面试手写代码之-委托事件

这应该是面试时手写常考题了,但是从来没具体写过,被问道时也是让我说下大概思路就行,现在特意手写练习一下。代码形式就是模仿jquery的形式,不多说直接上一个html文件代码 有什么问题欢迎指正交流

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <style>
  ul,li {list-style: none}
  ul {
    padding: 20px;
    border: 1px solid red;
    cursor: pointer;
  }
  li {
    padding: 0 40px;
    height: 40px;
    line-height: 40px;
    border: 1px solid green;
    text-align: center;
    margin-bottom: 10px;
  }
  span {
    background: lightblue;
    color: red;
    display: inline-block;
    height: 30px;
    line-height: 30px;
    padding: 0 40px;
  }
  </style>
</head>
<body>
  <ul class="ul">
    <li>
      <span class="span text" id="span1">第1个span标签</span>
    </li>
    <li>
      <span class="span" id="span1">第2个span标签</span>
    </li>
    <li>
      <span class="span" id="span1">第3个span标签</span>
    </li>
  </ul>
  <script>
  const ul = document.querySelector('.ul')
  const lis = ul.querySelectorAll('li')
  const spans = ul.querySelectorAll('span')

  // 给ul添加一个on方法
  // type 事件类型
  // selector 元素节点选择器 仅支持标签名 id class三种
  // callback 回调处理方法
  // data 传入的数据 任意类型
  ul.on = function(type, selector, callback, data){
    ul.addEventListener(type, function(e){
      let target = e.target

      // console.log(target.tagName)
      // console.log(target.getAttribute('class'))
      // console.log(target.getAttribute('id'))

      // 按标签名匹配
      if (target.tagName.toLowerCase() === selector) {
        return callback(e, data)
      }

      // 按id名匹配
      if (target.getAttribute('id') === selector) {
        return callback(e, data)
      }

      // 按class名匹配
      let classStr = target.getAttribute('class')
      if (classStr && classStr.split(' ').indexOf(selector.slice(1)) !== -1) {
        return callback(e, data)
      }

    })
  }
  
  // 使用实例
  ul.on('click', 'li', function(e, data){
    console.log(data)
  }, 'hello')

  ul.on('click', 'span', function(e, data){
    console.log(data)
  }, 'hello span')

   ul.on('click', '.text', function(e, data){
    console.log(data)
  }, 'hello text span')
  </script>
</body>
</html>
复制代码
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值