日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

讓我們寫(xiě)快速的JavaScript,JS性能優(yōu)化小竅門(mén)

瀏覽:118日期:2023-11-21 08:11:03

JavaScript已經(jīng)是目前最流行的語(yǔ)言了,它能做很多事情 - 網(wǎng)站界面,服務(wù)器端,游戲 ,操作系統(tǒng) ,機(jī)器人 等等很多很多。

不過(guò),說(shuō)實(shí)話,即使它這么瘋狂流行,它的性能還沒(méi)有達(dá)到它的極限。是的,它在改進(jìn),但是等到它在各個(gè)方面趕上本地應(yīng)用之前,在做一個(gè)HYBIRD混合應(yīng)用時(shí),你還不得不使用一些伎倆來(lái)優(yōu)化它的性能。

Firefox擁有目前最快的JavaScript解析器 SpiderMonkey,

有各種各樣的讓JavaScript的速度更快的努力,其中一個(gè)是asm.js. Asm.js是JavaScript是由Emscripten產(chǎn)生的一個(gè)子集,它為C/C++編繹成的JavaScript代碼做了很多優(yōu)化,編譯型后的代碼很難看,這就是為什么你不能自己寫(xiě)優(yōu)化后的代碼,但它運(yùn)行非常快。我建議你閱讀一下這篇文章

別扯了舉個(gè)例子吧!

好了,我們的目標(biāo)是寫(xiě)速度更快的JavaScript代碼,這里有讓你的代碼跑得更快一些的小竅門(mén),以及更好的內(nèi)存效率。請(qǐng)注意,我不是嚴(yán)格討論DOM和Web應(yīng)用程序,它是關(guān)于JavaScript的,DOM只是一部分。

眼見(jiàn)為實(shí),我要添加為第一個(gè)添加jsperf測(cè)試用例,使用的是Firefox38和Chrome39測(cè)試。

#1不要類型轉(zhuǎn)換

JavaScript是動(dòng)態(tài)類型,但如果你想提高速度不要使用該功能。盡量保持變量的類型一致。這也適用于數(shù)組,盡管主要是由瀏覽器都進(jìn)行了優(yōu)化,但盡量不要混用不同類型的數(shù)組。這就是為何編譯成 JavaScript的C/C++代碼使用靜態(tài)類型的原因之一。

{ var x = '2'; var y = 5; x = 2; x + y;}

測(cè)試用例

另外: 字符串與數(shù)字類型間相互轉(zhuǎn)換

比方說(shuō),你必須將字符串轉(zhuǎn)換為數(shù)字,parseInt與parseFloat是最好的方法嗎?讓我們來(lái)看看。

parseFloat("100")+"100"http:// 整型parseInt("100", 10)"100"|0"100" >> 0"100" << 0// 僅適用于正數(shù)"100" >>> 0

parseInt 測(cè)試 ~ parseFloat 測(cè)試

Firefox對(duì)位操作進(jìn)行了優(yōu)化,運(yùn)行的代碼比parseInt和+運(yùn)算速度快約99%。而Chrome顯然對(duì)位運(yùn)算符沒(méi)有偏愛(ài),他們比parseInt函數(shù)還慢62%。

parseFloat比+運(yùn)算符在兩種瀏覽器(Firefox 28%,Chrome 39%)上都要快。

因此,如果你在寫(xiě)Node/Chrome或Firefox的應(yīng)用程序?我認(rèn)為,一般使用parseInt函數(shù)是正確的。

#2不要重新構(gòu)造對(duì)象

重組對(duì)象不便宜,應(yīng)該避免它:

不要使用delete運(yùn)算符

刪除操作比分配一個(gè)null屬性慢很多。分配null在兩個(gè)瀏覽器都快99%,但它不能修改對(duì)象的結(jié)構(gòu),但刪除可以。

編輯:我認(rèn)為這里有點(diǎn)誤導(dǎo),這并不意味著你不應(yīng)該使用delete操作符,delete運(yùn)算符有它自己的使用情況,它可以防止對(duì)象的內(nèi)存泄漏。

delete vs null

不要以后再添加屬性

盡量不要在以后再添加屬性,最好從一開(kāi)始就定義對(duì)象的架構(gòu)。這在Firefox中快100%,在Chrome中快89%。

動(dòng)態(tài)屬性VS預(yù)先定義結(jié)構(gòu)

#3字符串聯(lián)連

字符串聯(lián)連是一個(gè)非常昂貴的操作,但是應(yīng)該用什么方法呢?當(dāng)然不是Array.prototype.join。

