用javascript写了一个树状组件,mouseover出现的元素没法和click事件绑定,应该如何解决?
黄舟
黄舟 2017-04-11 09:13:05
0
3
423

https://yisha0307.github.io/I...

上面是我写的demo~有个问题是我mouseover的时候后面会出现一个x和一个+,然后我把click事件绑在上面,用的是

$('body').on('click','.fa-times',dele)

dele表示的是一个window.prompt的function;然而我无法click到这个元素,为什么呢?

这是我的js代码:
https://github.com/yisha0307/...

html:
https://github.com/yisha0307/...

应该要怎么修改呢?谢谢各位!

黄舟
黄舟

人生最曼妙的风景,竟是内心的淡定与从容!

全員に返信(3)
PHPzhong

我认为是这里的问题:

$('body').on('mouseover','span',showicon);
$('body').on('mouseout','span',hideicon);

可以改成这样试试:

$('body').on('mouseenter','span',showicon);
$('body').on('mouseleave','span',hideicon);

而且,不建议直接使用span来绑事件,最好使用class

いいねを押す +0
洪涛

动态添加到DOM的元素(比如你的fa-times是动态添加的吧?),使用on()时要绑定到document对象上。
这样试试:

$(document).on('click','.fa-times',dele);
いいねを押す +0
阿神

html:
每项后面都先加上, 不要每次移入移出都要操作dom

<i id="special" class="fa fa-folder-open" aria-hidden="true"></i>

js:

var showicon = function(){
   $(this).find(".fa").show();
}

var hideicon=function(){
   $(this).find(".fa").hide();
}

css:

.fa{
    display:  none;
}

还有像楼上说的, 不是不建议用span 绑定, 是不能用. 建议题主多了解HTML语义化

いいねを押す +0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート