美文网首页
字符串的新增方法

字符串的新增方法

作者: 皇甫贝 | 来源:发表于2019-10-17 16:33 被阅读0次
  1. String.fromCodePoint()
  2. String.raw()
  3. 实例方法:codePointAt()
  4. 实例方法:normalize()
  5. 实例方法:includes(), startsWith(), endsWith()
  6. 实例方法:repeat()
  7. 实例方法:padStart(),padEnd()
  8. 实例方法:trimStart(),trimEnd()
  9. 实例方法:matchAll()

String.fromCodePoint()

优点:

用于从 Unicode 码点返回对应字符 ,弥补ES5 提供的String.fromCharCode()方法的不足(不能识别码点大于0xFFFF的字符)

用法:
String.fromCodePoint(0x20BB7)
// "𠮷"
String.fromCodePoint(0x78, 0x1f680, 0x79) === 'x\uD83D\uDE80y'
// true

上面代码中,如果String.fromCodePoint方法有多个参数,则它们会被合并成一个字符串返回。
注意,fromCodePoint方法定义在String对象上,而codePointAt方法定义在字符串的实例对象上。


String. raw()

优点:

返回一个斜杠都被转义(即斜杠前面再加一个斜杠)的字符串

使用场景:

用于模板字符串的处理方法

缺点:

如果原字符串的斜杠已经转义,那么String.raw()会进行再次转义。

用法:
String.raw`Hi\n${2+3}!`
// 实际返回 "Hi\\n5!",显示的是转义后的结果 "Hi\n5!"
String.raw`Hi\u000A!`;
// 实际返回 "Hi\\u000A!",显示的是转义后的结果 "Hi\u000A!"
// 再次转译
String.raw`Hi\\n`
// 返回 "Hi\\\\n"
String.raw`Hi\\n` === "Hi\\\\n" // true

String.raw()本质上是一个正常的函数,只是专用于模板字符串的标签函数。如果写成正常函数的形式,它的第一个参数,应该是一个具有raw属性的对象,且raw属性的值应该是一个数组,对应模板字符串解析后的值。

// `foo${1 + 2}bar`
// 等同于
String.raw({ raw: ['foo', 'bar'] }, 1 + 2) // "foo3bar"
作为函数的用法:
String.raw = function (strings, ...values) {
  let output = '';
  let index;
  for (index = 0; index < values.length; index++) {
    output += strings.raw[index] + values[index];
  }
  output += strings.raw[index]
  return output;
}

codePointAt()

作用

弥补ES5charAt()方法无法读取完整字符(只能读取2个字节)
测试一个字符由两个字节还是由四个字节组成的最简单方法
codePointAt()方法返回的是码点的十进制值(返回 32 位的 UTF-16 字符的码点),如果想要十六进制的值,可以使用toString()方法转换一下。

使用方式
// 十进制值
let s = '𠮷a';
s.codePointAt(0).toString(16) // "20bb7"
s.codePointAt(2).toString(16) // "61"
// 十六进制值
s.codePointAt(0).toString(16) // "20bb7"
s.codePointAt(2).toString(16) // "61"

注意上面的,codePointAt()方法的参数,仍然是不正确的。比如,上面代码中,字符a在字符串s的正确位置序号应该是 1,但是必须向codePointAt()方法传入 2。解决这个问题的一个办法是使用for...of循环,因为它会正确识别 32 位的 UTF-16 字符。

let s = '𠮷a';
for (let ch of s) {
  console.log(ch.codePointAt(0).toString(16));
}
// 20bb7
// 61

另一种方法也可以,使用扩展运算符(...)进行展开运算。

let arr = [...'𠮷a']; // arr.length === 2
arr.forEach(
  ch => console.log(ch.codePointAt(0).toString(16))
);
// 20bb7
// 61

测试一个字符由两个字节还是由四个字节组成的方法

function is32Bit(c) {
  return c.codePointAt(0) > 0xFFFF;
}
is32Bit("𠮷") // true
is32Bit("a") // false

normalize(略,没看懂)

实例方法():includes(), startsWith(), endsWith()