+=運(yùn)算符似乎比+快很多,String.prototype.concat和Array.prototype.join在兩種瀏覽器都更快。Array.prototype.join是最慢的,符合市場(chǎng)預(yù)期。

字符串連接測(cè)試

#4正確的使用正則表達(dá)式

使用RegExp.prototype.exec是沒(méi)有必要,不是嗎?

然而,RegExp.prototype.test和String.prototype.search之間是有性能差異的,讓我們來(lái)看看哪個(gè)方法更快:

正則表達(dá)式的方法

RegExp.prototype.exec比String.prototype.match快了不少,但他們是不完全一樣的東西,它們的區(qū)別超出了本文的范圍,看這個(gè)問(wèn)答。

RegEx.prototype.test更快,可能是因?yàn)樗环祷卣业狡ヅ涞乃饕?String.prototype.search應(yīng)僅用于找到所需的匹配的索引。

然而,你不應(yīng)該使用正則表達(dá)式來(lái)查找另一個(gè)字符串的位置,你可以使用String.prototype.indexOf方法。

String.prototype.search VS String.prototype.indexOf

另一個(gè)有趣的基準(zhǔn)是String.prototype.indexOf VS RegExp.prototype.test,我個(gè)人預(yù)計(jì)后者要快,這是在Firefox中發(fā)生的事情,但在Chrome中,事實(shí)并非如此。 RegExp.prototype.test在Firefox中快32%,而在Chrome中String.prototype.indexOf快33%。在這種情況下,你自己選擇喜歡的方式吧。

#5限制聲明/傳遞變量的范圍(作用域)

假如你調(diào)用一個(gè)函數(shù),瀏覽器必須做一些所謂的范圍查找,它的昂貴程度取決于它要查找多少范圍。盡量不要依辣全局/高范圍的變量,盡量使局部范圍變量,并將它們傳遞給函數(shù)。更少的范圍查找,更少的犧牲速度。

這個(gè)測(cè)試告訴我們,從局部范圍內(nèi)傳遞和使用變量比從更高的聲明范圍查找變量快,無(wú)論是Chrome和Firefox。

內(nèi)部范圍VS高范圍VS全局

#6你不需要所有的東西都用jQuery

大多數(shù)開(kāi)發(fā)者使用jQuery做一些簡(jiǎn)單的任務(wù),我的意思在一些場(chǎng)合你沒(méi)有必要使用jQuery,你覺(jué)得用$.val()始終是必要的嗎?就拿這個(gè)例子:

$('input').keyup(function() { if($(this).val() === 'blah') { ... }});

這是學(xué)習(xí)如何使用JavaScript修改DOM的最重要原因之一,這樣你可以編寫(xiě)更高效的代碼。

用純JavaScript100%完成同樣的功能100%的速度更快,這是JSPerf基準(zhǔn)測(cè)試

$('input').keyup(function() { if(this.value === 'blah') { ... }});

原文地址: medium.com

