欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript 學(xué)習(xí)筆記(七)字符串的連接

 更新時間:2009年12月31日 23:22:30   作者:  
javascript 字符串的連接效率問題,需要的朋友可以參考下。
字符串的連接
一、 最常用+=
一直說這種方式的效率是最低的,為什么呢?可以看下這種方式的實質(zhì)過程。
var str = "hello";
str += "world";
(1) 創(chuàng)建存儲"hello"的字符串。
(2) 創(chuàng)建存儲"world"的字符串。
(3) 創(chuàng)建存儲連接結(jié)果的字符串。
(4) 把str的當(dāng)前內(nèi)容復(fù)制到結(jié)果中。
(5) 把"world"復(fù)制到結(jié)果中。
(6) 更新str,使它指向結(jié)果。
每次完成字符串連接都會執(zhí)行步驟2到6,使得這種操作非常消耗資源。如果重復(fù)這一過程幾百次,甚至幾千次,就會造成性能問題。所有以后就要摒棄這種用法了,哈哈哈。^_^
二、 join()方法
復(fù)制代碼 代碼如下:

//按鈕調(diào)用
function JoinFn() {
var arr = new Array;
arr[0] = "張三";
arr[1] = "李四";
alert(arr.join(""));
}

執(zhí)行的步驟如下:
(1) 創(chuàng)建存儲結(jié)果的字符串。
(2) 把每個字符串復(fù)制到結(jié)果中的合適位置。
這中方法效率比第一種快。
三、 封裝一個自定義的類
JavaScript中沒有像C#中那樣的StringBuilder類,但是我們可以自定義一個StringBuilder類,建類的方法就是上一篇提到的“混合的構(gòu)造函數(shù)/原型方式”。
復(fù)制代碼 代碼如下:

//自定義一個StringBuilder類,用來連接字符串
function StringBuilder() {
this._strings = new Array();
}
StringBuilder.prototype.append = function(str) {
this._strings.push(str);
};
StringBuilder.prototype.toString = function() {
return this._strings.join("");
};
//按鈕調(diào)用
function MyConnectClassFn() {
var sb = new StringBuilder();
sb.append("張三");
sb.append("李四");
var strResult = sb.toString();
alert(strResult);
}

總結(jié)
最后比較以上這三種方法,書上說最后一種速度最快,但是經(jīng)過我測試,貌似join()是最快的,第三種反而是最慢的,難道我的自定義StringBuilder類有問題?

相關(guān)文章

  • JavaScript之移動端H5生成圖片解決方案講解

    JavaScript之移動端H5生成圖片解決方案講解

    這篇文章主要介紹了JavaScript之移動端H5生成圖片解決方案講解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • javascript去掉代碼里面的注釋

    javascript去掉代碼里面的注釋

    這篇文章主要介紹了javascript去掉代碼里面的注釋的方法和具體代碼,有需要的小伙伴可以參考下。
    2015-07-07
  • JavaScript中函數(shù)(Function)的apply與call理解

    JavaScript中函數(shù)(Function)的apply與call理解

    這篇文章主要介紹了JavaScript中函數(shù)(Function)的apply與call理解,本文講解了JavaScript函數(shù)調(diào)用分為4中模式以及通過apply和call實現(xiàn)擴展和繼承兩方面,需要的朋友可以參考下
    2015-07-07
  • javascript代碼優(yōu)化的8點總結(jié)

    javascript代碼優(yōu)化的8點總結(jié)

    本篇文章給大家分享了關(guān)于javascript代碼優(yōu)化的8點總結(jié),希望我們整理的內(nèi)容能夠幫助到大家。
    2018-01-01
  • JavaScript實現(xiàn)身份證驗證代碼

    JavaScript實現(xiàn)身份證驗證代碼

    本文給大家分享的是使用javascript實現(xiàn)身份驗證的規(guī)則以及代碼,非常的簡單實用,有需要的小伙伴可以參考下。
    2016-02-02
  • 聊聊JavaScript中的try...catch使用小技巧

    聊聊JavaScript中的try...catch使用小技巧

    作為一名web前端工程師,JavaScript中的try...catch是我們常用的特性之一,用于處理代碼中可能出現(xiàn)的錯誤,本文小編將和大家一起聊聊JavaScript中的try...catch使用小技巧,需要的朋友可以參考下
    2023-11-11
  • 詳解JavaScript中的屬性和特性

    詳解JavaScript中的屬性和特性

    本文對JavaScript中對象的本質(zhì)、對象與類的關(guān)系、對象與引用類型的關(guān)系;對象屬性如何進行分類;屬性中特性進行介紹。感興趣的朋友可以看下
    2016-12-12
  • JS比較兩個數(shù)值的大小實例

    JS比較兩個數(shù)值的大小實例

    下面小編就為大家?guī)硪黄狫S比較兩個數(shù)值的大小實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-11-11
  • 微信小程序wxml不能使用Array.includes條件判斷解決方法

    微信小程序wxml不能使用Array.includes條件判斷解決方法

    這篇文章主要為大家介紹了微信小程序wxml不能使用Array.includes條件判斷解決方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • 實用框架(iframe)操作代碼

    實用框架(iframe)操作代碼

    這篇文章主要介紹了實用框架(iframe)操作代碼 ,需要的朋友可以參考下
    2014-10-10

最新評論