ES9 新增 String.prototype.trimStart() 和 String.prototype.trimEnd() 方法

阅读时长 4 分钟读完

在 ES9(ECMAScript 2018)中,JavaScript 新增了两个字符串方法:String.prototype.trimStart()String.prototype.trimEnd()。这两个方法用于去除字符串开头和结尾的空白字符。

为什么需要这两个方法

在前端开发中,我们经常需要处理用户输入的字符串。用户输入的字符串可能会包含空白字符,例如空格、制表符、换行符等。这些空白字符在某些情况下可能会导致问题,例如:

  • 用户输入的密码中包含空格,导致无法登录
  • 用户复制粘贴的链接中包含空格,导致打不开链接
  • 用户输入的搜索关键字中包含空格,导致搜索结果不准确

为了解决这些问题,我们需要去除字符串开头和结尾的空白字符。在 ES9 之前,我们可以使用 String.prototype.trim() 方法去除字符串开头和结尾的空白字符。但是,这个方法只能去除开头和结尾的空白字符,不能去除字符串中间的空白字符。而且,这个方法是不可变的,即它不会修改原始字符串,而是返回一个新的字符串。这就意味着,每次调用这个方法都会创建一个新的字符串对象,会影响性能。

为了解决这些问题,ES9 新增了 String.prototype.trimStart()String.prototype.trimEnd() 方法,可以去除字符串开头和结尾的空白字符,并且它们是可变的,即它们会修改原始字符串。

用法示例

String.prototype.trimStart()

String.prototype.trimStart() 方法用于去除字符串开头的空白字符。它的用法如下:

在上面的代码中,str 字符串开头有三个空格字符,调用 trimStart() 方法后,返回一个新的字符串对象 'hello world',去除了开头的空白字符。

String.prototype.trimEnd()

String.prototype.trimEnd() 方法用于去除字符串结尾的空白字符。它的用法如下:

在上面的代码中,str 字符串结尾有三个空格字符,调用 trimEnd() 方法后,返回一个新的字符串对象 'hello world',去除了结尾的空白字符。

String.prototype.trimStart()String.prototype.trimEnd() 的组合使用

String.prototype.trimStart()String.prototype.trimEnd() 方法可以组合使用,用于去除字符串开头和结尾的空白字符。它的用法如下:

在上面的代码中,str 字符串开头和结尾都有三个空格字符,先调用 trimStart() 方法去除开头的空白字符,再调用 trimEnd() 方法去除结尾的空白字符,返回一个新的字符串对象 'hello world'

总结

ES9 新增的 String.prototype.trimStart()String.prototype.trimEnd() 方法,可以用于去除字符串开头和结尾的空白字符,解决了在前端开发中处理用户输入字符串的问题。这两个方法是可变的,即它们会修改原始字符串,不会创建新的字符串对象,因此性能更好。在实际开发中,可以根据需要选择使用这两个方法。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/657d6a4cd2f5e1655d83bcbd

纠错
反馈