標(biāo)簽: JavaScript
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品麻豆成人av电影艾秋| 久久国产日韩| 国产一级久久| 视频一区视频二区在线观看| 久久亚洲影院| 最新国产精品久久久| 视频一区二区三区入口| 日韩精品一级二级| 亚洲男人在线| 欧美一区激情| 美女视频网站久久| 国产一区二区三区天码| 日韩欧美精品| 国产亚洲欧美日韩在线观看一区二区| 国产精品成人自拍| 色老板在线视频一区二区| 视频一区视频二区在线观看| 免播放器亚洲| 国产麻豆一区二区三区精品视频| 日韩伦理一区| 日韩一区精品视频| 在线亚洲观看| 亚洲成人一区在线观看| 99视频精品全部免费在线视频| 精品国产免费人成网站| 久久狠狠婷婷| 最新国产精品视频| 国产精品男女| 偷拍精品精品一区二区三区| 婷婷六月综合| 日本aⅴ精品一区二区三区| 麻豆精品久久| 色乱码一区二区三区网站| 女同性一区二区三区人了人一 | 亚洲一区亚洲| 青青草精品视频| 成人亚洲一区二区| 亚洲一区国产一区| 国产精品成人一区二区网站软件| 久久久亚洲一区| 日韩精品亚洲专区| 日韩电影二区| 免费的成人av| 成人在线超碰| 欧美99久久| 日本午夜精品一区二区三区电影| 精品中国亚洲| 久久亚洲视频| 国产一区二区三区视频在线| 伊人久久亚洲热| 国产精品久久久久av蜜臀| 久久婷婷亚洲| 国产日韩精品视频一区二区三区| 精品三级久久| 日韩中文字幕| 欧美成a人免费观看久久| 亚洲一区二区三区无吗| 国产成人精品一区二区三区视频| 亚洲一区二区三区四区五区午夜| 亚洲黄色网址| 国产亚洲一区二区手机在线观看| 亚洲欧美成人综合| www在线观看黄色| 亚洲啊v在线| 精品久久久久中文字幕小说| 你懂的亚洲视频| 国产精品亚洲成在人线| 日韩av一级| 日韩高清电影免费| 日韩综合一区二区| 日韩精品免费一区二区三区| 亚洲精品一二三**| 中文字幕系列一区| 国产精品一区二区美女视频免费看 | 欧美视频一区| 亚洲激情偷拍| 中文字幕成在线观看| 日韩精品视频在线看| 在线视频观看日韩| 国产黄色一区| 天使萌一区二区三区免费观看| 一区二区三区网站| 日韩在线看片| 亚洲欧美日韩专区| 青青国产精品| 日韩激情av在线| 在线观看精品| 国产精品天天看天天狠| 亚洲国产日韩欧美在线| 高清日韩中文字幕| 国产一区 二区| 一区二区日韩免费看| 亚洲一本视频| 中文在线免费视频| 国产理论在线| 欧美日韩夜夜| 久久只有精品| 中文字幕中文字幕精品| 国产伦久视频在线观看| 色综合视频一区二区三区日韩 | 国产午夜精品一区在线观看| 国产欧美69| 99视频在线精品国自产拍免费观看| 999国产精品永久免费视频app| 国产情侣一区| 激情综合网站| 精品三级久久久| 国产在线不卡| 亚洲午夜av| 日韩精品一区二区三区中文字幕| 国产精品视频3p| 在线视频精品| 不卡中文一二三区| av资源中文在线| 国产高清不卡| 亚洲精品网址| 蜜桃传媒麻豆第一区在线观看| 日韩欧美另类一区二区| 国产精品一区二区美女视频免费看 | 久久精品九色| 麻豆视频观看网址久久| 国产精品久久久久久久久久妞妞| 国产私拍福利精品视频二区| 91p九色成人| 在线精品国产亚洲| 亚洲精品视频一二三区| 亚州av一区| 日韩成人在线看| 91精品日本| 国产极品模特精品一二| 欧美国产极品| 久久亚洲国产精品尤物| 老牛国内精品亚洲成av人片| 久久香蕉网站| 国产suv精品一区二区四区视频| 国产999精品在线观看| 高清在线一区| 日本久久成人网| 不卡在线一区| 亚洲少妇一区| 亚洲精品日本| 国产精品日本一区二区三区在线| 国产精品高清一区二区| 精品午夜视频| 99久久精品国产亚洲精品| 影院欧美亚洲| 日韩精品视频在线看| 久久99免费视频| 国产高潮在线| 亚洲欧美日韩高清在线| 国产精品美女久久久| 日韩国产在线一| 国产成人精品一区二区免费看京| 日韩伦理一区| 激情久久婷婷| 久久国产精品亚洲77777| 日韩国产在线一| 精品一区不卡| 亚洲一级影院| 日韩欧美中文字幕一区二区三区 | 日韩精品麻豆| 亚洲开心激情| 老牛国内精品亚洲成av人片| 99久久婷婷| 少妇精品久久久一区二区三区| 久久狠狠久久| 国产精品字幕| 亚洲一区二区三区四区五区午夜| 国产日韩欧美一区二区三区| 久久uomeier| 人人爽香蕉精品| 国产精品成人自拍| 伊人精品一区| 青青草视频一区| 九色porny丨国产首页在线| 久热综合在线亚洲精品| 麻豆精品久久| 99国产一区| 久久一区国产| 9国产精品视频| 国产精品嫩草影院在线看| 久久久成人网| 日韩中文字幕麻豆| 精品久久网站| 免费观看在线综合| 国产va在线视频| 亚洲日本免费电影| 欧美freesex黑人又粗又大| 亚洲精品婷婷| 精品丝袜在线| 国产乱码精品一区二区三区亚洲人| 精品亚洲美女网站| 国产一级成人av| 国产二区精品| 国语精品一区| 在线精品视频一区| 天堂日韩电影| 欧美日韩调教| 免费日韩av片| 天堂网av成人|