zoukankan      html  css  js  c++  java
  • JavaScript去除字符串两边空格trim

    去除字符串左右两端的空格,在大部分编程语言中,比如PHP、vbscript里面可以轻松地使用 trim、ltrim 或 rtrim实现。但在js中却没有这3个内置方法,需要手工编写。下面的实现方法是用到了正则表达式,效率不错,并把这三个方法加入String对象的内置方法中去。写成类的方法格式如下:(str.trim();)

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <script language="javascript">
      String.prototype.trim=function(){
         return this.replace(/(^\s*)|(\s*$)/g, "");
      }
      String.prototype.ltrim=function(){
         return this.replace(/(^\s*)/g,"");
      }
      String.prototype.rtrim=function(){
         return this.replace(/(\s*$)/g,"");
      }
     </script>

    写成函数可以这样:(trim(str))

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <script type="text/javascript">
      function trim(str){ //删除左右两端的空格
          return str.replace(/(^\s*)|(\s*$)/g, "");
      }
      function ltrim(str){ //删除左边的空格
          return str.replace(/(^\s*)/g,"");
      }
      function rtrim(str){ //删除右边的空格
          return str.replace(/(\s*$)/g,"");
      }
     </script>

    这是lgzx公司的一道面试题,要求给js的String添加一个方法,去除字符串两边的空白字符(包括空格、制表符、换页符等)。

    1
    2
    3
    4
    5
    String.prototype.trim = function() {
        //return this.replace(/[(^\s+)(\s+$)]/g,"");//會把字符串中間的空白符也去掉
        //return this.replace(/^\s+|\s+$/g,""); //
        return this.replace(/^\s+/g,"").replace(/\s+$/g,"");
    }

    JQuery1.4.2,Mootools 使用

    1
    2
    3
    function trim1(str){
        return str.replace(/^(\s|\xA0)+|(\s|\xA0)+$/g, '');
    }

    jQuery1.4.3,Prototype 使用,该方式去掉g以稍稍提高性能 在小规模的处理字符串时性能较好

    1
    2
    3
    function trim2(str){
        return str.replace(/^(\s|\u00A0)+/,'').replace(/(\s|\u00A0)+$/,'');
    }

    Steven Levithan 在进行性能测试后提出了在JS中执行速度最快的裁剪字符串方式,在处理长字符串时性能较好

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    function trim3(str){
        str = str.replace(/^(\s|\u00A0)+/,'');
        for(var i=str.length-1; i>=0; i--){
            if(/\S/.test(str.charAt(i))){
                str = str.substring(0, i+1);
                break;
            }
        }
        return str;
    }

    最后需要提到的是 ECMA-262(V5) 中给String添加了原生的trim方法(15.5.4.20)。此外Molliza Gecko 1.9.1引擎中还给String添加了trimLeft ,trimRight 方法。

    本文载自:http://www.nowamagic.net/javascript/js_TrimInJavascript.php

  • 相关阅读:
    Layui表格之动态添加数据(表格多选解决方案)
    Ztree勾选节点后取消勾选其父子节点
    如何判断某个元素在页面上是否存在
    Linux环境搭建SVN服务
    Linux环境下验证码不显示F12报500
    Ztree节点前加上两个自定义按钮
    解决window.location.href参数太长
    Ztree加载完成默认选中根节点右侧生成表格
    输入框点击下滑Ztree菜单
    Mybatis中and和or的细节处理
  • 原文地址:https://www.cnblogs.com/shoupifeng/p/2693211.html
Copyright © 2011-2022 走看看