实现一个 jQuery 的 API

思路

  • 判断传入的参数类型,选择器则选取对应全部元素,元素则放入伪数组
  • 通过DOM操作,实现添加class与修改内容
<!DOCTYPE html>
<html>
    <head>
        <meta charset="{CHARSET}">
        <title></title>
        <style>
          .red{color: red;}
        </style>
        
    </head>
    <body>
      <div>11</div>
      <div>11</div>
      <div>11</div>
      <div>11</div>
      <script>
      window.jQuery = function(nodeOrSelector){
        let nodes = {}
        if(typeof nodeOrSelector === 'string'){
          let temp = document.querySelectorAll(nodeOrSelector)
          for(let i = 0; i < temp.length;i++){
            nodes[i] = temp[i]
          }
          nodes.length = temp.length
        }else if(nodeOrSelector instanceof Node){
          nodes = {
            0:nodeOrSelector,
            length:1
          }
        }
        nodes.addClass = function(classes){
          classes.forEach((value)=> {
            for (let i = 0;i<nodes.length;i++){
              nodes[i].classList.add(value)
            }
          })
        }
        
        
        nodes.setText = function(classes){
          classes.forEach((value)=> {
            for (let i = 0;i<nodes.length;i++){
              nodes[i].textContent = value
            }
          })
        }
        return nodes
      }
      window.$ = jQuery
      
      
    </script>
    </body>
</html>
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 获取目标节点的兄弟节点 1.先获取该节点父节点的所有子标签,装入allchildren对象2创建arrary对象3...
    实肆阅读 289评论 0 0
  • 某统计网站的数据统计 ,使用jQuery的比例占70%左右。我们来看看jQuery 到底做了哪些事情,给开发者带来...
    怎么昵称阅读 231评论 0 1
  • 实现一个jQuery的API功能有: 给获取到的元素增加class 给获取到的元素设置文本 实现思路: 大视角:根...
    xyyojl阅读 407评论 0 1
  • 需要实现的效果:1.可将所有 div 的 class 添加一个 red2.可将所有 div 的 textConte...
    YukiWeng阅读 200评论 1 0
  • 20150617 キミがいれば 作詞:高柳恋作曲:大野克夫歌:伊織 うつむく その背中に痛い雨が つき刺さる祈る想...
    闲谢阅读 591评论 0 2