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

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

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 河北碼上科技有限公司 版權所有.
国模无码视频一区| 亚洲欧美色图| 免费夜色污私人影院在线观看| 国产成人精品AA毛片| 国产a欧美精品一区二区三区| 日本aaaaa高潮免费| 亚洲综合无码精品一区二区三区| 综合国产福利视频在线观看| 国产一区二区不卡老阿姨| 日韩在线欧美精品一区二区| 亚洲日韩在线在线播放视频在线| 亚洲精品一区二区视频| 在线播放国产麻豆VA剧情| 亚洲国产成人精品综合在线| 中文国产日韩欧美二视频| 欧美午夜理伦三级在线观看偷窥| 成人性生交大片免费看国外| 中文字幕有码无码| 久久精品视频免费观看| 亚洲精品美女久久久久99| 中文字字幕在线精品乱码app| 亚洲av永久无码精品无码四虎| 中文字幕亚洲乱码熟女一区二区| 天堂中文资源在线地址| 欧美日韩有精品一区二| 久久国产精品亚洲国产专区| 黄色三级av在线免费观看| 亚洲伊人成综合网| 久久精品国产99久久久| 国产高清精品一区二区| 亚洲一区二区三区四区在线观看| 亚洲国产另类无码日韩| 欧美日韩国产在线激情综合| 亚洲一区二区三区春色旅游攻略| a级国产理论片在线播放| 免费裸体无遮挡黄网站免费看| 中文字幕久久一区二区三区| 中日韩午夜理伦电影免费| 亚洲天堂一区二区三区四区| 久久只有这里有精品热久久| 精品久久久久久久久久久久久| 亚洲国产精品第一区二区三区| 色综合综合色| 国产亚洲伊人久久一区二区| 久久久夜色精品亚洲aⅴ网址| 亚洲日韩欧美一区久久久久久| 国产欧美精品区一区二区三区| 亚洲一区二区视频在线观看| 大桥未久作品番号| 99re国产在线视频| 亚洲第一网站在线观看| 久久天天躁夜夜躁狠狠躁| 久久精品国产99国产精品导航| 91一级a片在线观看| 亚洲第一区第二区在线| 91精品国产91久久久久久密臀| 国产精品一线二线三线精华液| 免费全文阅读和下载黄蓉、刘三| 天天躁夜夜躁狂狂躁综合| 国产福利一区二区精品秒拍| 真实国产普通话对白乱子子伦视频| 丰满女邻居做爰佐佐木明希| 在线看aⅴ五月天中文字幕| gay18无套禁18动漫网站| 精品国产丝袜一区二区三区乱码| 日本丶国产丶欧美色综合| 东京热人妻无码一区二区AV| 国精品午夜福利不卡视频大豆| 在线视频夫妻内射| 亚洲aV无码aV日韩aV网站| 国产福利网址一区二区| 色欲AV永久无码精品无码蜜桃| 欧美精品成人a在线观看| 日韩精品人妻一区二区在线视频| 在线A片杂交永久免费观看| 亚洲日韩精品欧美一区二区| 国产午夜片免费在线看| 国产无遮挡猛进猛出免费软件| 国产高清无码暴力插入黄片| 亚洲综合无码无在线观看| 日韩成人在线一区二区三区| 超碰97人人模人人爽人人喊| 性XXXX欧美老妇胖老太性多毛| 日本韩国免费观看高清电视剧| 亚洲av无码精品| 国产清纯白嫩初黑人高生在线观看| 亚洲AV狼在线| 亚洲色图无码视频深夜福利| 亚洲精品一区二区三区香蕉| 品色堂永远的免费论坛| 棉袜足j吐奶视频| 成人国产一区二区三区香蕉| 国产欧美在线观看不卡| 国产一级a电影在线播放| 国产午夜亚洲精品理论片a| 欧美大白屁股xxxooo| 亚洲一区二区中文| 亚洲一区无码精品色变态| 国内自拍v亚洲1314| 亚洲国产精品第一页| 中文字幕亚洲综合无码| 最新午夜黄色网站在线观看| 成人妇女免费播放久久久| 五月天婷婷丁香中文字幕| 中文字幕一区二区二三区四区| 校园春色 欧美| 亚洲日韩精品国产3区| 日本韩国免费观看高清电视剧| 国语自产拍在线观看99网| 天堂va欧美ⅴa亚洲va视频| 福利免费观看午夜体检区| 亚洲综合色区无码一| 任你躁国产自任一区二区三区| 人妻无码中文字幕免费视频蜜桃| 伊人亚洲综合网成人| 欧美日本日韩aⅴ在线视频| 国产真实露脸乱子伦| 中文国产日韩欧美视频| 国产精品欧美亚洲777777| 欧美日韩免费专区在线观看| 激情久久AV一区AV二区AV三区| 麻豆国产高清精品国在线| 中国熟妇高清videos| 小柔好湿好紧太爽了孕妇| 人妻精品久久久久中文字幕69| 亚洲欧美综合视频| 午夜福利一区二区三区| 亚洲中文字幕永远在线| 欧美亚洲国产精品久久高清| 亚洲av成人中文在线播放| 一本色道久久综合狠狠躁的推荐| 中文一区二区三区无码视频| 日本在线看片免费人成视频1000| 无卡无码无免费毛片| 色av综合av综合无码网站| 亚洲第一区二三区影视大全| 韩国精品一区二区三区无码视频| 国产日韩亚洲欧美在线| 在线精品亚洲一区二区不卡| 国产对白videos麻豆高潮| 高潮到不停喷水的免费视频| 伊人大香蕉在线视频华人绿色| 亚洲精品国产精品乱码不卞| 久久久久久久人妻无码中文字幕爆| 无人视频在线观看无码| 暴露娇妻被调教用力胬视频| 亚洲人ⅴsaⅴ国产精品| 日韩午夜理论二区在线观看| 激情無極限的成年一级黄片| 欧美成人精品电影在线观看| 天天做夜夜做久久做狠狠| 欧美激情视频一区二区三区| 精品国产污污免费网站入www| 亚洲天堂2017无码中文| 国产一区二区三区视频在线播放| 人人妻人人澡人人爽人人| 国产999精品久久久久久麻豆| 一级性片引发社会热议| 国产精品久久九九99九九99| 国产精品国产三级国产a| 亚洲片一区二区三区| 国产福利影院在线观看| 办公室漂亮人妇在线观看| 中文字幕a∨日韩精品一区二区|