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

Popular posts from this blog

Docker - Tomcat and PostgreSQL containers in same host - No Route to host -

Python Equivalent for matlab cart2pol and pol2cart -

java - Joda Time Interval Not returning what I expect -