javascript - JQuery rolling - stop previous & generalize -


मेरे पास ऐसा कोड है:

जावास्क्रिप्ट

  $ ( (Function () {$ ("a.link1") {$ ("a.link1")। क्लिक करें (फ़ंक्शन () {// $ (this) .stop ()। PreventDefault ()। ({Scrollopop: $ ("# link1") ऑफसेट ()। शीर्ष}, 2000);}};}); $ ("a.link2") क्लिक करें (फ़ंक्शन () { // $ (this) .stop ()। PreventDefault ()। चेतन (फ़ंक्शन () {$ ('html, body')। चेतन ({scrollTop: $ ("# link2")। ऑफसेट ()। शीर्ष}, 2000 ());}); $ ("a.link3") क्लिक करें (फ़ंक्शन () {// $ (this)। रोक ()। PreventDefault ()। चेतन (फ़ंक्शन () {$ (' एचटीएमएल, बॉडी ')। चेतन ({स्क्रोलटॉप: $ ("# लिंक 3") ऑफसेट ()। शीर्ष}, 2000);}};})}}};   

एचटीएमएल का शरीर:

  & lt; div id = "menu" & gt; & Lt; a href = '# link1' class = "link1" & gt; LINK 1 & lt; / a & gt; & Lt; a href = '# link2' class = "link2" & gt; LINK 2 & lt; / a & gt; & Lt; a href = '# link3' class = "link3" & gt; LINK 3 & lt; / a & gt; & Lt; / div & gt; & Lt; div id = "content" & gt; & Lt; a नाम = "link1" id = "link1" & gt; & lt; / a & gt; & Lt;! - कुछ पाठ - & gt; & Lt; a नाम = "link2" id = "link2" & gt; & lt; / a & gt; & Lt;! - कुछ पाठ - & gt; & Lt; एक नाम = "लिंक 3" आईडी = "लिंक 3" & gt; & lt; / a & gt; & Lt;! - कुछ पाठ - & gt; & Lt; / div & gt;   

कृपया मुझे इस के साथ मदद करें:

  1. रोक मैं जिस तरह से करना चाहता था काम करने के लिए नहीं लगता है। मैं एक तरफ पिछले रोलिंग को रोकना चाहता हूं जब एक और लिंक सक्रिय हो।
  2. क्या jQuery के भाग के सामान्यीकरण का कोई भी तरीका है। मेरे पास 3 से अधिक मेनू लिंक हैं और मैं प्रत्येक के लिए एक विशेष फ़ंक्शन नहीं बनाना चाहता।

    आपकी मदद के लिए बहुत बहुत धन्यवाद सामान्य कॉलम बैक को सामान्य कार्य में निकालने के द्वारा आप सामान्य बना सकते हैं:

         var लिंकक्लिक करेंबेलबैक = फ़ंक्शन (चयनकर्ता) {$ ('html, body')। रोक ()। चेतन ({scrollTop: $ (चयनकर्ता) .offset ()। Top}, 2000); } $ (दस्तावेज़) .ready (फ़ंक्शन () {$ ("a.link1")। क्लिक करें (लिंक क्लिक करें Callback.bind (null, '# link1')); $ ("a.link2")। क्लिक करें (linkClickCallback.bind (शून्य, '# लिंक 2')); $ ("a.link3")। क्लिक करें (लिंक क्लिक करें Callback.bind (null, '# link3'));});   

    ध्यान दें कि लिंक में क्लिक करेंक्लबैक मैंने भी स्टॉप () विधि का उचित उपयोग लिखा है।

    संपादित करें:

    यह मेनू में सभी आइटमों के लिए काम करेगा:

      $ (दस्तावेज़) .ready (function () {$ ("# menu a")। क्लिक करें (फ़ंक्शन (e) {e.preventDefault (); लिंकक्लिक करेंबैकबैक ('#' + this.className);});});   

    एक ही लिंक के साथक्लिक करेंबैकबैक फ़ंक्शन।

Comments

Popular posts from this blog

sonata admin - how to add ManyToOne property field in configureListfield in sonataAdmin -

wpf - ControlTemplate with changes for every class -

python - how we can use ajax() in views.py in django? -