javascript - 关于JQ源码中toArray的实现,有个问题不明白

查看:74
本文介绍了javascript - 关于JQ源码中toArray的实现,有个问题不明白的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

明白JQ源码将原生数组的方法slice赋给了变量core_slice,然后在toArray方法里,直接return core_slice.call(this)。这里的this应该是JQ对象实例,而JQ对象实例本身又不是数组,是个类似数组的JSON,比如找到通过$找到一堆class元素,console打印出来这个$对象是样子的:

然后直接调用数组的slice方法怎么可能会有这样的结果

slice方法不是截取数组中的某一段元素的吗,而且,调用slice方法的是JQ这个对象实例,这个实例又不是数组,里面还有length等属性,怎么就被slice方法调用时直接忽略掉的?

解决方案

  1. 这里的slice方法就是为了把你的c变成真正的数组

  2. 现在c不是真正的数组,所以为了引用slice方法,所以只能找个真正的数组,[]就是起这个作用的。

  3. 至于引用slice的到底是类原型还是实例其实没多大区别,因为你后面都要call来改变上下文的。
    如果你觉得[]不太好理解,那么这里改成Array.prototype.slice.call()是不是就清楚了?

  4. jq源码中用arr = []的原因有两个,一个是用变量代替之后,压缩代码的时候就能直接替换变量名字了,这样就能节省更多的空间,还有一个是避免操作中无意修改了Array原型的情况,操作起来更安全。

  5. 关于slice方法的原理,这种问题去翻规范,里面写的很清楚。

  6. 简单提一下,slice虽然是截取没错,但实际上是在过程中创建了一个新的数组,然后将旧数组中把被截取的部分浅复制一份,再把复制出来的元素放到新的数组中并返回。

  7. 关键就在于,当输入的(start, end)两个参数都是缺省的时候,将会自动变为start = 0; end = this.length;

  8. 所以,这里的[].slice(c),实际上就是把c这个类似数组但并不是数组的东西转变成真正的数组。唔……这么说也不太准确,准确的来说,c本身并没有变化,只是返回了一个新的数组,里面的元素和c数组中下标从0c.length - 1内的元素相等,其余别的属性并没有复制。

这篇关于javascript - 关于JQ源码中toArray的实现,有个问题不明白的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