实现一个 $attr(name,value) 遍历;属性为 name 值为 value 的元素集合

<body>
  <div class="box clearfix"></div>
  <div name="zs"></div>
  <div class="box"></div>
  <div name="ls"></div>
  <div class="attr"></div>
  <div class="box2"></div>
  <div class="box A"></div>
</body>
 
--------------------------------------------------------------------------------------------------------------------------------------
 
function $attr(property, value) {
  // 获取当前页面中所有的标签
  let elements = document.getElementsByTagName('*'),
    arr = [];
  elements = Array.from(elements); // => 把非数组转换为数组
  elements.forEach(item => {
    // => 储存的是当前元素 property 对应的属性值
    let itemValue = item.getAttribute(property);
    if (property === 'class') {
      // => 样式类属性名要特殊处理
      new RegExp("\\b" + value + "\\b").test(itemValue) ? arr.push(item) : null;
      return;
    }
    if (itemValue === value) {
      // => 获取的值和传递的值校验成功
      arr.push(item);
    }
  });
return arr;
}
console.log($attr('class', 'box'));
posted @ 2020-04-01 23:29  YuTing-721  阅读(238)  评论(0编辑  收藏  举报