JS中三种字符串连接方式及其性能比较

本文对比了JavaScript中三种常见的字符串连接方法:使用+运算符、数组的join方法及自定义对象连接方法。通过大量测试数据展示了不同场景下各方法的性能表现。

工作中经常会碰到要把2个或多个字符串连接成一个字符串的问题,在JS中处理这类问题一般有三种方法,这里将它们一一列出顺便也对它们的性能做个具体的比较。

第一种方法  用连接符“+”把要连接的字符串连起来:

str="a";
str+="b";

毫无疑问,这种方法是最便捷快速的,如果只连接100个以下的字符串建议用这种方法最方便。

 

第二种方法  以数组作为中介用 join 连接字符串:

var arr=new Array();
arr.push(a);
arr.push(b);
var str=arr.join("");

w3school 网站介绍说这种方法要比第一种消耗更少的资源,速度也更快,后面我们通过实验再验证是否是这样。

 

第三种方法  利用对象属性来连接字符串

复制代码
function stringConnect(){
    this._str_=new Array();
}
stringConnect.prototype.append=function(a){
    this._str_.push(a);
}
stringConnect.prototype.toString=function(){
    return this._str_.join();
}
    var mystr=new stringConnect;
    mystr.append("a");
    var str=mystr.toString();
复制代码

 

利用下面代码对三种方法性能进行比较,通过更改 c 的值来调整连接字符串的个数:

复制代码
var str="";
var d1,d2;
var c=5000;//连接字符串的个数

//------------------------测试第三种方法耗费时间------- d1=new Date(); function stringConnect(){ this._str_=new Array(); } stringConnect.prototype.append=function(a){ this._str_.push(a); } stringConnect.prototype.toString=function(){ return this._str_.join(""); } var mystr=new stringConnect; for(var i=0;i<c;i++){ mystr.append("a"); } str=mystr.toString(); d2=new Date(); console.log(d2.getTime()-d1.getTime()); //----------------------------------------------------- //------------------------测试第二种方法耗费时间------- d1=new Date(); var arr=new Array(); for(var i=0;i<c;i++){ arr.push("a"); } str=arr.join(""); d2=new Date(); console.log(d2.getTime()-d1.getTime()); //------------------------------------------------------- //------------------------测试第一种方法耗费时间------- d1=new Date();for(var i=0;i<c;i++){ str+="a"; } d2=new Date(); console.log(d2.getTime()-d1.getTime()); //-------------------------------------------------------
复制代码

 

 

我调整 c 分别等于5000、50000、500000、5000000,每个数值分别测了10次,最后结果如下:

c=5000
                                                                             平均耗时(单位毫秒)
第三种   3   2   2   3   1   2  2  1   1   1                              1.8
第二种   1   3   0   3   1   3  4  1   4   2                              2.2
第一种   0   0   0   0   0   1  1  1   1   1                              0.5


c=50000

第三种   22  12     9   14    12   13   13   13   10   17          13.5
第二种   8    13   12     8    11   11     8     9     8    9          9.7
第一种   7    12     5    11   10   10   10    13   16  12          10.6


c=500000

第三种 104 70 74 69 76 77 69 102 73 73                            78.7
第二种 78 100 99 99 100 98 96 71 94 97                             93.2
第一种 90 87 83 85 85 83 84 83 88 86                                 85.4


c=5000000

第三种 651 871 465 444 1012 436 787 449 432 444             599.1
第二种 568 842 593 747 417 747 719 549 573 563               631.8
第一种 516 279 616 161 466 416 201 495 510 515               417.5

统计5000000的时候在地址栏加入了随机参数,应该是避免了缓存的影响的。从结果来看,第一种方法并不比另2种方法消耗多,甚至还更有优势,这点和手册上的说明明显不一致。

 

测试系统:win 7旗舰

浏览器:chrome 52.0.2739.0 m

 




突破传统的上网方式,不用记网址、不用搜索引擎,输入一两个字母就能迅速打开你想访问的任何网站—— 小笨猪网址索引
分类:  性能优化
标签:  优化js对象连接字符串
1
0
« 上一篇: jquery 中toggle的2种用法
» 下一篇: 常见浏览器兼容性问题与解决方案
posted on  2016-06-02 23:08  老松壳 阅读( 44820) 评论( 1编辑  收藏

FeedBack:
#1楼    2017-10-30 09:54  guopeng1129972   
用到了

### JavaScript字符串连接方法 在JavaScript中,有多种方式可以实现字符串的连接或合并。以下是几种常见的方式及其特点: #### 1. 使用 `+` 或 `+=` 运算符 这是最简单也是最常见的字符串连接方式之一。通过加法运算符 (`+`) 可以轻松地将两个或多个字符串组合在一起。 ```javascript let str1 = "Hello, "; let str2 = "world!"; let result = str1 + str2; console.log(result); // 输出: Hello, world! ``` 这种方式的优点在于其简洁性易读性[^2]。 --- #### 2. 使用 `concat()` 方法 `concat()` 是一种专门用于字符串拼接的方法。它接受一个或多个参数,并返回一个新的字符串作为结果。 ```javascript let str1 = "Hello, "; let str2 = "world!"; let combined = str1.concat(str2); console.log(combined); // 输出: Hello, world! // 支持多个参数 let combinedMultiple = str1.concat(" ", str2, "!", " How are you?"); console.log(combinedMultiple); // 输出: Hello, world! How are you? ``` 需要注意的是,`concat()` 不会改变原始字符串的内容,而是返回一个新的字符串[^3]。 --- #### 3. 使用模板字符串(Template Literals) 模板字符串是一种现代的、功能强大的字符串表示形式,允许嵌入变量表达式,同时支持多行字符串。 ```javascript let name = "Alice"; let greeting = `Hello, ${name}!`; console.log(greeting); // 输出: Hello, Alice! // 多行字符串 let multiLine = ` This is a multi-line string. `; console.log(multiLine); ``` 模板字符串的优势在于它可以更直观地构建复杂的动态字符串,而不需要频繁调用其他方法[^3]。 --- #### 4. 使用 `join()` 方法(适用于数组场景) 虽然严格来说这不是直接针对字符串的操作,但在某些情况下可以通过先将字符串拆分为数组再重新组装来完成连接任务。 ```javascript let parts = ["Hello", "world"]; let joinedString = parts.join(", "); console.log(joinedString); // 输出: Hello, world ``` 此方法通常配合 `split()` 使用,在需要批量处理字符串片段时非常有用[^4]。 --- ### 总结 每种方法都有自己的适用范围与优缺点: - 如果追求极致性能或者兼容旧版浏览器,则推荐使用 `+`; - 对于更加灵活的功能需求可以选择 `concat()` 或者模板字符串; - 当面对大量离散数据单元待整合时考虑借助数组工具链如 `join()` 完成最终呈现效果。 以上就是关于如何在JavaScript里执行字符串连接的主要介绍[^1][^2][^3][^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值