最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JavaScript字符串连接性能优化_javascript技巧

来源:动视网 责编:小采 时间:2020-11-27 20:41:50
文档

JavaScript字符串连接性能优化_javascript技巧

JavaScript字符串连接性能优化_javascript技巧: 代码如下:var str = hello; str += world; 后台所做工作: 1)创建存储 hello 的字符串,且使 str 指向它。 2)创建存储 world 的字符串。 3)创建存储结果的字符串。 4)将 str 中的当前内容复制到结果字符串中。 5)把 world 复制
推荐度:
导读JavaScript字符串连接性能优化_javascript技巧: 代码如下:var str = hello; str += world; 后台所做工作: 1)创建存储 hello 的字符串,且使 str 指向它。 2)创建存储 world 的字符串。 3)创建存储结果的字符串。 4)将 str 中的当前内容复制到结果字符串中。 5)把 world 复制


代码如下:
var str = "hello";
str += " world";

后台所做工作:
1)创建存储 "hello" 的字符串,且使 str 指向它。
2)创建存储 "world" 的字符串。
3)创建存储结果的字符串。
4)将 str 中的当前内容复制到结果字符串中。
5)把 world 复制到结果字符串中。
6)更新 str ,使 str 指向结果字符串。
每拼接一次字符串就循环重复2)~6),如果重复成百上千次则会非常消耗资源,影响性能。
解决方法:
使用 Array 对象存储字符串,之后使用 join()方法输出结果。
仿照 Java 中的 StringBuffer 类。
代码如下:
function StringBuffer(){
this._strings = new Array;
}
StringBuffer.prototype.append = function (str){
this._strings.push(str);
}
StringBuffer.prototype.toString = function (){
return this._strings.join("");
}

测试性能:
代码1:使用 "+=" 拼接字符串
代码如下:
var d = new Date();
var str = "";
for(var i=0;i<10000;i++){
str += "test";
}
var d2 = new Date();
document.writeln(d2.getTime()-d.getTime());

代码2:使用 StringBuffer
代码如下:
var d = new Date();
var str = new StringBuffer();
for(var i=0;i<10000;i++){
str.append("test");
}
var res = str.toString();
var d2 = new Date();
document.writeln(d2.getTime()-d.getTime());

从多次测试结果看来,使用StringBuffer 可以节省50%以上的时间。

文档

JavaScript字符串连接性能优化_javascript技巧

JavaScript字符串连接性能优化_javascript技巧: 代码如下:var str = hello; str += world; 后台所做工作: 1)创建存储 hello 的字符串,且使 str 指向它。 2)创建存储 world 的字符串。 3)创建存储结果的字符串。 4)将 str 中的当前内容复制到结果字符串中。 5)把 world 复制
推荐度:
标签: js 拼接 javascript
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top