世界上最大的电商网站 amazon
居然还在用 jQuery
。
创新互联专注为客户提供全方位的互联网综合服务,包含不限于网站制作、网站设计、师宗网络推广、微信小程序开发、师宗网络营销、师宗企业策划、师宗品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联为所有大学生创业者提供师宗建站搭建服务,24小时服务热线:18980820575,官方网址:www.cdcxhl.com
好奇的我又去翻了翻 jQuery
的源码,发现了下面这个奇妙的写法:
var elemData = initialValue
...
elemData.events = elemData = function(){};
...
elemData.events = {};
为了简单理解,这里省略了很多代码,完整源码:http://code.jquery.com/jquery-1.4.3rc1.js
初看还有点奇怪, elemData.events
为啥被赋值了两次?后面的赋值肯定会把前面覆盖掉啊?这怕不会是个 Bug 吧?
仔细想了下不对, jQuery
都已经稳定运行十几年了,哪还来的 Bug
?下面我们仔细分析下...
给变量赋值是我们代码里最常见的写法,但是你可能会忽略一点,赋值也属于一种表达式,这种表达式计算的值是赋值右侧 ( RHS
) 的值。比如下面的代码:
let x
if(x = 1) { // 1 is truthy
console.log(1) // 1
}
而且赋值运算符 =
是右结合的:
let a, b
a = b = 2 // the same as a = ( b = 2)
console.log(a) // 2
console.log(b) // 2
回到前面那段令人费解的 jQuery
代码
elemData.events = elemData = function(){};
它包含两种运算符:两个赋值运算符和一个属性访问运算符( elemData.events
)。
如果我们的一段代码里有不同类型的运算符, 运算符优先级表
会决定了哪种类型的运算符优先运算。
运算符优先级表:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Operator_Precedence#table
从 运算符优先级表
中我们得知:属性访问运算符的优先级为 18
,而赋值运算符只有 2
,这意味着属性访问运算符的优先级高于赋值运算符。
比如 obj.name = 'ConardLi'
这段代码,计算的第一个表达式是 obj.name
,解析为对 name
属性的引用,然后才是赋值操作。
把前面提到的两个知识点融合一下,我们在回顾下这段代码:
var elemData = initialValue // 1
// ...
elemData.events = elemData = function(){}; // 2
// ...
elemData.events = {}; // 3
elemData
initialValue
elemData.events
elemData = function(){}
elemData
function (){}
initialValue.events = function(){}
elemData
initialValue
elemData.events
属性指向 {}
可以看看下面这种图的总结:
这也让我回想起 for in
循环,当我们在循环进行到一半时改变对象的绑定(即给变量重新赋值),被枚举的属性不会直接改变,而是会等到循环结束后再变:
let obj = {a: 1, b: 2, c: 3}
let obj2 = {d: 1, e: 2, f: 3}
for(const prop in obj ) {
console.log(prop) // a, b, c
obj = obj2
}
console.log(obj) // { d: 1, e: 2, f: 3 }
这个模式挺巧妙的,其实我们很多业务场景的代码都可以利用下这种写法,比如我们可以来实现个链表:
let i = 0, root = { index: i }, node = root
while (i < 10) {
node.next = node = {} // `node` in `node.next` is the old `node`
node.index = ++i // `node` in `node.index` is the new `node`
}
node = root
do {
console.log(node.index) // 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10
} while ((node = node.next))
可以看下面这张图,其实是一样的道理:
文章标题:从jQuery源码中学到一个有意思的设计模式
文章网址:http://www.csdahua.cn/qtweb/news11/87261.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网