Wang's blog Wang's blog
首页
  • 前端文章

    • HTML教程
    • CSS
    • JavaScript
  • 前端框架

    • Vue
    • React
    • VuePress
    • Electron
  • 后端技术

    • Npm
    • Node
    • TypeScript
  • 编程规范

    • 规范
  • 我的笔记
  • Git
  • GitHub
  • VSCode
  • Mac工具
  • 数据库
  • Google
  • 服务器
  • Python爬虫
  • 前端教程
更多
收藏
关于
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

Wang Mings

跟随大神,成为大神!
首页
  • 前端文章

    • HTML教程
    • CSS
    • JavaScript
  • 前端框架

    • Vue
    • React
    • VuePress
    • Electron
  • 后端技术

    • Npm
    • Node
    • TypeScript
  • 编程规范

    • 规范
  • 我的笔记
  • Git
  • GitHub
  • VSCode
  • Mac工具
  • 数据库
  • Google
  • 服务器
  • Python爬虫
  • 前端教程
更多
收藏
关于
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • CSS

  • Npm

  • Vue

  • HTML

  • Node

  • Yaml

  • React

  • 框架

  • 规范

  • Electron

  • JS演示

  • VuePress

  • JavaScript

    • DOM
    • 事件
    • 实用API
    • 作用域
    • 基础篇
    • 定时器
    • 内存管理
    • 异步操作
    • 日期处理
    • 点击约束
    • 防抖节流
    • this的学习
    • ES面向对象
    • JS事件详解
    • new命令原理
    • 内置对象篇
    • 函数柯里化
    • 正则表达式
      • 浏览器模型
      • 事件订阅发布
      • 获取页面高度
      • 面向对象编程
      • JS随机打乱数组
      • js各种开发技巧
      • 函数的深入浅出
      • 防抖与节流函数
      • 模块化的使用总结
      • JS获取和修改url参数
      • JS设计模式总结笔记
      • fetch拦截和封装使用
      • 浏览器渲染原理流程
      • JavaScript对象从浅入深
      • JavaScript高级程序设计
      • Promise使用和实现方法
      • JS的种打断点调试方式
      • js深浅拷贝详解与实现
      • 九种跨域方式实现原理
      • 多种数组去重性能对比
      • 闭包原理以及使用场景
      • 判断是否为移动端浏览器
      • 比typeof运算符更准确的类型判断
      • 搞清事件循环、宏任务、微任务
      • 将一维数组按指定长度转为二维数组
    • TypeScript

    • 微信小程序

    • TypeScript-axios

    • 前端
    • JavaScript
    wangmings
    2022-07-19
    目录

    正则表达式

    # 正则表达式

    菜鸟教程 正则表达式 (opens new window) 在线正则验证 (opens new window)

    # 语法

    - [ABC]   	  匹配 [...] 中的所有字符
    - [^ABC]   	  匹配 除了[...] 中的所有字符
    - [0-9a-zA-Z] 匹配 0-9 a-z A-Z区间的字符
    - .           匹配除换行符(\n、\r)之外的任何单个字符,相等于 [^\n\r]。
    - [\s\S]      匹配所有。\s 是匹配所有空白符,包括换行,\S 非空白符,不包括换行。
    - \w          匹配字母、数字、下划线。等价于 [A-Za-z0-9_]
    - \W          匹配非字母、数字、下划线。等价于 '[^A-Za-z0-9_]'。
    - \d          匹配一个数字字符。等价于 [0-9]。
    - \D          匹配一个非数字字符。等价于 [^0-9]。
    - \num        匹配 num,其中 num 是一个正整数。对所获取的匹配的引用。例如,'(.)\1' 匹配两个连续的相同字符。
    

    # 修饰符

    - i    不区分大小写
    - g    全局匹配
    - m    多行匹配    使边界字符 ^ 和 $ 匹配每一行的开头和结尾,记住是多行,而不是整个字符串的开头和结尾。
    - s    特殊字符圆点 . 中包含换行符 \n   默认情况下的圆点 . 是 匹配除换行符 \n 之外的任何字符,加上 s 修饰符之后, . 中包含换行符 \n。
    

    # 非打印字符

    - \cx  匹配由x指明的控制字符。例如, \cM 匹配一个 Control-M 或回车符。x 的值必须为 A-Z 或 a-z 之一。否则,将 c 视为一个原义的 'c' 字符。
    - \f   匹配一个换页符。等价于 \x0c 和 \cL。
    - \n   匹配一个换行符。等价于 \x0a 和 \cJ。
    - \r   匹配一个回车符。等价于 \x0d 和 \cM
    - \t   匹配一个制表符。等价于 \x09 和 \cI。
    - \v   匹配一个垂直制表符。等价于 \x0b 和 \cK。
    - \s   匹配任何空白字符,包括空格、制表符、换页符等等。等价于 [ \f\n\r\t\v]。注意 Unicode 正则表达式会匹配全角空格符。
    - \S   匹配任何非空白字符。等价于 [^ \f\n\r\t\v]。
    

    # 特殊字符

    - ^    匹配输入字符串的开始位置,在方括号中使用时表示不接受方括号表达式中的字符集合
    - $    匹配输入字符串的结尾位置。如果设置了 RegExp 对象的 Multiline 属性,则 $ 也匹配 '\n' 或 '\r'。
    - ( )  标记一个子表达式的开始和结束位置。子表达式可以获取供以后使用。 在JScript 中则使用 $0…$9 属性。要匹配圆括号字符,请使用 '\(' 或 '\)'。
    - *    匹配前面的子表达式零次或多次
    - +    匹配前面的子表达式一次或多次
    - .    匹配除了换行符\n之外的任何单字符
    - ?    匹配前面的子表达零次或一次
    - \    将下一个字符标记为特殊字符
    - [    标记一个中括号表达式的开始
    - {    标记限定符表达式的开始
    - |    指明两项之间的一个选择
    

    # 限定符

    - *    匹配前面的子表达式零次或多次, 等价于{0,}
    - +    匹配前面的子表达式一次或多次,  等价于{1,}
    - ?    匹配前面的子表达式零次或一次,  等价于{0,1}
    - {n}  n是一个非负整数,匹配确定的n次
    - {n,m} n <=m , 最少匹配n次而且最多匹配m次,注意逗号和两个数直接不能有空格
    

    # 定位符

    - ^    匹配输入字符串开始的位置。如果设置了 RegExp 对象的 Multiline 属性,^ 还会与 \n 或 \r 之后的位置匹配。
    - $    匹配输入字符串结尾的位置。如果设置了 RegExp 对象的 Multiline 属性,$ 还会与 \n 或 \r 之前的位置匹配。
    - \b   匹配一个单词边界,即字与空格间的位置。
    - \B   非单词边界匹配。
    

    # 转义

    - 要匹配特殊字符,和限定符的话,要加转义符合 \  例如: \$   \\   \.
    

    # 选择

    - () 表示捕获分组,() 会把每个分组里的匹配的值保存起来, 多个匹配值可以通过数字 n 来查看(n 是一个数字,表示第 n 个捕获组的内容)。
    - |
    - 列出 ?=、?<=、?!、?<! 的使用区别
        - exp1(?=exp2)   查找 exp2 前面的 exp1。
        - (?<=exp2)exp1  查找 exp2 后面的 exp1。
        - exp1(?!exp2)   查找后面不是 exp2 的 exp1。
        - (?<!exp2)exp1  查找前面不是 exp2 的 exp1。
    

    # 方法

    • search() 方法可使用正则表达式或字符串作为参数。字符串参数会转换为正则表达式:
    var str = "Visit Runoob!"; 
    var n = str.search(/Runoob/i);
    var n = str.search("Runoob");
    
    1
    2
    3
    • test() 方法用于检测一个字符串是否匹配某个模式,如果字符串中含有匹配的文本,则返回 true,否则返回 false。
    var patt = /e/;
    patt.test("The best things in life are free!");
    
    /e/.test("The best things in life are free!")
    
    1
    2
    3
    4
    • match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。返回数组
    var str = "The rain in SPAIN stays mainly in the plain"; 
    var n = str.match(/ain/gi); // ['ain', 'AIN', 'ain', 'ain']
    
    str.match(/ain/) == 'ain'   // ture    这里其他拿到的是 ['ain']    经过 == 隐示转换, 把['ain'].toStrin() == 'ain'
    
    1
    2
    3
    4
    • String.prototype.replace() 替换

    语法: str.replace(regexp|substr, newSubStr|function)

    • function(match, p1, p2..., offset, string, NamedCaptureGroup)
      • match 匹配的子串。(对应于上述的$&。)
      • p1,p2, ... 假如replace()方法的第一个参数是一个RegExp 对象,则代表第n个括号匹配的字符串。(对应于上述的$1,$2等。)例如,如果是用 /(\a+)(\b+)/ 这个来匹配,p1 就是匹配的 \a+,p2 就是匹配的 \b+。
      • offset 匹配到的子字符串在原字符串中的偏移量。(比如,如果原字符串是 'abcd',匹配到的子字符串是 'bc',那么这个参数将会是 1)
      • string 被匹配的原字符串。
      • NamedCaptureGroup 命名捕获组匹配的对象

    # 如何用 vscode 在项目中将颜色值统一替换为变量?如 color: #F5F5F5; 替换为 color: $color-F5F5F5;

    - #([0-9a-fA-F]{3,6});
    - $color-$1;
    - .js,.gitignore,.md,.svg,var.scss
    

    # 面试题:用正则表达式书写一个获取URL参数的函数

    function getUrlParmas(name){
        const reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i")
        let result = window.location.search.substr(1).match(reg)
        if(result !== null){
            return unescape(result[2])
        }
        return null
    }
    window.location = 'http://www.baidu.com?name=yu&age=18'
    let name = getUrlParams('name')
    
    
    // 获取所有的url参数
    function paramesUrl(url){
        let pattern = /(\w+)=(\w+)/ig
        let parames = {}
        url.replace(pattern, function(a, b, c){
            parames[b] = c
        })
        return parames
    }
    
    let url = 'http://www.baidu.com?name=yu&age=18'
    let params = paramesUrl(url)
    console.log(params)
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25

    # 用正则实现千分位分隔符,如将 1234567 转为 1,234,567

    (\d)(?=(\d{3})+.)

    (?<!..*)(\d)(?=(?:\d{3})+(?:$|.))

    num.toString().replace(/(?<!\..*)(\d)(?=(?:\d{3})+($|\.))/g, '$1,')

    /**
     * 格式化数字,每隔三位添加逗号
     * @param {number} num 数值
     * @returns {string} 格式化后的数值字符串
     */
    export function parseNum(num) {
      try {
        return num.toString().replace(/(?<!\..*)(\d)(?=(?:\d{3})+($|\.))/g, '$1,')
      } catch (error) {
        const numberString = (num || 0).toString()
        // 在转换一些以万为单位的金额时,小数点位数会超过3位,小数点中的数字暂不解析
        const decimalPointIndex = numberString.indexOf('.')
        let intString = decimalPointIndex > -1 ? numberString.slice(0, decimalPointIndex) : numberString
        let decimalString = decimalPointIndex > -1 ? numberString.slice(decimalPointIndex) : ''
        return intString.replace(/(\d)(?=(?:\d{3})+($|\.))/g, "$1,") + decimalString
      }
    }
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17

    # 分析一下这个正则表达式:/^(?=.*[A-Za-z])(?=.*\d)[A-Za-z\d]{8,}$/

    编辑 (opens new window)
    函数柯里化
    浏览器模型

    ← 函数柯里化 浏览器模型→

    最近更新
    01
    theme-vdoing-blog博客静态编译问题
    09-16
    02
    搜索引擎
    07-19
    03
    友情链接
    07-19
    更多文章>
    Theme by Vdoing | Copyright © 2019-2022 Evan Xu | MIT License
    • 跟随系统
    • 浅色模式
    • 深色模式
    • 阅读模式