• 可想实现一个自己的简单jQuery库?(五)


    Lesson-4


    这个版本我们要增加一个用的非常多的方法!

    那就是each!

    我们知道each不仅能遍历数组,还能遍历对象.

    首先我们需要一个对数组进行验证的方法

    function isArray(obj) {
        return Array.isArray(obj);
    }

    接着就是我们的重头戏

    Kodo.each = function(obj,callback) {
        var len = obj.length,
            constru = obj.constructor,
            i = 0;
    
        if(constru === window.f) {
            for (; i < len; i++) {
                var val = callback.call(obj[i],i,obj[i]);
                if(val === false) break;
            }
        } else if (isArray(obj)) {
            for (; i < len; i++) {
                var val = callback.call(obj[i],i,obj[i]);
                if(val === false) break;
            }
        } else {
            for( i in obj ) {
                var val = callback.call(obj[i],i,obj[i]);
                if(val === false) break;
            }
        }
    
    };

    因为我们还可能遍历Kodo数组对象

    f("div").each(function(index,item) {
    
    })

    所以还需要一个判断 是否是Kodo数组对象

    if(constru === window.f) {
        for (; i < len; i++) {
            var val = callback.call(obj[i],i,obj[i]);
            if(val === false) break;
        }
    }

    在这应该强调下call的用法,还是很多人不知道call何时使用.

    在我们的callback里 第一个参数是下标,第二个参数是当前的对象,然后this还要指向他自己

    所以 callback.call(obj[i],i,obj[i]); 就是这样写 第一个参数是改变this指向,第二个参数是下标,第三个是自己本身

    很简单不是吗?

    既然你都看到这里了,还不给我一个star?!

    github地址: https://github.com/MeCKodo/forchange/tree/master/lesson-4
    可想造一个属于你自己的jQuery库?(四):http://segmentfault.com/a/1190000004001281

  • 相关阅读:
    ubuntu16.04安装破解pycharm
    python解压,压缩,以及存数据库的相关操作
    cocoapods Error
    swift项目导入OC框架
    实现全屏滑动返回效果
    Storyboard & XIB 自己的理解
    View & Controller 一些方法的执行顺序
    Touch ID 实现
    Apple Pay 初探
    ReactiveCocoa学习
  • 原文地址:https://www.cnblogs.com/10manongit/p/12666218.html
Copyright © 2020-2023  润新知