ECMAScript6面对大于0xFFFF的Unicode字符如何正确返回长度

Posted Mazey

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ECMAScript6面对大于0xFFFF的Unicode字符如何正确返回长度相关的知识,希望对你有一定的参考价值。

一、match()

1.定义

match()方法用于检索字符串内指定(字符串或正则)的值,返回指定值的数组,若找不到,返回null。

2.语法

str.match(searchvalue)
str.match(regexp)

3.示例

let str = 'abc-def-zxc';
console.log(str.match('-')); // ["-", index: 3, input: "abc-def-zxc"]
console.log(str.match(/[a-z]{3}/g)); // ["abc", "def", "zxc"]

4.注意

match()常常与正则标识g配合使用,若没有g则只匹配一次。

let str = 'abc-def-zxc';
console.log(str.match(/[a-z]{3}/)); // ["abc", index: 0, input: "abc-def-zxc"]
console.log(str.match(/[a-z]{3}/g)); // ["abc", "def", "zxc"]

二、使用match()方法判断大于0xFFFF的Unicode字符长度

正则标识u能识别码点大于0xFFFF的Unicode字符。

console.log(/^.$/.test('??')); // false 正常情况下??被当作两个字符
console.log(/^.$/u.test('??')); // true

利用u这个特性可以用来验证判断大于0xFFFF的Unicode字符长度。

function getRealLength (str) {
    let ret = str.match(/./gu);
    return ret ? ret.length : 0;
}
let str = '??????';
console.log(str.length); // 6
console.log(getRealLength(str)); // 3

以上是关于ECMAScript6面对大于0xFFFF的Unicode字符如何正确返回长度的主要内容,如果未能解决你的问题,请参考以下文章

ES6 字符串的新增方法

字符串的新增方法

ES6字符串对象的新增11种实例方法必知

ES6语法总结-字符串新增方法

uni-app三目运算 uni-app监听属性

uni-app开发微信小程序的几天时间