數(shù)組方法解決JS字符串連接性能問題有爭(zhēng)議
更新時(shí)間:2011年01月12日 22:19:59 作者:
大多數(shù)情況下,加法運(yùn)算符是首選;如果用戶主要使用IE6或7,并且字符串大小較大或數(shù)量較多時(shí),那么數(shù)組技術(shù)就很值得。
1、傳統(tǒng)上,字符串連接一直是js中性能最低的操作之一。
var text="Hello";
text+=" World!";
早期瀏覽器沒有對(duì)這種運(yùn)算進(jìn)行優(yōu)化。
由于字符串是不可變的,這意味著要?jiǎng)?chuàng)建中間字符串來存儲(chǔ)連接的結(jié)果。頻繁地在后臺(tái)創(chuàng)建和銷毀字符串導(dǎo)制性能異常低下。
2、發(fā)現(xiàn)這一點(diǎn)后,開發(fā)者們利用數(shù)組對(duì)象進(jìn)行優(yōu)化。
var buffer=[],i=0;
buffer[i++]="Hello";//通過相應(yīng)索引值添加元素比push方法快
buffer[i++]=" World!";
var text=buffer.join("");
在早期的瀏覽器中,沒有創(chuàng)建和銷毀中間字符串,在大量字符串連接情況下,這技術(shù)已被證明遠(yuǎn)快于使用加法方式。
3、如今瀏覽器對(duì)字符串的優(yōu)化已經(jīng)改變了字符串相連的局面。
Safari、Opera、Chrome、Firefox和IE8都在使用加法運(yùn)算符上表現(xiàn)出了更好的性能。但是,IE8之前的版本沒有優(yōu)化,因此數(shù)組方法依然有效。
這并不意味著字符串相連時(shí)我們要進(jìn)行瀏覽器檢測(cè)。在決定如何連接時(shí)要考慮的是字符串的大小和數(shù)量。
1)當(dāng)字符串相對(duì)較?。?lt;20字符)且連接數(shù)量也較小時(shí)(<1000個(gè)),所有的瀏覽器使用加法運(yùn)算符都能在不到1豪秒內(nèi)輕松完成連接。
2)增加字符串?dāng)?shù)量或大小時(shí),IE7中性能會(huì)明顯下降。
3)字符串大小增加時(shí),F(xiàn)irefox中加法運(yùn)算符和數(shù)組成技巧性能差異會(huì)變小。
4)字符串?dāng)?shù)量增加時(shí),Safari中加法運(yùn)算符和數(shù)組成技巧性能差異會(huì)變小。
5)改變字符串?dāng)?shù)量或大小時(shí),Chrome和Opera中加法運(yùn)算符一直保持領(lǐng)先優(yōu)勢(shì)。
所以,由于在各瀏覽器下性能不一致,選用技術(shù)取決于實(shí)際情況和面對(duì)的瀏覽器。
大多數(shù)情況下,加法運(yùn)算符是首選;如果用戶主要使用IE6或7,并且字符串大小較大或數(shù)量較多時(shí),那么數(shù)組技術(shù)就很值得。
var text="Hello";
text+=" World!";
早期瀏覽器沒有對(duì)這種運(yùn)算進(jìn)行優(yōu)化。
由于字符串是不可變的,這意味著要?jiǎng)?chuàng)建中間字符串來存儲(chǔ)連接的結(jié)果。頻繁地在后臺(tái)創(chuàng)建和銷毀字符串導(dǎo)制性能異常低下。
2、發(fā)現(xiàn)這一點(diǎn)后,開發(fā)者們利用數(shù)組對(duì)象進(jìn)行優(yōu)化。
var buffer=[],i=0;
buffer[i++]="Hello";//通過相應(yīng)索引值添加元素比push方法快
buffer[i++]=" World!";
var text=buffer.join("");
在早期的瀏覽器中,沒有創(chuàng)建和銷毀中間字符串,在大量字符串連接情況下,這技術(shù)已被證明遠(yuǎn)快于使用加法方式。
3、如今瀏覽器對(duì)字符串的優(yōu)化已經(jīng)改變了字符串相連的局面。
Safari、Opera、Chrome、Firefox和IE8都在使用加法運(yùn)算符上表現(xiàn)出了更好的性能。但是,IE8之前的版本沒有優(yōu)化,因此數(shù)組方法依然有效。
這并不意味著字符串相連時(shí)我們要進(jìn)行瀏覽器檢測(cè)。在決定如何連接時(shí)要考慮的是字符串的大小和數(shù)量。
1)當(dāng)字符串相對(duì)較?。?lt;20字符)且連接數(shù)量也較小時(shí)(<1000個(gè)),所有的瀏覽器使用加法運(yùn)算符都能在不到1豪秒內(nèi)輕松完成連接。
2)增加字符串?dāng)?shù)量或大小時(shí),IE7中性能會(huì)明顯下降。
3)字符串大小增加時(shí),F(xiàn)irefox中加法運(yùn)算符和數(shù)組成技巧性能差異會(huì)變小。
4)字符串?dāng)?shù)量增加時(shí),Safari中加法運(yùn)算符和數(shù)組成技巧性能差異會(huì)變小。
5)改變字符串?dāng)?shù)量或大小時(shí),Chrome和Opera中加法運(yùn)算符一直保持領(lǐng)先優(yōu)勢(shì)。
所以,由于在各瀏覽器下性能不一致,選用技術(shù)取決于實(shí)際情況和面對(duì)的瀏覽器。
大多數(shù)情況下,加法運(yùn)算符是首選;如果用戶主要使用IE6或7,并且字符串大小較大或數(shù)量較多時(shí),那么數(shù)組技術(shù)就很值得。
您可能感興趣的文章:
- JavaScript數(shù)組方法大全(推薦)
- JavaScript學(xué)習(xí)筆記之ES6數(shù)組方法
- js 定義對(duì)象數(shù)組(結(jié)合)多維數(shù)組方法
- javascript中FOREACH數(shù)組方法使用示例
- js數(shù)組方法reduce經(jīng)典用法代碼分享
- js數(shù)組方法擴(kuò)展實(shí)現(xiàn)數(shù)組統(tǒng)計(jì)函數(shù)
- 基于JavaScript Array數(shù)組方法(新手必看篇)
- Javascript中數(shù)組方法匯總(推薦)
- JavaScript基礎(chǔ)進(jìn)階之?dāng)?shù)組方法總結(jié)(推薦)
- 可能被忽略的一些JavaScript數(shù)組方法細(xì)節(jié)
相關(guān)文章
javascript函數(shù)定義的幾種區(qū)別小結(jié)
本篇文章主要是對(duì)javascript函數(shù)定義的幾種區(qū)別進(jìn)行了詳細(xì)的總結(jié)介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助2014-01-01JS組件系列之Bootstrap table表格組件神器【二、父子表和行列調(diào)序】
本文結(jié)合Bootstrap table的父子表和行列調(diào)序的用法再來介紹下它稍微高級(jí)點(diǎn)的用法。對(duì)bootstrap表格組件相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2016-05-05JS實(shí)現(xiàn)焦點(diǎn)圖輪播效果的方法詳解
這篇文章主要介紹了JS實(shí)現(xiàn)焦點(diǎn)圖輪播效果的方法,結(jié)合實(shí)例形式詳細(xì)分析了JS焦點(diǎn)圖輪播效果的原理、實(shí)現(xiàn)步驟與相關(guān)操作技巧,需要的朋友可以參考下2016-12-12簡(jiǎn)介alert()與console.log()的不同
alert()和console.log()在程序中經(jīng)常會(huì)用到,大家知道他們的區(qū)別嗎,接下來,通過本文給大家介紹alert()與console.log()的不同,需要的朋友可以參考下2015-08-08js當(dāng)一個(gè)變量為函數(shù)時(shí) 應(yīng)該注意的一點(diǎn)細(xì)節(jié)小結(jié)
變量testFun為一個(gè)匿名函數(shù),匿名函數(shù)返回的一個(gè)testFun.init對(duì)象(也是一個(gè)匿名函數(shù))2011-12-12純 JS 實(shí)現(xiàn)放大縮小拖拽功能(完整代碼)
這篇文章主要介紹了純js實(shí)現(xiàn)放大縮小拖拽功能,文中給大家提到了在開發(fā)過程中遇到的一些問題及解決方法,需要的朋友可以參考下2019-11-11JS獲取子窗口中返回的數(shù)據(jù)實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄狫S獲取子窗口中返回的數(shù)據(jù)實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-05-05