实现一个 jQuery 的 API

代码

window.jQuery=function(nodeOrSelector){
  let nodes=[]
  if(nodeOrSelector === 'string'){
    let temp = document.querySelectorAll(nodeSelector)
    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(text){
    for(let i=0;i<nodes.lenght;i++)
      {
        nodes[i].textContent=text
      }
  }
  return nodes
}

获取dom节点

1.要判断传入的是字符串还是节点
2.最后要封装成一个伪数组

编写addClass方法

1.forEach方法遍历传入的参数数组
2.遍历第一步的伪数组,用dom api给数组中节点添加类
3.把该方法添加到伪数组中(node.addClass=function...)

编写setText方法

1.遍历第一步的伪数组,用dom api提供的textContent更新数组节点的文本
3.把该方法添加到伪数组中(node.setText=function...)

注意

window.$ = jQuery
var $div = $('div')

用jQ取值并赋值给变量时给变量前面加$

instanceof

instanceof运算符用于测试构造函数的prototype属性是否出现在对象的原型链中的任何位置

  • 事例
function C(){} 
function D(){} 

var o = new C();

o instanceof C; // true,因为 Object.getPrototypeOf(o) === C.prototype

o instanceof D; // false,因为 D.prototype不在o的原型链上
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 最近开始学习 jQuery,jQuery 是 JavaScript最受欢迎的一个库,它让原本极不方便的JS DOM...
    不讨喜的大雄阅读 3,759评论 0 1
  • 某统计网站的数据统计 ,使用jQuery的比例占70%左右。我们来看看jQuery 到底做了哪些事情,给开发者带来...
    怎么昵称阅读 1,634评论 0 1
  • 想要实现一个以下功能用原生js的DOM API来实现一个类jQuery API的功能 1、首先获取DOM元素 判断...
    小白兔养家阅读 1,306评论 0 0
  • 实现一个jQuery的API功能有: 给获取到的元素增加class 给获取到的元素设置文本 实现思路: 大视角:根...
    xyyojl阅读 3,064评论 0 1
  • L问我是不是生气了,回答他说没有。而其实事实上还是有的。只是似乎已经习惯了如此的口是心非。应该是从13年过后吧,喜...
    一直是晴天阅读 1,207评论 0 0

友情链接更多精彩内容