日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

探讨js字符串数组拼接的性能问题

發布時間:2024/5/24 综合教程 28 生活家
生活随笔 收集整理的這篇文章主要介紹了 探讨js字符串数组拼接的性能问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

這篇文章主要介紹了有關js對字符串數組進行拼接的性能問題,字符串連接一直是js中性能最低的操作之一,應該如何解決呢?請參看本文的介紹

我們知道,在js中,字符串連接是性能最低的操作之一。
例如:

復制代碼 代碼如下:

var text="Hello";
text+=" World!";

早期瀏覽器沒有對這種運算進行優化。
由于字符串是不可變的,這意味著要創建中間字符串來存儲連接的結果。頻繁地在后臺創建和銷毀字符串導制性能異常低下。

因此,可以利用數組對象進行優化。
例如:

?

1
2
3
4

var buffer=[],i=0;
buffer[i++]="Hello"; //通過相應索引值添加元素比push方法快
buffer[i++]=" World!";
var text=buffer.join("");

在早期的瀏覽器中,沒有創建和銷毀中間字符串,在大量字符串連接情況下,這技術已被證明遠快于使用加法方式。

如今瀏覽器對字符串的優化已經改變了字符串相連的局面。Safari、Opera、Chrome、Firefox和IE8都在使用加法運算符上表現出了更
好的性能。但是,IE8之前的版本沒有優化,因此數組方法依然有效。這并不意味著字符串相連時我們要進行瀏覽器檢測。在決定如何連接時要考慮的是字符串的
大小和數量。

當字符串相對較小(小于20字符)且連接數量也較小時(小于1000個),所有的瀏覽器使用加法運算符都能在不到1毫秒內輕松完成連接。增加字符串
數量或大小時,IE7中性能會明顯下降。字符串大小增加時,Firefox中加法運算符和數組成技巧性能差異會變小。字符串數量增加時,Safari中加
法運算符和數組成技巧性能差異會變小。改變字符串數量或大小時,Chrome和Opera中加法運算符一直保持領先優勢。

所以,由于在各瀏覽器下性能不一致,選用技術取決于實際情況和面對的瀏覽器。

大多數情況下,加法運算符是首選;如果用戶主要使用IE6或7,并且字符串大小較大或數量較多時,那么數組技術就很值得。

一般情況下,如果是語義性的字符串,不應該使用Array,比如:
'Hello, my name is ' + name;

如果字符串是"相似情況的重復"的話,建議使用Array,比如:

?

1
2
3
4
5

var array = [];
for (i = 0; i < length; i++) {
array[i] = '<li>' + list[i] + '</li'>;
}
document.getElementById('somewhere').innerHTML = array.join('
'
);

有關js字符串數組連接的性能比較,就介紹到這里了,希望對大家有所幫助。

總結

以上是生活随笔為你收集整理的探讨js字符串数组拼接的性能问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。