一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

JavaScript 學習筆記(七)字符串的連接

字符串的連接
一、 最常用+=
一直說這種方式的效率是最低的,為什么呢?可以看下這種方式的實質過程。
var str = "hello";
str += "world";
(1) 創建存儲"hello"的字符串。
(2) 創建存儲"world"的字符串。
(3) 創建存儲連接結果的字符串。
(4) 把str的當前內容復制到結果中。
(5) 把"world"復制到結果中。
(6) 更新str,使它指向結果。
每次完成字符串連接都會執行步驟2到6,使得這種操作非常消耗資源。如果重復這一過程幾百次,甚至幾千次,就會造成性能問題。所有以后就要摒棄這種用法了,哈哈哈。^_^
二、 join()方法
復制代碼 代碼如下:
//按鈕調用
function JoinFn() {
var arr = new Array;
arr[0] = "張三";
arr[1] = "李四";
alert(arr.join(""));
}

執行的步驟如下:
(1) 創建存儲結果的字符串。
(2) 把每個字符串復制到結果中的合適位置。
這中方法效率比第一種快。
三、 封裝一個自定義的類
JavaScript中沒有像C#中那樣的StringBuilder類,但是我們可以自定義一個StringBuilder類,建類的方法就是上一篇提到的“混合的構造函數/原型方式”。
復制代碼 代碼如下:
//自定義一個StringBuilder類,用來連接字符串
function StringBuilder() {
this._strings = new Array();
}
StringBuilder.prototype.append = function(str) {
this._strings.push(str);
};
StringBuilder.prototype.toString = function() {
return this._strings.join("");
};
//按鈕調用
function MyConnectClassFn() {
var sb = new StringBuilder();
sb.append("張三");
sb.append("李四");
var strResult = sb.toString();
alert(strResult);
}

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

JavaScript技術JavaScript 學習筆記(七)字符串的連接,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产无遮挡床戏视频免费 | 精品国产区一区二区三区在线观看 | 很黄很色视频 | 美女久久精品 | 欧美日韩亚洲一区二区三区 | 91免费福利精品国产 | 色资源二区在线视频 | 老湿司午夜爽爽影院榴莲视频 | 免费激情网站 | 91精品国产综合久久久久 | 精品九九九 | 成人福利免费视频 | 看免费5xxaaa毛片 | 91短视频在线高清hd | 国产欧美另类久久久品 | 第一区| 一级做a | 色视频观看 | 亚1洲二区三区四区免费 | 不卡国产00高中生在线视频 | 天天色天天干天天 | 九九热久久免费视频 | 9ⅰ视频在线播放 | 四虎啪啪| 久久亚洲福利 | 91天堂97年嫩模在线观看 | 日韩精品欧美亚洲高清有无 | 国产精品一区视频 | 136xxoo导航| 天天躁日日躁狠狠躁中文字幕老牛 | 国产手机在线国内精品 | 亚洲肥熟 | 国产欧美在线观看精品一区二区 | 国产一级做a爰片久久毛片 国产一级做a爰片久久毛片99 | 韩国一级片免费 | 久久88色综合色鬼 | 日韩精品一区二区三区免费视频 | 草草国产 | 四虎永久在线精品视频免费观看 | 欧美综合图片 | 精品免费国产一区二区三区 |