传统上,JavaScript 只有indexOf方法,可以用来确定一个字符串是否包含在另一个字符串中。ES6 又提供了三种新方法。

  • includes():返回布尔值,表示是否找到了参数字符串。
  • startsWith():返回布尔值,表示参数字符串是否在原字符串的头部。
  • endsWith():返回布尔值,表示参数字符串是否在原字符串的尾部。
let s = 'Hello world!';
s.startsWith('Hello') // true
s.endsWith('!') // true
s.includes('o') // true

这三个方法都支持第二个参数,表示开始搜索的位置

let s = 'Hello world!';
s.startsWith('world', 6) // true
s.endsWith('Hello', 5) // true
s.includes('Hello', 6) // false

上面代码表示,使用第二个参数n时,endsWith的行为与其他两个方法有所不同。它针对前n个字符,而其他两个方法针对从第n个位置直到字符串结束。


实例方法:repeat()

repeat方法返回一个新字符串,表示将原字符串重复n

注意:
  • 参数如果是小数,会被向下取整(1.9 => 1 ; 0.9 => 0)
  • 如果repeat的参数是负数或者Infinity,会报错
  • 参数NaN等同于 0。
  • 如果repeat的参数是数字字符串,则会转换成数字;如果是字母、汉字、中英文字母,则会转成0
'x'.repeat(3) // "xxx"
'hello'.repeat(2) // "hellohello"
'na'.repeat(0) // ""

// 小数取整
'na'.repeat(2.9) // "nana"

// 负数或者Infinity
'na'.repeat(Infinity)
// RangeError
'na'.repeat(-1)
// RangeError

//报错
'na'.repeat(-0.9) // ""

//参数NaN等同于 0
'na'.repeat(NaN) // ""

//参数是字符串,则会先转换成数字
'na'.repeat('na') // ""
'na'.repeat('3') // "nanana"


实例方法:trimStart(),trimEnd()
  • 这两个方法与trim()功能一致,trimStart()消除字符串头部的空格,trimEnd()消除尾部的空格。它们返回的都是新字符串,不会修改原始字符串
  • 浏览器还部署了额外的两个方法,trimLeft()trimStart()的别名,trimRight()trimEnd()的别名。
const s = '  abc  ';
s.trim() // "abc"
s.trimStart() // "abc  "
s.trimEnd() // "  abc"

trimStart()只消除头部的空格,保留尾部的空格。trimEnd()也是类似行为。

除了空格键,这两个方法对字符串头部(或尾部)的 tab 键、换行符等不可见的空白符号也有效。


实例方法:matchAll()

matchAll()方法返回一个正则表达式在当前字符串的所有匹配

相关文章

  • learn-es6常用语法(4)

    1字符串新增方法 模板字符串 ${变量} `` `解决之前字符串连接要多次拼接的问题 新增方法 startsWi...

  • ES6学习 第四章 字符串的新增方法

    前言 本章介绍字符串对象的新增方法。不常用的方法不做重点笔记。本章原文链接:字符串的新增方法[https://es...

  • 字符串

    1. 字符串方法。 2. ES6新增加的字符串方法。

  • ES6基础入门教程(十三)新增的字符串方法

    新增:模板字符串 你要注意,输出的时候,下面那个可不是引号,是 数字1 旁边那个波折号。。 新增:字符串方法 新增...

  • es6-字符串扩展

    字符串新增特性 Unicode表示法 遍历接口 模板字符串 新增方法 babel-polifill 兼容 es7 ...

  • JS判断对象是否为空

    方法一: 将 Object 对象转换为字符串,然后判断字符串 方法二: 方法三: ES6 新增的方法 Object...

  • ECMAScript 6 新增内容

    变量的扩展letconst变量的结构 字符串的扩展及新增方法模板字符串 (`${}`)matchAll 方法返回一...

  • ECMAScript6--5.字符串扩展

    1.字符串新增特性 Unicode表示法 遍历接口 模板字符串 新增方法(10种)eg:1.Unicode表示法{...

  • ES6新增(学习中...)

    1、多行字符串的表示方法:把字符放在``的中间例如: 2、字符串的连接,新增了模板字符串例如:

  • 字符串

    1、模版字符串 2、字符串新增的一些方法 intro.startWidth('我'):字符串是否以“我”为开头in...

网友评论

      本文标题:字符串的新增方法

      本文链接:https://www.haomeiwen.com/subject/mhjmmctx.html