实现一个 jQuery 的 API

window.jquery = function(nodeOrSelector){
    let nodes = {};
    if(typeof nodeOrSelector === 'string'){
        //nodes = document.querySelectorAll(nodeOrSelector);//包含node的原型链
        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){
        for(let key in classes){
            var value = classes[key];
            var methodName = value ? 'add' : 'remove';
            for(let i=0;i<nodes.length;i++){
                nodes[i].classList[methodName](key);
            }
        }
    }
    /*nodes.getText = function(){
        var texts = [];
        for(let i=0;i<nodes.length;i++){
            texts.push(nodes[i].textContent)
        }
        return texts;
    }
    nodes.setText = function(text){
        for (var i = nodes.length - 1; i >= 0; i--) {
            nodes[i].textContent = text;
        }
    }*/
    nodes.text = function(text){
        if(text === undefined){
            var texts = [];
            for (let i = nodes.length - 1; i >= 0; i--) {
                texts.push(nodes[i].textContent);
            }
            return texts;
        }else{
            for (let i = nodes.length - 1; i >= 0; i--) {
                nodes[i].textContent = text;
            }
        }
    }
    return nodes;
}

var node2 = jquery('ul > li');
node2.addClass({a:true,b:false,c:true});
node2.text('hi');
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 阮一峰jQuery 不要学jquery mobile 获取某个节点的所有兄弟姐妹 ul>li[id=item$]{...
    tsl1127阅读 377评论 0 2
  • 某统计网站的数据统计 ,使用jQuery的比例占70%左右。我们来看看jQuery 到底做了哪些事情,给开发者带来...
    怎么昵称阅读 231评论 0 1
  • 实现一个jQuery的API 主要实现以下的功能 给元素增加class 给对应的元素设置文本 实现过程 首先声明一...
    qfstudy阅读 196评论 0 1
  • 没有看错,这是公号第100篇原创。这是一个有纪念意义的数字,在2016年岁末的时候,原创到了第100篇。一路走来,...
    黑脸阿康阅读 415评论 2 6
  • 今天主题:孝德团队第一届线上换食营冠军之夜 今晚是我们孝德团队第一届线上换食营7天换食结营的美好之夜!心中充满了无...
    耕读传家林亮伟阅读 159评论 0 1