js去除空格的12种实用方法


Posted in Javascript onNovember 08, 2013

实现1

String.prototype.trim = function() {
 return this.replace(/^\s\s*/, '').replace(/\s\s*$/, '');
}

看起来不怎么样, 动用了两次正则替换,实际速度非常惊人,主要得益于浏览器的内部优化。一个著名的例子字符串拼接,直接相加比用Array做成的StringBuffer 还快。base2类库使用这种实现。

实现2

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

和实现1 很相似,但稍慢一点,主要原因是它最先是假设至少存在一个空白符。Prototype.js使用这种实现,不过其名字为strip,因为 Prototype的方法都是力求与Ruby同名。

实现3

String.prototype.trim = function() {
 return this.substring(Math.max(this.search(/\S/), 0),this.search(/\S\s*$/) + 1);
}

以截取方式取得空白部分(当然允许中间存在空白符),总共 调用了四个原生方法。设计得非常巧妙,substring以两个数字作为参数。Math.max以两个数字作参数,search则返回一个数字。速度比上 面两个慢一点,但比下面大多数都快。

实现4

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

这个可以称得上实现2的简化版,就是 利用候选操作符连接两个正则。但这样做就失去了浏览器优化的机会,比不上实现3。由于看来很优雅,许多类库都使用它,如JQuery与mootools

实现5

String.prototype.trim = function() {
 var str = this;
 str = str.match(/\S+(?:\s+\S+)*/);
 return str ? str[0] : '';
}

match 是返回一个数组,因此原字符串符合要求的部分就成为它的元素。为了防止字符串中间的空白符被排除,我们需要动用到非捕获性分组(?:exp)。由于数组可 能为空,我们在后面还要做进一步的判定。好像浏览器在处理分组上比较无力,一个字慢。所以不要迷信正则,虽然它基本上是万能的。

实现6

String.prototype.trim = function() {
 return this.replace(/^\s*(\S*(\s+\S+)*)\s*$/, '$1');
}

把符合要求的部分提供出来,放到一个空字符串中。不过效率很差,尤其是在IE6中。

实现7

String.prototype.trim = function() {
 return this.replace(/^\s*(\S*(?:\s+\S+)*)\s*$/, '$1');
}

和实现6很相似,但用了非捕获分组进行了优点,性能效之有一点点提升。

实现8

String.prototype.trim = function() {
 return this.replace(/^\s*((?:[\S\s]*\S)?)\s*$/, '$1');
}

沿着上面两个的思路进行改进,动用了非捕获分组与字符集合,用?顶替了*,效果非常惊人。尤其在IE6中,可 以用疯狂来形容这次性能的提升,直接秒杀火狐。

实现9

String.prototype.trim = function() {
 return this.replace(/^\s*([\S\s]*?)\s*$/, '$1');
}

这次是用懒惰匹配 顶替非捕获分组,在火狐中得到改善,IE没有上次那么疯狂。

实现10

String.prototype.trim = function() {
 var str = this,
 whitespace = ' \n\r\t\f\x0b\xa0\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u200b\u2028\u2029\u3000';
 for (var i = 0,len = str.length; i < len; i++) {
  if (whitespace.indexOf(str.charAt(i)) === -1) {
   str = str.substring(i);
   break;
  }
 }
 for (i = str.length - 1; i >= 0; i--) {
  if (whitespace.indexOf(str.charAt(i)) === -1) {
   str = str.substring(0, i + 1);
   break;
  }
 }
 return whitespace.indexOf(str.charAt(0)) === -1 ? str : '';
}

我 只想说,搞出这个的人已经不是用牛来形容,已是神一样的级别。它先是把可能的空白符全部列出来,在第一次遍历中砍掉前面的空白,第二次砍掉后面的空白。全 过程只用了indexOf与substring这个专门为处理字符串而生的原生方法,没有使用到正则。速度快得惊人,估计直逼上内部的二进制实现,并且在 IE与火狐(其他浏览器当然也毫无疑问)都有良好的表现。速度都是零毫秒级别的。

实现11

String.prototype.trim = function() {
 var str = this,
 str = str.replace(/^\s+/, '');
 for (var i = str.length - 1; i >= 0; i--) {
  if (/\S/.test(str.charAt(i))) {
   str = str.substring(0, i + 1);
   break;
  }
 }
 return str;
}

实现10已经告诉我们普通的原生字符串截取方法是远胜于正则替换,虽然是复杂一点。但只要正则 不过于复杂,我们就可以利用浏览器对正则的优化,改善程序执行效率,如实现8在IE的表现。我想通常不会有人在项目中应用实现10,因为那个 whitespace 实现太长太难记了(当然如果你在打造一个类库,它绝对是首先)。实现11可谓其改进版,前面部分的空白由正则替换负责砍掉,后面用原生方法处理,效果不逊 于原版,但速度都是非常逆天。

实现12

String.prototype.trim = function() {
 var str = this,
 str = str.replace(/^\s\s*/, ''),
 ws = /\s/,
 i = str.length;
 while (ws.test(str.charAt(--i)));
 return str.slice(0, i + 1);
}

