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