js/vue/jq——事件委托

74 篇文章 0 订阅
9 篇文章 0 订阅

事件委托好处:
1,性能好
2,新添加的元素会动态跟踪事件

js事件委托

window.onload = function(){
  var Ul = document.getElementById("ul");
  var Li = oUl.getElementsByTagName("li");

/*
event:事件源,在哪个事件中,操作的那个元素就是事件源
ie浏览器:window.event.srcElement
标准下:event.target
nodeName:找到元素的标签名
*/
  Ul.onmouseover = function(ev){
    var ev = ev || window.event;
    var target = ev.target || ev.srcElement;
    if(target.nodeName.toLowerCase() == "li"){
    target.style.height = "100px";
    }
  }
  Ul.onmouseout = function(ev){
    var ev = ev || window.event;
    var target = ev.target || ev.srcElement;
    if(target.nodeName.toLowerCase() == "li"){
    target.style.height = "200px";
    }
  }
}

关于更多event事件源,参见:https://blog.csdn.net/lucky541788/article/details/81809283
vue事件委托

	<div class="preview" ref="preview" @click="deleteCanvas($event)"></div>

	// methods
	deleteCanvas (e) {
		// 功能:点击删除其对应的子元素
        this.$refs.preview.removeChild(e.target)
      }

jq事件委托

<ul>
    <li>我是第1个li</li>
    <li>我是第2个li</li>
    <li>我是第3个li</li>
</ul>
<button>新增一个li</button>
$(function () {
            $('button').click(function () {
                $('ul').append("<li>我是第0个li</li>");
            });
            // $('ul>li').click(function () {
            //     alert($(this).text());
            // });
            $('ul').delegate('li', 'click', function () {
                alert($(this).text());
            })
        });
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值