javascript - AngularJS - Angular way of binding on parent to trigger child -
मेरे पास निम्न मार्कअप है:
& lt; div class = "parent" & gt; & Lt; div class = "child" & gt;
और मेरे पास दो निर्देश हैं, एक अभिभावक
और बच्चे
के लिए एक है। अब, माता पिता
पर एक घटना (क्लिक करें) पर, मुझे child
पर कुछ होने चाहिए (कहना है कि एक क्लिक हो)
ऐसा करने का jQuery का तरीका होगा:
app.directive ('parent', function () {return {restrict: 'c', link: function ( दायरा, तत्व, एटर्स) {element.bind ('click', function () {element.find ('। Child')। क्लिक करें ();})}}}}
और अगर मैं ग़लत नहीं हूँ, तो काइवर का रास्ता, मूल
में एक गुंजाइश बदल सकता है, और बच्चे में इसके लिए $ watch
:
App.directive ('parent', function () {return {restrict: 'c', link: function (scope, element, attrs) {scope.childEvent = false; element.bind ('click', function)) Scope.childEvent = true;});}}} एप्लिकेशन डायरेक्टिव ('बच्चे', फ़ंक्शन) {वापसी {प्रतिबंधित करें: 'सी', लिंक: फ़ंक्शन (स्कोप, एलिमेंट, एटर्स) {स्कोप। $ Watch ('childEvent ', फ़ंक्शन (मूल्य) {If (value) element.click (); }}}}}
क्या कोई मुझे बता सकता है कि कौन से विधि बेहतर है, और क्यों? पहली विधि निश्चित रूप से छोटी है, लेकिन ऐसा लगता है कि हर कोई कहता है कि काली रास्ता दूसरी विधि है (ताकि मैं jQuery का उपयोग न करें) मैं जानना चाहता हूं कि यदि मैं jQuery के रास्ते का उपयोग करता हूं तो क्या समस्याएं पैदा हो सकती हैं।
मुझे लगता है, दूसरा संस्करण आपकी समस्या को सुलझाने का "कोणीय रास्ता" है यह एक है (यदि आप किसी कोयोलर डेवलपर के दृश्य से देखते हैं) समाधान जो DOM मैनुअल को छेड़छाड़ किए बिना हो जाता है मेरी राय में कि अंगुलर जेएस का मुख्य विचार है: DOM मैनुअल में हेर-फेर करना बंद करो - अंगूठी आपके लिए ऐसा करें।
Comments
Post a Comment