JavaScript 学习笔记二 字符串拼接_基础知识
程序员文章站
2022-05-10 11:04:43
...
var str="hello";
str+="world";
实际上,这段代码在幕后执行的步骤如下:
(1) 创建存储"hello"的字符串。
(2) 创建存储"world"的字符串。
(3) 创建存储连接结果的字符串。
(4) 把str的当前内容复制到结果中。
(5) 把"world"复制到结果中。
(6) 更新str,使它指向结果。
每次完成字符串连接都会执行步骤2到6,使得这种操作非常消耗资源。如果重复这一过程几百次,甚至几千次,就会造成性能问题。解决方法是用Array对象存储字符串,然后用join()方法(参数是空字符串)创建最后的字符串。想像用下面的代码代替前面的代码:
var str=new Array();
str[0]="hello";
str[1]="world";
str.join("");
这样,无论在数组中引入多少字符串都不成问题,因为只在调用join()方法时才会发生连接操作。此时,执行的步骤如下:
(1) 创建存储结果的字符串。
(2) 把每个字符串复制到结果中的合适位置。
function StringBuilder(){
this._string=new Array();
}
StringBuilder.prototype.Append=function(str){
this._string.push(str);
}
StringBuilder.prototype.toString=function(){
return this._string.join("");
}
相关提升效率的文章:
html数组字符串拼接的最快方法
javascript之大字符串的连接的StringBuffer 类
更多可以参考脚本之家以前的文章。
str+="world";
实际上,这段代码在幕后执行的步骤如下:
(1) 创建存储"hello"的字符串。
(2) 创建存储"world"的字符串。
(3) 创建存储连接结果的字符串。
(4) 把str的当前内容复制到结果中。
(5) 把"world"复制到结果中。
(6) 更新str,使它指向结果。
每次完成字符串连接都会执行步骤2到6,使得这种操作非常消耗资源。如果重复这一过程几百次,甚至几千次,就会造成性能问题。解决方法是用Array对象存储字符串,然后用join()方法(参数是空字符串)创建最后的字符串。想像用下面的代码代替前面的代码:
复制代码 代码如下:
var str=new Array();
str[0]="hello";
str[1]="world";
str.join("");
这样,无论在数组中引入多少字符串都不成问题,因为只在调用join()方法时才会发生连接操作。此时,执行的步骤如下:
(1) 创建存储结果的字符串。
(2) 把每个字符串复制到结果中的合适位置。
复制代码 代码如下:
function StringBuilder(){
this._string=new Array();
}
StringBuilder.prototype.Append=function(str){
this._string.push(str);
}
StringBuilder.prototype.toString=function(){
return this._string.join("");
}
相关提升效率的文章:
html数组字符串拼接的最快方法
javascript之大字符串的连接的StringBuffer 类
更多可以参考脚本之家以前的文章。
推荐阅读
-
C学习笔记(5)--- 指针第二部分,字符串,结构体。
-
JavaScript学习笔记(五)——类型、转换、相等、字符串
-
JavaScript正则表达式学习笔记(二) - 打怪升级
-
PHP学习笔记(之 篇二常量、字符串、运算符、数组、if、switch)
-
JavaScript高级程序设计(第三版)学习笔记(二)JavaScript使用
-
《JavaScript DOM编程艺术》(第二版)学习笔记(一)
-
JavaScript高级程序设计(第四版)学习笔记(第二章 HTML中的JavaScript)
-
ASP.NET学习笔记(二)字符串常见操作
-
Python 学习笔记(七)Python字符串(二)
-
我的ASP.NET学习笔记05Javascript基础知识01