实现10与实现11在写法上更好的改进版,注意说的不是性能速 度,而是易记与使用上。和它的两个前辈都是零毫秒级别的,以后就用这个来工作与吓人。

JS(去掉前后空格或去掉所有空格)的用法

1、 去掉字符串前后所有空格:

代码如下:

function Trim(str){ 
 return str.replace(/(^\s*)|(\s*$)/g, ""); 
}

说明:

如果使用jQuery直接使用$.trim(str)方法即可,str表示要去掉前后所有空格的字符串。

2、 去掉字符串中所有空格(包括中间空格,需要设置第2个参数为:g)

代码如下:

function Trim(str,is_global){
  var result;
  result = str.replace(/(^\s+)|(\s+$)/g,"");
  if(is_global.toLowerCase()=="g")
      {
        result = result.replace(/\s/g,"");
       }
      return result;
}
Javascript 相关文章推荐
jQuery学习笔记之jQuery的DOM操作
Dec 22 Javascript
Js点击弹出下拉菜单效果实例
Aug 12 Javascript
jquery制作 随机弹跳的小球特效
Feb 01 Javascript
jQuery日期范围选择器附源码下载
May 23 jQuery
Swiper实现轮播图效果
Jul 03 Javascript
vue+Java后端进行调试时解决跨域问题的方式
Oct 19 Javascript
动手写一个angular版本的Message组件的方法
Dec 16 Javascript
JS实现简单的星期格式转换功能示例
Jul 23 Javascript
详解Vue CLI 3.0脚手架如何mock数据
Nov 23 Javascript
Vue 3.x+axios跨域方案的踩坑指南
Jul 04 Javascript
vue transition 在子组件中失效的解决
Nov 12 Javascript
javascript+css实现俄罗斯方块小游戏
Jun 28 Javascript
js加载之使用DOM方法动态加载Javascript文件
Nov 08 #Javascript
javascript获取url上某个参数的方法
Nov 08 #Javascript
jqgrid 编辑添加功能详细解析
Nov 08 #Javascript
动态加载JS文件的三种方法
Nov 08 #Javascript
JQGrid的用法解析(列编辑,添加行,删除行)
Nov 08 #Javascript
jQuery 获取和设置select下拉框的值实现代码
Nov 08 #Javascript
jqGrid增加时--判断开始日期与结束日期(实例解析)
Nov 08 #Javascript
You might like
重新封装zend_soap实现http连接安全认证的php代码
2011/01/12 PHP
详谈symfony window下的安装 安装时候出现的问题以及解决方法
2017/09/28 PHP
Laravel中的Blade模板引擎示例详解
2017/10/10 PHP
一个判断email合法性的函数[非正则]
2008/12/09 Javascript
javascript操作cookie_获取与修改代码
2009/05/21 Javascript
Javascript学习笔记6 prototype的提出
2010/01/11 Javascript
JavaScript Timer实现代码
2010/02/17 Javascript
JavaScript中的一些定位属性[图解]
2010/07/14 Javascript
jquery插件unobtrusive实现片段式加载
2015/06/15 Javascript
Bootstrap每天必学之下拉菜单
2015/11/25 Javascript
AngularJS实现表单手动验证和表单自动验证
2015/12/09 Javascript
Vue.js教程之计算属性
2016/11/11 Javascript
laydate如何根据开始时间或者结束时间限制范围
2018/11/15 Javascript
详解nodejs 配置文件处理方案
2019/01/02 NodeJs
如何在vue中使用video.js播放m3u8格式的视频
2021/02/01 Vue.js
说一说Python logging
2016/04/15 Python
利用Python如何生成随机密码
2016/04/20 Python
Python基于回溯法子集树模板解决找零问题示例
2017/09/11 Python
python高效过滤出文件夹下指定文件名结尾的文件实例
2018/10/21 Python
python 为什么说eval要慎用
2019/03/26 Python
基于plt.title无法显示中文的快速解决
2020/05/16 Python
Python爬虫实现百度翻译功能过程详解
2020/05/29 Python
pycharm 对代码做静态检查操作
2020/06/09 Python
浅谈matplotlib 绘制梯度下降求解过程
2020/07/12 Python
python 使用csv模块读写csv格式文件的示例
2020/12/02 Python
美国最大的在线寄售和旧货店:Swap.com
2018/08/27 全球购物
为娇小女性量身打造:Petite Studio
2018/11/01 全球购物
Etam俄罗斯:法国女士内衣和家居服网上商店
2019/10/30 全球购物
J2ee常用的设计模式?说明工厂模式
2015/05/21 面试题
应届生煤化工求职信
2013/10/21 职场文书
行政助理的职责
2013/11/14 职场文书
2014年党员公开承诺践诺书
2014/03/25 职场文书
大型会议策划方案
2014/05/17 职场文书
学校通报表扬范文
2015/05/04 职场文书
热血教师观后感
2015/06/10 职场文书
优秀新员工事迹材料
2019/05/13 职场文书