JavaScript中对字符串中空格的处理


在JavaScript语言中,字符串就是一种对象。

字符串的操作必须使用内置的构造器和设置方法来完成,JavaScript为字符串提供了很多方法,最常用的比如indexOf()、charAt()和substring()。然而,有一些其他开发语言中字符串的常用操作却没有提供,比如是去除字符串前后空格的trim()函数就没有提供。

在这里,为广大web开发者提供一个字符串trim()的源码,希望能为大家开发中提供方便:
function trim(s)
{
    if (s == null)
    {
        return s;
    }

    var i;
    var beginIndex = 0;
    var endIndex = s.length - 1;

    for (i=0; i<s.length; i++)
    {
        if (s.charAt(i) == ' ' || s.charAt(i) == ' ')
        {
            beginIndex++;
        }
        else
        {
            break;
        }
    }

    for (i = s.length - 1; i >= 0; i--)
    {
        if (s.charAt(i) == ' ' || s.charAt(i) == ' ')
        {
            endIndex--;
        }
        else
        {
            break;
        }
    }

    if (endIndex < beginIndex)
    {
        return "";
    }

    return s.substring(beginIndex, endIndex + 1);
}
上面这个trim()函数只是将字符串s的前后空格去掉了,而对字符串中间的空格没有受影响。

如果说在字符串中间有多个连续空格,而只想保留其中的一个,可以用下边的cutSpace()函数:

//去除多余的空格,如果有连续空格,只保留第一个
function cutSpace(s)
{
    var len = s.length;
    var i;
    var ch;
    var result = "";

    i = 0;
    while (i < len)
    {
        ch = s.charAt(i++);
        result += ch;
        if (ch != ' ')
        {
            continue;
        }

        while (i < len && (ch = s.charAt(i)) == ' ')
        {
           i++;
        }
    }

    return result;
}
可能有人会觉得为什么不把中间的空格都去掉了,一个都不留呢?呵呵,空格存在必然有其存在的道理。空格一般来说就是用来分隔的,多了就浪费空间了,而一个都不留的话,那么就没有分隔了,所有的字、词、句都连一块了。因此,去除空格也应该考虑“过犹不及”。

当然,如果用户真有去掉所有空格的需求,相信你根据上边的cutSpace()函数稍稍改写一下,就能实现你的需要。祝你顺利。

简短的Trim

String.prototype.trim  =   function ()  {
    
return this.replace(/^s+|s+$/g,"");
}

String.prototype.ltrim 
=   function ()  {
    
return this.replace(/^s+/,"");
}

String.prototype.rtrim 
=   function ()  {
    
return this.replace(/s+$/,"");
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值