zoukankan      html  css  js  c++  java
  • js 去掉空格 (转帖)

    JavaScript去除字符串两边空格trim(转帖)

    2011-03-01

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

    写成类的方法格式如下:(str.trim();)

    	<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))

    	<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>
    

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

    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 使用

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

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

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

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

    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 方法。

  • 相关阅读:
    【InfoPath2007】The form has been closed
    深入浅出Nintex——调用子流程
    深入浅出Nintex——使用查询XML动作
    深入浅出Nintex——使用Call WebService来查询Item ID
    深入浅出Nintex——获得某群组的用户集合
    深入浅出SharePoint2007——Webpart开发
    深入浅出Nintex——获得指定用户的角色
    深入浅出Nintex——使用构建动态字符串动作
    Lucene.net 实现全文搜索
    DotLucene源码浅读笔记(1)补遗:编写简单中文分词器ChineseAnalyzer
  • 原文地址:https://www.cnblogs.com/umlzhang/p/2519211.html
Copyright © 2011-2022 走看看