मुझे कुछ jQuery कोड के साथ कुछ समस्याएं आ रही हैं, और मैं उम्मीद कर रहा हूं और सोच रहा हूं कि समाधान अपेक्षाकृत सरल है।तालिका पंक्ति पर ईवेंट पर क्लिक करें - केवल तभी ट्रिगर करें यदि कुछ भी 'क्लिक नहीं किया गया'
मैं की तरह एक मेज है कहते हैं:
<table>
<tr>
<td><input type="checkbox" name="hai" value="der" /></td>
<td><a href="mypage.php">My link</a></td>
<td>Some data</td>
<td>Some more data</td>
</tr>
...
</table>
अब जावास्क्रिप्ट के माध्यम से मैं jQuery में निम्नलिखित (document) .ready करना();
jQuery("table tr").click(function(){
var row = jQuery(this);
var hasClass = row.hasClass("highlight");
jQuery("table tr").removeClass("highlight");
if(!hasClass){
row.addClass("highlight");
}
});
यह सब बहुत सरल सामान है - मैं एक पंक्ति क्लिक करने के लिए सक्षम होना चाहते हैं और वह हाइलाइट किया जा रहा है और केवल एक पंक्ति एक समय में प्रकाश डाला जा सकता है (जाहिर है अपने वास्तविक कोड में मुझे लगता है कि अधिक से अधिक करना) - अब मेरी समस्या है:
जब कोई उपयोगकर्ता एंकर टैग या चेकबॉक्स पर क्लिक करता है, तो यह पंक्ति क्लिक ईवेंट को भी ट्रिगर करता है और मैं इसे फ़िल्टर करने के तरीके को कैसे काम नहीं कर सकता? मुझे पता है कि मुझे अपने क्लिक हैंडलर में ईवेंट शामिल करने की आवश्यकता है, लेकिन इस तरह से इस तरह की जांच कैसे करें कि यह जितना संभव हो उतने ब्राउज़रों में काम करता है?
आप कृपया समझा सकते हैं कि क्या यह वास्तव में इसका मतलब है? – darkapple
@ डार्कापल घटनाएं डीओएम के माध्यम से उच्च स्तर के तत्वों पर हैंडलर तक बुलबुला करती हैं। प्रचार को रोककर, हम ब्राउज़र को बताते हैं कि घटना को उन तत्वों तक नहीं पारित करें और इस प्रकार उनके हैंडलर कभी नहीं बुले जाएंगे। रिटर्निंग सत्य तत्व को जारी रखने के लिए डिफ़ॉल्ट क्रिया की अनुमति देता है (उदाहरण के लिए, एक नए पृष्ठ पर ले जाने वाला लिंक)। तो इस मामले में, हम हैंडलर का आह्वान नहीं करते हैं जो पंक्ति या हाइलाइट पर क्लिक नहीं किया जाता है अगर लिंक या चेकबॉक्स क्लिक किया जाता है, लेकिन यदि पंक्ति में कुछ और है। – tvanfosson
स्पष्टीकरण के लिए धन्यवाद। मैं आश्चर्यचकित था कि वापसी का क्या सच था। – darkapple