mousedown। भाई बहन पर प्रचार event.targets
मैं 'स्थिति पूर्ण' जो दोनों mousedown घटना को संभालने के साथ 2 भाई-नोड्स की है। जब मैं 'div 2' (चित्र पर) के पारदर्शी क्षेत्र पर क्लिक कर रहा हूं, तो मैं 'div 1' के हैंडलर को कैसे ट्रिगर कर सकता हूं।
mousedown। भाई बहन पर प्रचार event.targets
मैं 'स्थिति पूर्ण' जो दोनों mousedown घटना को संभालने के साथ 2 भाई-नोड्स की है। जब मैं 'div 2' (चित्र पर) के पारदर्शी क्षेत्र पर क्लिक कर रहा हूं, तो मैं 'div 1' के हैंडलर को कैसे ट्रिगर कर सकता हूं।
अतिव्यापी तत्वों गतिशील हैं, तो मुझे नहीं लगता कि यह इस का उपयोग करते हुए नियमित रूप से घटना बुदबुदाती पूरा करने के लिए के बाद से सवाल में दो अतिव्यापी तत्व हैं "भाई बहन" संभव है।
मुझे एक ही समस्या थी और मैं इसे हिटटेस्ट स्केनेरियो के साथ हल करने में सक्षम था, जहां मैं परीक्षण करता हूं कि उपयोगकर्ता की माउस स्थिति उसी क्षेत्र में है या नहीं।
function _isMouseOverMe(obj){
var t = obj.offset().top;
var o = obj.offset().left;
var w = obj.width();
var h = obj.height();
if (e.pageX >= o+1 && e.pageX <= o+w){
if (e.pageY >= t+1 && e.pageY <= t+h){
return true;
}
}
return false
}
आप 3 ईवेंट हैंडलर का उपयोग करना चाहेंगे, एक div1 के लिए, एक div2 के लिए, और सामग्री के लिए एक एरिया। सामग्री एरिया हैंडलर को प्रचार रोकना चाहिए ताकि div2 हैंडलर को नहीं बुलाया जा सके। DIV2 हैंडलर div1 हैंडलर बुलाना चाहिए:
function div1Click (e)
{
// do something
}
function div2Click (e)
{
div1Click.call(div1, e);
}
function contentAreaClick (e)
{
e = e || window.event;
if (e.stopPropagation) e.stopPropagation();
e.cancelBubble = true;
// do something
}
div1.onclick = div1Click;
div2.onclick = div2Click;
contentArea.onclick = contentAreaClick;
समस्या मेरे मामले में, है, मैं कई जैसे divs है और वे गतिशील (खींचने योग्य) कर रहे हैं और div1 एक ही संरचना है, इसलिए मैं इस तरह से – AlaskaKid
धन्यवाद संभाल घटनाओं नहीं कर सकता कि, मैं वास्तव में यह किया इसी तरह से – AlaskaKid