前端进阶之旅前端进阶之旅
基础篇
进阶篇
高频篇
精选篇
手写篇
原理篇
面经篇
自检篇
每日一题
  • 综合
    • 综合题型
    • 其他问题
    • 设计模式
    • 思维导图
    • 学习路线
  • 前端基础
    • HTTP
    • 浏览器
    • 计算机基础
  • 进阶学习
    • NPM工作流
    • Docker
    • Canvas
    • Node学习指南
    • 前端综合文章
  • 其他
    • Handbook
    • 职场话题
    • CSS可视化
小程序题库
公众号动态
博客动态
开发者导航
基础篇
进阶篇
高频篇
精选篇
手写篇
原理篇
面经篇
自检篇
每日一题
  • 综合
    • 综合题型
    • 其他问题
    • 设计模式
    • 思维导图
    • 学习路线
  • 前端基础
    • HTTP
    • 浏览器
    • 计算机基础
  • 进阶学习
    • NPM工作流
    • Docker
    • Canvas
    • Node学习指南
    • 前端综合文章
  • 其他
    • Handbook
    • 职场话题
    • CSS可视化
小程序题库
公众号动态
博客动态
开发者导航
  • JavaScript Part 1

    • Ajax总结篇
    • Canvas 绘制八大行星
    • Canvas 绘制动画时钟
    • Canvas 绘制粒子动画背景
    • DOM编程之API学习总结篇
    • JS 中的 call、apply、bind 方法
    • JS 中的事件绑定、事件监听、事件委托
    • JS常用的内置函数整理
    • JS继承的几种方法总结
    • JS计算字符串所占字节数
    • JavaScript-DOM事件
    • JavaScript事件机制
    • JavaScript代码片段100个
    • JavaScript作用域分析总结
    • JavaScript原型链回顾
    • JavaScript原生数组及高阶函数
    • JavaScript及jQuery中的各种宽高属性图解
    • JavaScript启示录阅读笔录
    • JavaScript对象
    • JavaScript工程项目的一系列最佳实践
    • JavaScript常用API合集
    • JavaScript常用的代码片段
    • JavaScript数组、字符串、对象常用方法
    • JavaScript数组方法总结篇
    • JavaScript深浅拷贝
    • JavaScript继承的几种方式
    • JavaScript词法分析和作用域闭包
    • JavaScript运动框架之速度时间版本
    • JavaScript运行机制Event Loop
    • JavaScript防抖节流原理
    • Javascript中的复制粘贴功能
    • Javascript常用方法函数收集
    • Javascript数组详解
    • OOP之原型与原型链
    • OOP之类与对象
    • OOP之面向对象
    • Object.defineProperty详解
    • V8源码浅析JS数组常见方法
    • arguments详解
    • await 在 forEach 中不生效解决方案
    • iframe+表单跨域提交POST请求
    • javascript 下常用的字符串操作
    • javascript常用积累
    • javascript笔记总结篇
    • parsetInt parsetFloat与eval isNaN用法
    • 业务中处理数据结构常用的JS方法
    • 作用域
    • 你真的掌握变量和类型了吗
    • 前后端分离之数据Mock
    • 原型与原型链
    • 原生JS与jQuery操作DOM对比
    • 原生JS补给(上)
    • 如何写出一个惊艳面试官的深拷贝
    • 带你填一些JS容易出错的坑
    • 彻底弄懂 JavaScript 执行机制
    • 执行上下文 执行栈
    • 梳理常用的正则表达式
    • 正则回顾总结
    • 正则基础知识
    • 正则完整篇
      • 第一章 正则表达式字符匹配攻略
        • 1.1 两种模糊匹配
          • 1.1.1 横向模糊匹配
          • 1.1.2 纵向模糊匹配
        • 1.2 字符组
          • 1.2.1 范围表示法
          • 1.2.2 排除字符组
          • 1.2.3 常见的简写形式
        • 1.3 量词
          • 1.3.1 简写形式
          • 1.3.2 贪婪匹配和惰性匹配
        • 1.4 多选分支
        • 1.5 案例分析
          • 1.5.1 匹配16进制颜色值
          • 1.5.2 匹配时间
          • 1.5.3 匹配日期
          • 1.5.4 window操作系统文件路径
          • 1.5.5 匹配id
      • 第二章 正则表达式位置匹配攻略
        • 2.1 什么是位置
        • 2.2 如何匹配位置
          • 2.2.1 $和^
          • 2.2.2 \b和\B
          • 2.2.3 (?=p)和(?!p)
        • 2.3 位置的特性
        • 2.4 相关案例
          • 2.4.1 不匹配任何东西的正则
          • 2.4.2 数字的千位分隔符表示法
          • 2.4.3 验证密码问题
      • 第三章 正则表达式括号的作用
        • 3.1 分组和分支结构
          • 3.1.1 分组
          • 3.1.2 分支结构
        • 3.2 引用分组
        • 3.3 反向引用
        • 3.4 非捕获分组
        • 3.5 相关案例
          • 3.5.1 字符串trim方法模拟
          • 3.5.2 将每个单词的首字母转换为大写
          • 3.5.3 驼峰化
          • 3.5.4 中划线化
          • 3.5.5 html转义和反转义
          • 3.5.6 匹配成对标签
      • 第4章 正则表达式回溯法原理
        • 4.1 没有回溯的匹配
        • 4.2 有回溯的匹配
        • 4.3 常见的回溯形式
      • 第5章 正则表达式的拆分
        • 5.1 结构和操作符
        • 5.2 注意要点
        • 5.3 案例分析
      • 第六章 正则表达式编程
        • 6.1 正则表达式的四种操作
          • 6.1.1 验证
          • 6.1.2 切分
          • 6.1.3 提取
          • 6.1.4 替换
        • 6.2 相关API注意要点
    • 正则表达式
    • 浅析JSON stringify
    • 浅析Promise原理
    • 浅谈JavaScript中的异步处理
    • 浅谈闭包
    • 深拷贝 vs 浅拷贝
    • 编写可维护的JavaScript
    • 聊一聊typeof instanceof 实现原理.
    • 聊一聊闭包
    • 高阶函数map reduce filter
  • JavaScript Part 2

  • CSS

  • HTML

  • Jquery

  • ES6

  • 小程序

  • Vue

  • React

  • 深入React

  • React Native

  • NodeJS

  • Angular

  • TypeScript

  • Webpack

  • 浏览器

  • 移动端

  • 前端工程化

  • Electron

  • HTTP

  • Nginx

  • Linux

  • 数据结构与算法

  • LeetCode算法题

  • 综合

