猫幻  
对于一些超过俩个字符四个字节的异体文字,es6新增了codePointAt()方法
俩个字符的异体文字,暂时用?代替,文档显示不出来,上面土,下面口 这个异体文字
let text = '𠮷';
console.log(text.length);
console.log(text.charAt(0));
console.log(text.charCodeAt(0));
console.log(text.charCodeAt(1));
console.log(text.codePointAt(0));
对于超过俩个字符的码点,可以通过ES6新增的String.fromCodePoint()获得
console.log(String.fromCodePoint(134071));//𠮷
es6提供normalize()方法用于有音标的符号组合形式进行统一:
console.log('\u01D1');
console.log('\u004F');用处不大了解下
console.log('\u030C');
console.log('\u004F\u030C' == '\u01D1'.normalize());
 
es6提供了三种判断字符串的方法:includes()、startsWith()和endsWith();(常用)
let text = 'Hello Mr.lee!';
console.log(text.includes('Mr.'));//查找 true ,是可以查找到'Mr.'
console.log(text.startsWith('Hell'));//ture,必须从头开始找
console.log(text.includes('ee!'));//true,必须从结尾查找
console.log(text.includes('Mr.',7));//false,超过位置,第二参数寻找的位置
 
repat()重复字符串padStart()补全字符串头部padEnd()补全字符串尾部
console.log('x'.repeat(5));//重复字符串
console.log('x'.padStart(5,'Mr'));//补全字符串头部
console.log('x'.padEnd(5,'Mr'));//补全字符串尾部
 
现在可以直接使用(`)反引号配合${var}模版语法格式,直接实现变量解析功能;
如果我们想在字符串中插入表达式,也可以使用${a + b}模版语法;
${$0}这种模版嵌套的方式,也是支持的:
可以使用String.raw来得到原生字符串;
let name='Mr.lee',
    age=100,
    flag=true,
    // text='我是'+'是'+name+',今年'+age+'岁';以前写法
    //text=`我是$(name),今年$(age)岁,一加一等于:${1+1}`;//模板字符串,换行不需要转移符号
    // text=`结果:${flag ? `true${1+1}` : 'false'}`;
    text=String.raw`我\n是`;


    console.log(text);
 
 
es6提供了u修饰符对占俩个字符特殊字进行正则识别
let result=/吉{2}/.test('吉吉');
let result = /𠮷{2}/u.test('𠮷𠮷');用u修饰符可以解决这个问题
console.log(result);
 
ES6提供了y修饰符它的作用是当匹配过一次后继续往下匹配;
对于y修饰符ES6提供了stikcy属性用来检测是否存在y修饰符;
ES6提供了flags属性,用于返回正则使用的修饰符名称:
let text='xxx_xx_xxx',
    patt= /x+_/y;
console.log(patt.exec(text));
console.log(patt.exec(text));
console.log(patt.sticky); 对于y修饰符ES6提供了stikcy属性用来检测是否存在y修饰符;
console.log(patt.flags); ES6提供了flags属性,用于返回正则使用的修饰符名称:
.表示匹配所有除了终止符比如回车\n 换行\n等等使用s修饰符匹配;
let text='x\nyz',
    patt= /x.+yz/s;//加s

    console.log(patt.exec(text));
es6支持修饰符替换之前会直接报错
let regex=new RegExp(/xyz/iu,g);//后面的g会把前面代替掉
console.log(regex.flags);
posted on 2021-11-26 20:14  猫幻  阅读(56)  评论(0编辑  收藏  举报