前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >正则表达式

正则表达式

作者头像
心谭博客
发布2020-04-20 17:08:04
4590
发布2020-04-20 17:08:04
举报
文章被收录于专栏:YuanXinYuanXin

内容一览 ?:

  • 正则常见函数
  • 实现千分位标注
  • 全局匹配与lastIndex
  • 字符串第一个出现一次的字符

正则常见函数

正则表达式常用的方法分为 2 类:

  1. 字符串上调用,进行正则规则匹配。操作对象是正则表达式
  2. 正则表达式上调用。操作对象是字符串。

准备了下面代码:

const pattern = /runoob/gi; // 正则表达式
const str = "Visit Runoob!runoob"; // 待匹配字符串

字符串上调用的方法,常见的有:search/ match / replace

// Return: Number 代表搜索到的开始地址
console.log(str.search(/Runoob/i));

// Return: Array 匹配出来的所有字符串
console.log(str.match(/run/gi));

// Return: 新的string对象
console.log(str.replace(/visit/i, "visit"));

正则表达式对象上的方法,常见的有:test / exec

// Return: Boolean 代表是否符合匹配
console.log(pattern.test(str));

// Return: 找到第一个匹配的值,返回一个数组,存放着匹配信息
console.log(pattern.exec(str));

实现千分位标注

题目:实现千分位标注位,考虑小数、负数和整数三种情况。

sep参数是自定义的分隔符,默认是,

/**
 * 实现千分位标注位
 * @param {*} str 待标注的字符串
 * @param {*} sep 标注符号
 */
const addSeparator = (str = "", sep = ",") => {
    str += "";
    const arr = str.split("."),
        re = /(\d+)(\d{3})/;

    let integer = arr[0],
        decimal = arr.length <= 1 ? "" : `.${arr[1]}`;

    while (re.test(integer)) {
        integer = integer.replace(re, "$1" + sep + "$2");
    }

    return integer + decimal;
};

console.log(addSeparator(-10000.23)); // -10,000.23
console.log(addSeparator(100)); // 100
console.log(addSeparator(1234, ";")); // 1;234

全局匹配与lastIndex

题目:请说出下面代码执行结果(为了方便,我将结果注释在代码中了),并且解释。

const str = "google";
const re = /o/g;
console.log(re.test(str)); // true
console.log(re.test(str)); // true
console.log(re.test(str)); // false

由于使用的是全局匹配,因此会多出来lastIndex这个属性,打印如下:

const str = "google";
const re = /o/g;

console.log(re.test(str), re.lastIndex); // true 2
console.log(re.test(str), re.lastIndex); // true 3
console.log(re.test(str), re.lastIndex); // false 0

简单理解就是:同一个全局匹配的正则对同一个目标串匹配后,匹配过的部分串将不再匹配。

字符串第一个出现一次的字符

题目:字符串中第一个出现一次的字符

利用字符串的match方法匹配指定字符:

const find_ch = str => {
    for (let ch of str) {
        const re = new RegExp(ch, "g");
        // 检查每个字符的匹配数量
        if (str.match(re).length === 1) {
            return ch;
        }
    }
};
// 输出答案是 l
console.log(find_ch("google"));

除了上述方法,使用indexOf/lastIndexOf同样可以:

const find_ch = str => {
    for (let ch of str) {
        if (str.indexOf(ch) === str.lastIndexOf(ch)) {
            return ch;
        }
    }
};
// 输出答案是 l
console.log(find_ch("google"));

扫码关注「心谭博客」, 专注前端与算法

目前已有前端面试、剑指Offer·JS、动画设计、Webpack等系列专题

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-03-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 正则常见函数
  • 实现千分位标注
  • 全局匹配与lastIndex
  • 字符串第一个出现一次的字符
    • 扫码关注「心谭博客」, 专注前端与算法
      • 目前已有前端面试、剑指Offer·JS、动画设计、Webpack等系列专题
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档