丝袜美腿美女被狂躁动态图片|麻豆视频免费在线观看|欧美日韩精品一区二区|天天爽亚洲中文字幕|久久久久九九精品影院|久久一区二区三区四区|人妻内射一区二区在线视频

丝袜美腿美女被狂躁动态图片|麻豆视频免费在线观看|欧美日韩精品一区二区|天天爽亚洲中文字幕|久久久久九九精品影院|久久一区二区三区四区|人妻内射一区二区在线视频

Internet Develppment
互聯(lián)網(wǎng)開(kāi)發(fā)& 推廣服務(wù)提供商

我們擅長(cháng)商業(yè)策略與用戶(hù)體驗的完美結合。

歡迎瀏覽我們的案例。

首頁(yè) > 新聞中心 > 新聞動(dòng)態(tài) > 正文

JavaScript命名沖突不可避免?沖突源有哪些

發(fā)布時(shí)間:2022-03-17 09:16:24來(lái)源:博客園

  從 1995 年開(kāi)始,本文作者 Dr.Axel Rauschmayer 就專(zhuān)門(mén)從事 JavaScript 和 Web 開(kāi)發(fā),已經(jīng)有 30 多年了。2010 年,他獲得慕尼黑大學(xué)信息學(xué)博士學(xué)位。自 2011 年以來(lái),他一直在 2ality.com 寫(xiě)博客,并寫(xiě)了幾本關(guān)于 JavaScript 的書(shū),比如《JavaScript for impatient programmers》、《Deep JavaScript: Theory and techniques》等。今天這篇文章就來(lái)自于他的博客,介紹了在 JavaScript 命名沖突時(shí),現有代碼如何強制對提議的功能進(jìn)行重命名。

  不斷發(fā)展的 JavaScript:不要破壞 web!

  JavaScript 的一個(gè)發(fā)展核心原則就是"不要破壞 Web":在將新特性添加到語(yǔ)言中后,所有現有代碼都必須能夠繼續運行。

  這樣有一個(gè)壞處,就是不能從語(yǔ)言中刪除現有的 quirks。但這樣做益處多多,比如舊的代碼可以繼續運行,而且升級到新的 ECMAScript 版本很簡(jiǎn)便等等。

  在為新特征(如方法名稱(chēng))選擇名稱(chēng)時(shí),需要進(jìn)行一個(gè)重要的測試,即在瀏覽器的 nightly 版本(早期預發(fā)布版本)中添加該特征,并檢查是否有任何網(wǎng)站出現錯誤。

  接下來(lái)將介紹過(guò)去案例中的的四個(gè)沖突源,當產(chǎn)生這四種沖突時(shí),就必須重命名特征。

  沖突源1:向內置原型添加方法

  在 JavaScript 中,我們可以通過(guò)改變其原型來(lái)為內置值添加方法:

  神奇的是,語(yǔ)言可以通過(guò)這種方式改變。這種運行時(shí)的修改被稱(chēng)為猴子補丁(monkey patch)。

  什么是猴子補丁?

  如果我們給內置原型添加方法,我們就是在運行時(shí)修改一個(gè)軟件系統。這樣的修改被稱(chēng)為猴子補丁。簡(jiǎn)單來(lái)說(shuō),對其含義有兩種可能的解釋。

  這個(gè)叫法起源于 Zope 框架,人們在修正 Zope 的 Bug 的時(shí)候經(jīng)常在程序后面追加更新部分,這些被稱(chēng)作是“雜牌軍補丁(guerilla patch)”,后來(lái) guerilla 就漸漸的寫(xiě)成了 gorllia ((猩猩),再后來(lái)就寫(xiě)了 monkey (猴子),所以猴子補丁的叫法是這么莫名其妙的得來(lái)的。

  另一種說(shuō)法是,它指的是搞亂(monkeying about)代碼。

  反對改變內置原型的原因

  對任何類(lèi)型的全局命名,都會(huì )存在名稱(chēng)沖突的風(fēng)險。如果有解決沖突的機制,就能規避風(fēng)險。例如:

  全局模塊是通過(guò)裸模塊指定器或 URLs 來(lái)識別的。前者之間的名稱(chēng)沖突可以通過(guò) npm 注冊表來(lái)解決。后者之間的名稱(chēng)沖突可以通過(guò)域名注冊處來(lái)解決。

  可以通過(guò)將符號添加到 JavaScript 中,以避免方法之間的名稱(chēng)沖突。例如,任何對象都可以通過(guò)添加一個(gè)鍵為 .NET 的方法而成為可迭代的。由于每個(gè)符號都是唯一的,所以這個(gè)鍵永遠不會(huì )與任何其他屬性鍵 .Symbol.iterator 發(fā)生沖突。

  然而,帶有字符串鍵的方法會(huì )導致名稱(chēng)沖突:

  不同的庫可能會(huì )對他們添加到 .Array.prototype 的方法使用相同的名字。

  如果一個(gè)名字已經(jīng)被某個(gè)庫使用了,那么這個(gè)名稱(chēng)就不能用于命名 JavaScript 標準庫的一個(gè)新特性。

  具有諷刺意味的是,謹慎地添加一個(gè)方法可能會(huì )適得其反:

  我們會(huì )檢查一個(gè)方法是否已經(jīng)存在。如果沒(méi)有,我們就添加它。

  如果我們要實(shí)現一個(gè) polyfill(模擬原生 Web 平臺功能),將新的 JavaScript 方法添加到不支持它的引擎中,那么這個(gè)技術(shù)就能發(fā)揮作用。(順便說(shuō)一下,這是修改內置原型的一個(gè)合法用例。也許是唯一的一個(gè))。

  然而,如果我們對一個(gè)普通庫的方法使用這種技術(shù),然后 JavaScript 獲取具有相同名稱(chēng)的方法,那么這兩種實(shí)現的工作方式就不一樣了,并且使用庫方法的所有代碼在使用內置方法時(shí)都會(huì )中斷。

  必須更改名稱(chēng)的原型方法示例

  ES6 的方法最初是與 JavaScript 框架 MooTools.String.prototype.includes () .contains ()全局添加的方法相沖突。

  ES2016 的方法最初是與 MooTools.Array.prototype.includes () .contains ()添加的方法相沖突。

  ES2019 的方法最初是和 MooTools.Array.prototype.flat () .flatten ()相沖突。

  修改內置原型并不總是糟糕的

  你可能會(huì )對 MooTools 的創(chuàng )建者的粗心大意感到疑惑。但是,向內置原型添加方法并不總是糟糕的。在 ES3(1999 年 12 月)和 ES5(2009 年 12 月)之間,JavaScript 是一種停滯不前的語(yǔ)言。MooTools 和 Prototype 等框架改進(jìn)了它。這些方法的缺點(diǎn)只有在 JavaScript 的標準庫再次增加之后才會(huì )凸顯出來(lái)。

  沖突源2:檢查一個(gè)屬性的存在

  ES2022 的方法最初是 .NET 的。因為以下庫檢查屬性以確定對象是否是一個(gè) HTML 集合(而不是一個(gè)數組),所以它必須被重新命名:Magic360、YUI 2、YUI 3.Array.prototype.at () .item () .item

  沖突源3:檢查全局變量是否存在

  自 ES2020 以來(lái),我們可以通過(guò) globalThis 訪(fǎng)問(wèn)全局對象。Node.js 一直使用該名稱(chēng)來(lái)實(shí)現此目的。最初的計劃是為所有平臺標準化該名稱(chēng) .global

  然而,以下模式經(jīng)常被用來(lái)確定當前平臺:

  如果瀏覽器也有一個(gè)名為 .global 的全局變量,這種模式(以及類(lèi)似的模式)就會(huì )失效。因此,標準化的名稱(chēng)被改為 .globalglobalThis。

  沖突源4:通過(guò)創(chuàng )建局部變量 with 語(yǔ)句

  JavaScript 的聲明 with 語(yǔ)句

  長(cháng)期以來(lái),人們一直不鼓勵使用 JavaScript 的 with 語(yǔ)句,甚至在 ES5 中引入的嚴格模式中也被定為非法。在其他地方,嚴格模式在 ECMAScript 模塊中是活躍的。

  該語(yǔ)句將一個(gè)對象的屬性變成局部變量:with

  由 with 語(yǔ)句引起的沖突

  框架 Ext.js 使用的代碼與下面的片段有些相似點(diǎn):

  當 ES6 方法被添加到 JavaScript 中時(shí),如果用 Array(B行)來(lái)調用它,它就會(huì )失效。該語(yǔ)句將 Array 的所有屬性變成了局部變量。其中一個(gè)是繼承的屬性。因此,A行中的語(yǔ)句已記錄,不再是參數

  Array.prototype.values () myFunc () withvalues.valuesArray.prototype.valuesvalue

  Unscopables:防止 with 導致的沖突

  公共符號Symbol.unscopables 允許對象隱藏語(yǔ)句中的某些屬性。它只在標準庫中使用一次,對于 Array.prototype:with

  結論

  以上提出了 JavaScript 結構與現有代碼發(fā)生名稱(chēng)沖突的四種方式:

  向內置原型添加方法

  檢查屬性是否存在

  檢查全局變量是否存在

  創(chuàng )建局部變量 with

  沖突的某些來(lái)源很難預測,但存在以下一些一般規則:

  不要更改全局數據。

  避免檢查是否存在全局數據。

  請注意,內置值將來(lái)可能會(huì )獲得其他屬性(自己的或繼承的屬性)。

  對于庫來(lái)說(shuō),為 JavaScript 值提供功能的最安全方法是通過(guò)函數。如果 JavaScript 得到一個(gè) pipe operator,我們也可以像方法一樣使用它們。
 ?。?a href="http://www.reeanfmc.com/wechat/">邯鄲微信平臺)