完整面试题地址:
作者:程序员poetry
扫码关注作者公众号:「前端进阶之旅」 每天分享技术干货
前端进阶之旅公众号二维码

正则表达式是匹配模式,要么匹配字符,要么匹配位置。请记住这句话

# 第一章 正则表达式字符匹配攻略

# 1.1 两种模糊匹配

如果正则只有精确匹配是没多大意义的,比如/hello/,也只能匹配字符串中的"hello"这个子串

var regex = /hello/;
console.log( regex.test("hello") ); 
// => true
@前端进阶之旅: 代码已经复制到剪贴板
  • 正则表达式之所以强大,是因为其能实现模糊匹配
  • 而模糊匹配,有两个方向上的“模糊”:横向模糊和纵向模糊

# 1.1.1 横向模糊匹配

  • 横向模糊指的是,一个正则可匹配的字符串的长度不是固定的,可以是多种情况的
  • 其实现的方式是使用量词。譬如{m,n},表示连续出现最少m次,最多n次

比如/ab{2,5}c/表示匹配这样一个字符串:第一个字符是“a”,接下来是2到5个字符“b”,最后是字符“c”。测试如下

var regex = /ab{2,5}c/g;
var string = "abc abbc abbbc abbbbc abbbbbc abbbbbbc";
console.log( string.match(regex) ); 
// => ["abbc", "abbbc", "abbbbc", "abbbbbc"]
@前端进阶之旅: 代码已经复制到剪贴板

# 1.1.2 纵向模糊匹配

纵向模糊指的是,一个正则匹配的字符串,具体到某一位字符时,它可以不是某个确定的字符,可以有多种可能

  • 其实现的方式是使用字符组。譬如[abc],表示该字符是可以字符“a”、“b”、“c”中的任何一个
var regex = /a[123]b/g;
var string = "a0b a1b a2b a3b a4b";
console.log( string.match(regex) ); 
// => ["a1b", "a2b", "a3b"]
@前端进阶之旅: 代码已经复制到剪贴板

只要掌握横向和纵向模糊匹配,就能解决很大部分正则匹配问题

# 1.2 字符组

需要强调的是,虽叫字符组(字符类),但只是其中一个字符。例如[abc],表示匹配一个字符,它可以是“a”、“b”、“c”之一

# 1.2.1 范围表示法

如果字符组里的字符特别多的话,怎么办?可以使用范围表示法

  • 如果字符组里的字符特别多的话,怎么办?可以使用范围表示法
  • 比如[123456abcdefGHIJKLM],可以写成[1-6a-fG-M]。用连字符-来省略和简写
  • 因为连字符有特殊用途,那么要匹配“a”、“-”、“z”这三者中任意一个字
fe
基础篇
进阶篇
高频篇
精选篇
手写篇
原理篇
面经篇
自检篇
每日一题
  • 综合
    • 综合题型
    • 其他问题
    • 设计模式
    • 思维导图
    • 学习路线
  • 前端基础
    • HTTP
    • 浏览器
    • 计算机基础
  • 进阶学习
    • NPM工作流
    • Docker
    • Canvas
    • Node学习指南
    • 前端综合文章
  • 其他
    • Handbook
    • 职场话题
    • CSS可视化
