यहां कुछ उदाहरण दिए गए हैं जो लोगों को उनकी समस्याओं को बेहतर ढंग से समझने और उनका निवारण करने में मदद कर सकते हैं।
टी एल; डॉ
on*
ईवेंट हैंडलर (जैसे onclick
एक बटन तत्व पर विशेषता): ईवेंट को रद्द करने के लिए गलत लौटें
addEventListener
एक अलग एपीआई है, वापसी मान (जैसे false
) को नजरअंदाज किया जाता है: उपयोग event.preventDefault()
।
onclick="<somejs>"
अपने स्वयं के संभावित भ्रम की स्थिति है क्योंकि <somejs>
ऑन्कलिक फ़ंक्शन के शरीर में लिपटे हुए हैं।
getEventListeners
यदि आपका ईवेंट हैंडलर अपेक्षा के अनुरूप व्यवहार नहीं कर रहा है, तो यह देखने के लिए कि आपके ईवेंट श्रोता को समस्या निवारण के लिए कैसा दिखता है, ब्राउज़र devtools API का उपयोग करें ।
उदाहरण
यह उदाहरण लिंक के click
साथ ईवेंट के लिए विशिष्ट है <a>
... लेकिन अधिकांश ईवेंट प्रकारों के लिए इसे सामान्यीकृत किया जा सकता है।
हमारे पास क्लास के साथ एक एंकर (लिंक) है js-some-link-hook
जो हम एक मोडल खोलना चाहते हैं और किसी भी पेज नेविगेशन को होने से रोकते हैं।
नीचे दिए गए उदाहरण MacOS Mojave पर google chrome (71) में चलाए गए थे।
एक प्रमुख नुकसान यह है कि onclick=functionName
उपयोग करने के समान व्यवहार हैaddEventListener
मान लीजिए कि हमारे पास एक लंगर टैग (लिंक) है जिसे हम जावास्क्रिप्ट के साथ संभालना चाहते हैं जब जावास्क्रिप्ट सक्षम किया जाता है। हम नहीं चाहते कि ब्राउज़र लिंक पर क्लिक करें ("डिफ़ॉल्ट" व्यवहार को रोकें)।
<a href="https://www.example.com/url/to/go/to/when/no/javascript"
class="js-some-link-hook">click me!</a>
विशेषता पर क्लिक करें
function eventHandler (event) {
alert('eventHandler ran');
return false;
}
function addEventListenerToElement () {
var link = document.querySelector('.js-some-link-hook');
link.setAttribute('onclick', eventHandler);
}
addEventListenerToElement();
फिर ब्राउज़र devtools कंसोल में चलाएं:
var el = document.querySelector('a.js-some-link-hook'),
listener = getEventListeners(el).click[0].listener;
console.log(''+listener);
... और आप देखें:
function onclick(event) {
function eventHandler (event) {alert('eventHandler ran'); return false;}
}
यह बिल्कुल काम नहीं करता है। onclick=
अपने हैंडलर फ़ंक्शन का उपयोग करते समय किसी अन्य फ़ंक्शन में लपेटा जाता है।
आप देख सकते हैं कि मेरी फ़ंक्शन परिभाषा शामिल है, लेकिन इसे कॉल नहीं किया गया है क्योंकि मैंने इसे संदर्भित किए बिना फ़ंक्शन संदर्भ निर्दिष्ट किया है। यानी हमें यह सुनिश्चित करने की आवश्यकता onclick="functionName()"
नहीं onclick="functionName"
है कि functionName
तत्व को क्लिक करने पर चलाया जाए।
इसके अलावा, आप देख सकते हैं कि भले ही मेरे फ़ंक्शन को कॉल किया गया था और मेरा फ़ंक्शन गलत लौटा था ... onclick
फ़ंक्शन उस गलत मान को वापस नहीं करेगा ... जिसे इवेंट को 'रद्द' करना आवश्यक है।
इसे ठीक करने के लिए, हम वह सेट कर सकते onclick
हैं return myHandlerFunc();
जो यह सुनिश्चित करता है कि onclick
रिटर्न वैल्यू (गलत) रिटर्न से myHandlerFunc
।
तुम भी निकाल सकते return false;
से myHandlerFunc
और परिवर्तन onclick
होने के लिए myHandlerFunc(); return false;
, लेकिन यह कम समझ में आता है जैसा कि आप शायद तर्क अपने हैंडलर समारोह में एक साथ रखना चाहते हैं।
onclick
जावास्क्रिप्ट के साथ सेटिंग करते समय ध्यान दें , जब आप onclick
जावास्क्रिप्ट (मेरे उदाहरणों की तरह) के बजाय सीधे html में सेट कर रहे हैं , तो onclick
विशेषता मान टाइप स्ट्रिंग और सब कुछ काम करता है। यदि आप onclick
जावास्क्रिप्ट का उपयोग कर सेट कर रहे हैं , तो आपको टाइप करने पर ध्यान देने की आवश्यकता है। यदि आप कहते हैं कि element.setAttribute('onclick', myHandlerFunc())
myHandlerFunc
अभी चलाया जाएगा और परिणाम प्रत्येक क्लिक पर चलने के बजाय विशेषता में संग्रहीत किया जाएगा। इसके बजाय आपको यह सुनिश्चित करना चाहिए कि विशेषता मान स्ट्रिंग के रूप में सेट है। element.setAttribute('onclick', 'return myHandlerFunc();')
अब जब हम देखते हैं कि यह कैसे काम कर रहा है, तो हम जो चाहें वह करने के लिए कोड को संशोधित कर सकते हैं। उदाहरण के उद्देश्यों के लिए अजीब उदाहरण (इस कोड का उपयोग न करें):
function eventHandler (e) {
alert('eventHandler ran');
console.log(e);
return false;
}
function addEventListenerToElement () {
var link = document.querySelector('.js-some-link-hook');
link.setAttribute('onclick', 'return ('+eventHandler+')(event);');
}
addEventListenerToElement();
आप देखते हैं कि हमने अपने ईवेंटहैंडलर फ़ंक्शन की परिभाषा को स्ट्रिंग में लपेट दिया है। विशेष रूप से: एक स्व-निष्पादन वाला कार्य जो कि फ्रंट में रिटर्न स्टेटमेंट है।
फिर से क्रोम devtools कंसोल में:
var el = document.querySelector('a.js-some-link-hook'),
listener = getEventListeners(el).click[0].listener;
console.log(''+listener);
...दिखाता है:
function onclick(event) {
return (function eventHandler (e) {
alert('eventHandler ran');
console.log(e);
return false;
})(event);
}
... तो हाँ, यह काम करना चाहिए। इतना ज़रूर है कि अगर हम लिंक पर क्लिक करते हैं तो हमें अलर्ट मिलता है और अलर्ट को खारिज करते हुए पेज कहीं भी नेविगेट या रिफ्रेश नहीं होता है।
एक और ध्यान दें onclick
... यदि आप event
घटना के समय पैरामीटर प्राप्त करना और उसका उपयोग करना चाहते हैं , तो आपको ध्यान देना चाहिए कि इसे "ईवेंट" नाम दिया गया है। आप नाम का उपयोग करके अपने event
अभिभावक के पास इसे एक्सेस कर सकते हैं (पैरेंट onclick
फंक्शन स्कोप के माध्यम से उपलब्ध )। या आप event
एक पैरामीटर (परीक्षण के लिए बेहतर) के रूप में लेने के लिए अपने हैंडलर का निर्माण कर सकते हैं ... उदाहरण के लिए onclick="return myEventHandler(event);"
या जैसा कि आप पिछले उदाहरण में देखते हैं।
addEventListener
function eventHandler (ev) {
alert('eventHandler ran');
console.log(ev);
return false;
}
function addEventListenerToElement () {
var link = document.querySelector('.js-some-link-hook');
link.addEventListener('click', eventHandler, false);
}
addEventListenerToElement();
ब्राउज़र devtools:
var el = document.querySelector('a.js-some-link-hook'),
listener = getEventListeners(el).click[0].listener;
console.log(''+listener);
परिणाम:
function eventHandler (ev) {
alert('eventHandler ran');
console.log(ev);
return false;
}
तो आप पहले से ही अंतर देख सकते हैं। साथ addEventListener
हम एक में लिपटे नहीं कर रहे हैं onclick
कार्य करते हैं। हमारा हैंडलर event
सीधे पैरामीटर प्राप्त करता है (और इसलिए हम इसे जो चाहें कह सकते हैं)। इसके अलावा हमारे return false
यहां "शीर्ष स्तर" पर है और हमें इसके साथ अतिरिक्त रिटर्न स्टेटमेंट जोड़ने के बारे में चिंता करने की आवश्यकता नहीं है onclick
।
तो ऐसा लगता है कि यह काम करना चाहिए। लिंक पर क्लिक करके हमें अलर्ट मिलता है। अलर्ट को खारिज कर दें और पृष्ठ नेविगेट / ताज़ा करें। यानी झूठी लौटकर घटना को रद्द नहीं किया गया था।
यदि हम युक्ति खोजते हैं (नीचे संसाधन देखें), तो हम देखते हैं कि addEventListener के लिए हमारा कॉलबैक / हैंडलर फ़ंक्शन रिटर्न प्रकार का समर्थन नहीं करता है। हम जो चाहें वापस कर सकते हैं, लेकिन चूंकि यह ब्राउज़र एपीआई / इंटरफ़ेस का हिस्सा नहीं है, इसलिए इसका कोई प्रभाव नहीं पड़ता है।
समाधान: के event.preventDefault()
बजाय का उपयोग कर return false;
...
function eventHandler (ev) {
ev.preventDefault();
alert('eventHandler ran');
}
function addEventListenerToElement () {
var link = document.querySelector('.js-some-link-hook');
link.addEventListener('click', eventHandler, false);
}
addEventListenerToElement();
ब्राउज़र devtools ...
var el = document.querySelector('a.js-some-link-hook'),
listener = getEventListeners(el).click[0].listener;
console.log(''+listener);
देता है ...
function eventHandler (ev) {
ev.preventDefault();
alert('eventHandler ran');
}
...जैसा सोचा था।
फिर से परीक्षण:
- लिंक पर क्लिक करें।
- अलर्ट हो जाएं।
- अलर्ट को खारिज करें।
- कोई पृष्ठ नेविगेशन या ताज़ा नहीं होता है ... जो हम चाहते हैं।
तो झूठे के रूप में addEventListener
उपयोग event.preventDefault()
के साथ कुछ भी नहीं करता है।
साधन
एचटीएमएल 5 कल्पना ( https://www.w3.org/TR/html5/webappapis.html#events ) बातें confuses क्योंकि वे दोनों का उपयोग onclick
और addEventListener
उनके उदाहरण में और वे निम्नलिखित कहते हैं:
ईवेंट हैंडलर एच और एक इवेंट ऑब्जेक्ट ई के लिए ईवेंट हैंडलर प्रोसेसिंग एल्गोरिथ्म इस प्रकार है:
...
- प्रक्रिया वापसी मूल्य निम्नानुसार है:
...
यदि वापसी मान एक वेब IDL बूलियन गलत मान है, तो ईवेंट रद्द करें।
तो यह सूचित करते हैं कि लगता है return false
दोनों के लिए घटना को रद्द करता है addEventListener
और onclick
।
लेकिन, अगर आप उनकी जुड़ी हुई परिभाषा को event-handler
देखते हैं:
एक इवेंट हैंडलर का एक नाम है, जो हमेशा "चालू" से शुरू होता है और उसके बाद उस इवेंट के नाम से शुरू होता है, जिसके लिए उसका इरादा है।
...
इवेंट हैंडलर दो तरीकों में से एक में उजागर होते हैं।
पहला तरीका, सभी इवेंट हैंडलर के लिए सामान्य, एक इवेंट हैंडलर IDL विशेषता के रूप में है।
दूसरा तरीका एक ईवेंट हैंडलर सामग्री विशेषता के रूप में है। HTML तत्वों पर ईवेंट हैंडलर और विंडो ऑब्जेक्ट्स पर कुछ ईवेंट हैंडलर इस तरह से उजागर होते हैं।
https://www.w3.org/TR/html5/webappapis.html#event-handler
तो ऐसा लगता है कि return false
वास्तव में ईवेंट रद्द करना केवल onclick
(या आम तौर पर on*
) ईवेंट हैंडलर्स पर लागू होता है, न कि उन हैंडलर्स को ईवेंट करने के लिए addEventListener
जिनके द्वारा एक अलग एपीआई है।
चूंकि addEventListener
API html5 स्पेक (केवल on*
ईवेंट हैंडलर) के तहत कवर नहीं किया गया है ... यदि वे on*
अपने उदाहरणों में स्टाइल ईवेंट हैंडलर से चिपके रहते हैं तो यह कम भ्रामक होगा ।