最新資訊
? 2018 河北碼上網(wǎng)絡(luò )科技有限公司 版權所有 冀ICP備18021892號-1   
? 2018 河北碼上科技有限公司 版權所有.
无码精品国产一区二区三区免费| 国内精品免费午夜又爽又色愉情| 国产山村乱淫老妇av| 国内伦精品一区二区三区在线观看| 人人澡人人爽人人人妻| 在线日本高清视频一区二区| 婷婷色爱区综合五月激情| 岛国AAAA级午夜福利片| 日韩欧美另类亚洲狠狠| 五月雨美女がさ乱れる| 无码不卡av手机版免费| 中文在线а√天堂官网| 中文字幕日产乱码中| 日韩大片在线永久免费观看网站| 欧美日韩一区二区在线免费观看| 国产在线观看www鲁啊鲁免费| 亚洲天堂网站视频| 精品久久无码中文字幕| 国产成人精品a视频免费福利| 国产黄片在线免费观看地址| 一本久久精品一区二区| 美女黄18岁以下禁看| 国产精品国色综合久久| 国产丰满老熟女重口对白| 国产激情Av在线视频播放| 国产成人精品三上悠亚| 女跳蛋插水裙车嗯啊| 亚洲成av人不卡无码影片| 最新中文字幕1级在线视频| 中国少妇内射xxxhd| 亚洲大尺度av无码专区中文| 一级黄色电影网址| 久久久久人妻一区二区三区| 成人k视频国产频道网址| 青青青免费在线视频| 蜜臀久久精品国产亚洲av| 亚洲国产成人久久| 日本不卡的高清一区二区视频| 中文字幕日本不卡一二三区| 国产深夜福利在线观看网站| 久久国产精品95久久久久久| 不卡av电影在线| 国产精品久久久久77777按摩| 亚洲A成人片在线播放| 亚洲制服丝袜无码第3页| 亚洲国产精品亚洲国产| 成人午夜?v在线免费观看| 中文在线高清字幕电视剧大全| 最近中文字幕大全2019| 一区二区三区人妻少妇| 精品一区二区三区在线播放| 亚洲高清视频免费在线观看| 精品国产自线午夜福利在线观看| 国产性色av网站网址| 中文字幕久久波多野结衣av| 亚洲精品久久久久久动漫| 最新国产亚洲亚洲精品f罩| 亚洲av无码乱码在线看片不卡| 亚洲一区无码中文字幕| 日本乱偷人妻中文字幕| 亚洲欧洲色玖玖资源在线| 国产成人无码精品久久久露脸| 亚洲欧美国产一区二区三区| 国产精品入口麻豆免费观看| 亚洲第一精品在线观看| 国产无套粉嫩白浆内谢| 日本一区二区不卡电影观看| 三级片黄色视频aaa| 国产精品拍自网站资源多| 亚洲av无码手机在线播放| 肉肉高潮液体高干文H| 国产农村妇女精品一区| 欧美喷潮久久久XXXXX| x8x8拨牐拨牐x8免费视频8午夜| 亚洲欧美日韩www| 欧美国产一级二级三级在线| 一级做a爰片性色毛片成人| 精品无人区一区二区三| 无码中文字幕在线播放2| 97se亚洲国产综合自在线观看| 日韩精品一区二区三区不卡| 男JI大巴进入女人的视频| 伊人精品久久大香线蕉| 97夜夜澡人人爽人人| 国产日韩专区欧美第一页| 亚洲肥老太BBW中国熟女| 色婷婷精品二区蜜臀av| 日韩卡1卡2卡三卡免费网站| 亚洲欧美精品日本| 国产精品毛片一区二区三区| 无码国产精成人午夜视频不卡| 亚洲综合另类第一页| 天天操夜夜操| 国产黄色视频免费在线| 曰本黄页在线观看| 最好看的中文字幕免费| 欧美色视频在线观看| 亚洲精品午夜精品| 亚洲欧美日韩国产综合久久| 久久国产精品99久久久久久老狼| 欧美mv日韩mv国产mv网站| 91麻豆精品国产专区| 一级一级18女人毛片| 在线观看免费精品国白产| 免费高清欧美大片在线看| 中文字幕乱码免费视频| 色偷偷AV一区二区三区| 欧美激情视频建材有限公司| 曰本无码不卡高清av一区二区| 午夜福利自怕| 欧美AAAAAA级午夜福利视频| 亚洲中文字幕无码AV| 国偷自产一区二区三区在线观看| 欧美人与动牲交a精品| 中文字幕在线免费电影网站大全| 亚洲一区二区国产精品无l| 午夜美女裸体福利视频| 日本一级爱免费观看视频| 中文无码不卡岛国片| 亚洲专区精品中文字幕| 亚洲日本电影中文字幕| AV综合色区无码一区| 亚洲国产成人综合在线观看| 国产精品美女一区二区视频| 国产精品亚韩精品无码a在线| 日韩在线免费观看视频| 亚洲成人午夜精品日韩久久久| 在线成人精品国产区免费| 亚洲午夜久久久影院| 丰满人妻翻云覆雨呻吟视频| 一区二区日韩国产精品| 亚洲久热无码AV中文字幕| 国产免费的野战视频| 国产亚洲欧美精品一区二区三区| 国产偷亚洲偷欧美偷精品| 国产精品情侣呻吟对白视频| 国产精品视频一区二区噜噜| 欧美精品一区二区性色| 国产精品无码DVD在线观看| 最新精品国偷自产在线91| 在线成人精品国产区免费| 蜜桃成人精品一区二区三区| 久久久久毛片精品美女免费| 国产av天堂亚洲国产av二区| 高清无码黄色一级网 播放| 日韩视频中文字幕久久| 千金被调教室跪趴SM是什么视频| 久久精品国产亚洲av热东京热| 欧美人与牲动交XXXX| 伊人色综合网一区二区三区| 亚洲精品AV无码重口另类| 亚洲国产一级A级毛片久久久久| 人人妻人人澡人人爽欧美一区97| 精品国产污污免费网站| 美女被揉胸强操| 在线看片无码永久| 国产 日韩 欧美 三区| 国产高清一级毛片在线视频| 日本三级欧美三级| 亚洲精品网站在线播放gif| 国产精品又黄又爽又色无遮挡软件| 好大好湿好硬顶到了好爽视频| 亚洲欧美小说激情另类奇幻玄幻| 亚洲性生活视频|