小程序题库
公众号动态
博客动态
开发者导航
  • JavaScript Part 1

    • Ajax总结篇
    • Canvas 绘制八大行星
    • Canvas 绘制动画时钟
    • Canvas 绘制粒子动画背景
    • DOM编程之API学习总结篇
    • JS 中的 call、apply、bind 方法
    • JS 中的事件绑定、事件监听、事件委托
    • JS常用的内置函数整理
    • JS继承的几种方法总结
    • JS计算字符串所占字节数
    • JavaScript-DOM事件
    • JavaScript事件机制
    • JavaScript代码片段100个
    • JavaScript作用域分析总结
    • JavaScript原型链回顾
    • JavaScript原生数组及高阶函数
    • JavaScript及jQuery中的各种宽高属性图解
    • JavaScript启示录阅读笔录
    • JavaScript对象
    • JavaScript工程项目的一系列最佳实践
    • JavaScript常用API合集
    • JavaScript常用的代码片段
    • JavaScript数组、字符串、对象常用方法
    • JavaScript数组方法总结篇
    • JavaScript深浅拷贝
    • JavaScript继承的几种方式
    • JavaScript词法分析和作用域闭包
    • JavaScript运动框架之速度时间版本
    • JavaScript运行机制Event Loop
    • JavaScript防抖节流原理
    • Javascript中的复制粘贴功能
    • Javascript常用方法函数收集
    • Javascript数组详解
    • OOP之原型与原型链
    • OOP之类与对象
    • OOP之面向对象
    • Object.defineProperty详解
    • V8源码浅析JS数组常见方法
    • arguments详解
    • await 在 forEach 中不生效解决方案
    • iframe+表单跨域提交POST请求
    • javascript 下常用的字符串操作
    • javascript常用积累
    • javascript笔记总结篇
    • parsetInt parsetFloat与eval isNaN用法
    • 业务中处理数据结构常用的JS方法
    • 作用域
    • 你真的掌握变量和类型了吗
    • 前后端分离之数据Mock
    • 原型与原型链
    • 原生JS与jQuery操作DOM对比
    • 原生JS补给(上)
    • 如何写出一个惊艳面试官的深拷贝
    • 带你填一些JS容易出错的坑
    • 彻底弄懂 JavaScript 执行机制
    • 执行上下文 执行栈
    • 梳理常用的正则表达式
    • 正则回顾总结
    • 正则基础知识
    • 正则完整篇
      • 第一章 正则表达式字符匹配攻略
        • 1.1 两种模糊匹配
          • 1.1.1 横向模糊匹配
          • 1.1.2 纵向模糊匹配
        • 1.2 字符组
          • 1.2.1 范围表示法
          • 1.2.2 排除字符组
          • 1.2.3 常见的简写形式
        • 1.3 量词
          • 1.3.1 简写形式
          • 1.3.2 贪婪匹配和惰性匹配
        • 1.4 多选分支
        • 1.5 案例分析
          • 1.5.1 匹配16进制颜色值
          • 1.5.2 匹配时间
          • 1.5.3 匹配日期
          • 1.5.4 window操作系统文件路径
          • 1.5.5 匹配id
      • 第二章 正则表达式位置匹配攻略
        • 2.1 什么是位置
        • 2.2 如何匹配位置
          • 2.2.1 $和^
          • 2.2.2 \b和\B
          • 2.2.3 (?=p)和(?!p)
        • 2.3 位置的特性
        • 2.4 相关案例
          • 2.4.1 不匹配任何东西的正则
          • 2.4.2 数字的千位分隔符表示法
          • 2.4.3 验证密码问题
      • 第三章 正则表达式括号的作用
        • 3.1 分组和分支结构
          • 3.1.1 分组
          • 3.1.2 分支结构
        • 3.2 引用分组
        • 3.3 反向引用
        • 3.4 非捕获分组
        • 3.5 相关案例
          • 3.5.1 字符串trim方法模拟
          • 3.5.2 将每个单词的首字母转换为大写
          • 3.5.3 驼峰化
          • 3.5.4 中划线化
          • 3.5.5 html转义和反转义
          • 3.5.6 匹配成对标签
      • 第4章 正则表达式回溯法原理
        • 4.1 没有回溯的匹配
        • 4.2 有回溯的匹配
        • 4.3 常见的回溯形式
      • 第5章 正则表达式的拆分
        • 5.1 结构和操作符
        • 5.2 注意要点
        • 5.3 案例分析
      • 第六章 正则表达式编程
        • 6.1 正则表达式的四种操作
          • 6.1.1 验证
          • 6.1.2 切分
          • 6.1.3 提取
          • 6.1.4 替换
        • 6.2 相关API注意要点
    • 正则表达式
    • 浅析JSON stringify
    • 浅析Promise原理
    • 浅谈JavaScript中的异步处理
    • 浅谈闭包
    • 深拷贝 vs 浅拷贝
    • 编写可维护的JavaScript
    • 聊一聊typeof instanceof 实现原理.
    • 聊一聊闭包
    • 高阶函数map reduce filter
  • JavaScript Part 2

  • CSS

  • HTML

  • Jquery

  • ES6

  • 小程序

  • Vue

  • React

  • 深入React

  • React Native

  • NodeJS

  • Angular

  • TypeScript

  • Webpack

  • 浏览器

  • 移动端

  • 前端工程化

  • Electron

  • HTTP

  • Nginx

  • Linux

  • 数据结构与算法

  • LeetCode算法题

  • 综合