javascript - Firebug: "event is not defined" -
मेरे पास इन विधियों के साथ एक कन्स्ट्रक्टर है:
function getMouseXY (ईवेंट) {var x = event ClientX - this.offsetLeft; Var y = event.clientY - this.offsetTop; वापसी [एक्स, वाई]; } फ़ंक्शन चेतावनी () {var c = this.getMouseXY (ईवेंट); चेतावनी (ग [0]); } एचटीएमएल कोड में मैं एक एचटीएमएल 5 कैनवास 'इवेंट माउसअप में अलर्टएक्स फ़ंक्शन को असाइन करता हूं:
document.getElementById (' केबैगग्राउंड ')। AddEventListener (' mouseup ', object.alertx , असत्य); अपेक्षित परिणाम क्या है? कैनवास पर क्लिक करने से यह माउस की एक्स स्थिति को दर्शाता है, इसके बजाय मुझे कुछ भी नहीं मिला। फायरबग के साथ आगे की अन्वेषण मुझे "घटना परिभाषित नहीं है" त्रुटि मिलती है मुझे नहीं पता कि इससे कैसे बचें! कोई सुझाव? धन्यवाद!
कुछ मुद्दे देखें:
- कोड> अलर्टएक्स () एक
ईवेंटतर्क प्राप्त नहीं करता है। - उस फ़ंक्शन में आप
getMouseXYकोका उपयोग कर कॉल कर रहे हैं। उस समय के इस खोजशब्द, उस तत्व को देखेंगे जो ईवेंट को ट्रिगर करेगा। - आप ईवेंट हैंडलर को अज्ञात
वस्तुचर में बाध्य कर रहे हैं।
मुझे लगता है कि आप ऐसा कुछ करना चाहते हैं:
फ़ंक्शन getMouseXY (ईवेंट) {var x = event.clientX - this.offsetLeft, // नोटिस, 'यह' प्रयोग किया जाता है y = इवेंट। क्लिथिइ - यह। ओफ़सेटटॉप; वापसी [एक्स, वाई]; } समारोह चेतावनी (घटना) {var सी = getMouseXY.call (यह, घटना); // तत्व को 'यह' चेतावनी के रूप में सेट करें (c [0]); } और अगर आपके पास कन्स्ट्रक्टर फ़ंक्शन है, और उपर्युक्त कार्य करने का उदाहरण है, तो आप ऐसा कुछ कर सकते हैं:
function MyObject () { // कंस्ट्रक्टर} MyObject.prototype.getMouseXY = फ़ंक्शन (ईवेंट) {var x = event.clientX - this.offsetLeft, y = event.clientY - this.offsetTop; वापसी [एक्स, वाई]; }; MyObject.prototype.alertx = समारोह (घटना, तत्व) {var c = this.getMouseXY.call (तत्व, घटना); चेतावनी (ग [0]); } इस घटना को बंधन करते समय, आप संदर्भ को लागू करने के लिए एक अज्ञात समारोह जोड़ सकते हैं:
var वस्तु = नया MyObject (); Document.getElementById ('cbackground')। AddEventListener ('mouseup', फ़ंक्शन (e) {object.alertx (ई, यह); // सतर्कता को सही 'यह'}, झूठी) के साथ बुलाया जाएगा; संपादित करें: आपकी टिप्पणी के जवाब में, आपको सिर्फ यह जानना होगा कि सन्दर्भ ( यह कीवर्ड) निहित सेट करें:
जब आप एक उदाहरण विधि को कॉल करते हैं:
obj.method (); यह कीवर्ड के अंदर विधि , obj देखेंगे।
वही बात तब होती है जब आप ग्लोबल वैरिएबल कहते हैं, क्योंकि वे वैश्विक ऑब्जेक्ट के सदस्य हैं ( विंडो ब्राउज़र स्क्रिप्टिंग में):
वैश्विक फ़ंक्शन ();
के समतुल्य है:
window.globalFunction ();
और उस फ़ंक्शन के अंदर का संदर्भ वैश्विक ऑब्जेक्ट ही होगा ( विंडो )।
एक और मामला तब होता है जब आप नया ऑपरेटर:
var उदाहरण = नया MyConstructor ();
उस स्थिति में यह कीवर्ड एक नया ऑब्जेक्ट, new ऑपरेटर। जब आप कोई ईवेंट हैंडलर के रूप में किसी फ़ंक्शन का उपयोग करते हैं, तो यह कीवर्ड उस तत्व को संदर्भित करेगा जो ईवेंट को चालू करता है:
Document.getElementById ('myId')। Onclick = obj.myfunction;
उस स्थिति में myFunction एक obj की एक उदाहरण विधि है, लेकिन यह कीवर्ड का संदर्भ देगा DOM तत्व को क्लिक किया गया है।
और अंत में, जैसा कि आप मेरे कोड में देखते हैं, संदर्भ का उपयोग करके स्पष्ट रूप से सेट किया जा सकता है।
Comments
Post a Comment