温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

javascript怎么提升字符串拼接的效率及性能

发布时间:2021-11-20 14:00:51 来源:亿速云 阅读:411 作者:iii 栏目:开发技术

本篇内容主要讲解“javascript怎么提升字符串拼接的效率及性能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript怎么提升字符串拼接的效率及性能”吧!

/*
利用Array对象join方法模拟 C#中的StringBuilder,提升JS中字符串拼接的效率及性能。
功能同JS文件夹下StringBuilder.js文件实现功能,
因实现方式不同且为避免冲突将此文件置于该文件夹下供月度资金计划使用
Author : panwb 
Date   : 2012-11-29
*/
function StringBuilder(str)
{
    //字符串数组
	this.arrstr = (str === undefined ? new Array() : new Array(str.toString()));

    //字符串长度(任何影响newstr字符串长度的方法都必须同时重置length)
	this.length = (str === undefined ? 0 : str.length);

    // 字符串模板转换,类似于C#中的StringBuilder.Append方法
	this.append = StringBuilder_append;

    // 字符串模板转换,类似于C#中的StringBuilder.AppendFormat方法
	this.appendFormat = StringBuilder_appendFormat;

    //重写toString()方法
	this.toString = StringBuilder_toString;

    //重写replace()方法
	this.replace = StringBuilder_replace;

    //添加remove()方法
	this.remove = StringBuilder_remove;

    //从当前实例中移除所有字符
    this.clear = StringBuilder_clear;
}

// 字符串模板转换,类似于C#中的StringBuilder.Append方法
function StringBuilder_append(f)
{
    if (f === undefined || f === null)
    {
        return this;
    }

    this.arrstr.push(f);
    this.length += f.length;
    return this;
}

// 字符串模板转换,类似于C#中的StringBuilder.AppendFormat方法
function StringBuilder_appendFormat(f)
{
    if (f === undefined || f === null)
    {
        return this;
    }

    //存储参数,避免replace回调函数中无法获取调用该方法传过来的参数
    var params = arguments;
    
    var newstr = f.toString().replace(/\{(\d+)\}/g,
        function (i, h) { return params[parseInt(h, 10) + 1]; });
    this.arrstr.push(newstr);
    this.length += newstr.length;
    return this;
}

//重写toString()方法
function StringBuilder_toString()
{
    return this.arrstr.join('');
}

//重新replace()方法
function StringBuilder_replace()
{
    if (arguments.length >= 1)
    {
        var newstr = this.arrstr.join('').replace(arguments[0], arguments[1]);
        this.arrstr.length = 0;
        this.length = newstr.length;
        this.arrstr.push(newstr);
    }
    return this;
}

//添加remove()方法
function StringBuilder_remove()
{
    if (arguments.length > 0)
    {
        var oldstr = this.arrstr.join('');
        var substr = (arguments.length >= 2 ?
            oldstr.substring(arguments[0], arguments[1]) : oldstr.substring(arguments[0]));
        var newstr = oldstr.replace(substr, "");
        this.arrstr.length = 0;
        this.length = newstr.length;
        this.arrstr.push(newstr);
    }
    return this;
}

//从当前实例中移除所有字符
function StringBuilder_clear()
{
    this.arrstr.length = 0;
    this.length = 0;
    return this;
}

到此,相信大家对“javascript怎么提升字符串拼接的效率及性能”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI