JS高级 - 正则表达式

本文详细介绍了正则表达式的基础知识,包括其用于字符串匹配、提取和替换的功能。重点讲解了元字符、限定符、其他符号的使用,并展示了如何创建正则对象及进行匹配操作。同时,提到了JavaScript中的正则表达式方法如test()和match()。此外,还探讨了HTML5的web存储(localStorage和sessionStorage)以及函数的防抖和节流概念。
摘要由CSDN通过智能技术生成

正则表达式的定义

正则表通常被用来检索、替换那些符合某个模式(规则)的文本

正则表达式的作用

给定的字符串是否符合正则表达式的过滤逻辑(匹配)

可以通过正则表达式,从字符串中获取我们想要的特定部分(提取)

强大的字符串替换能力(替换)

正则表达式的特点

灵活性、逻辑性和功能性非常的强

可以迅速地用极简单的方式达到字符串的复杂控制

常用元字符

元字符

说明

\d

匹配至少有一个数字

\D

匹配至少任意一个非数字的字符

\w

匹配至少一个字母或数字或下划线

\W

匹配至少有一个不是字母,数字,下划线

\s

匹配至少任意的空白符

\S

匹配至少一个不是空白符的字符

.

匹配至少有一个非换行符

^

表示匹配行首的文本(以谁开始) ^\d

$

表示匹配行尾的文本(以谁结束)\d$

限定符

限定符

说明

*

重复零次或更多次\d*  /^ab*$/:表示一个字符串有一个a后面跟着零个或若干个b。("a", "ab", "abbb",……);

+

重复一次或更多次\d+     / ab+/:表示一个字符串有一个a后面跟着至少一个b或者更多;

?

重复零次或一次    /^ab?$/:表示一个字符串有一个a后面跟着零个或者一个b;

{n}

至少重复n次

{n,}

重复n次或更多次

{n,m}

重复n到m次

其他符号

[] 字符串用中括号括起来,表示匹配其中的任一字符,相当于或的意思 [0-9]

[^]  匹配除中括号以内的内容

\ 转义符: \的用法 \ 主要是用法是在正则表达式中的特殊符号转换为它本身的意思

| 或者,选择两者中的一个。注意|将左右两边分为两部分,而不管左右两边有多长多乱

() 从两个直接量中选择一个,分组

eg:gr(a|e)y匹配gray和grey

[\u4e00-\u9fa5]  匹配汉字

创建正则对象

(1)、字面量创建

  var reg1 = /\d/;

(2)、构造函数创建

 var regObj1 = new RegExp(/\w/);

正则匹配

RegExp.prototype.test()

语法:regexObj.test(str)

参数:str 用来与正则表达式匹配的字符串

返回值:如果正则表达式与指定的字符串匹配 ,返回true;否则false。

正则提取

String.prototype.match()

语法:str.match(regexp)

参数:regexp

参数

标志

说明

i

忽略大小写

g

全局匹配

gi

全局匹配+忽略大小写

.正则替换

String.prototype.replace()

replace() 方法返回一个由替换值(replacement)替换一些或所有匹配的模式(pattern)后的新字符串。模式可以是一个字符串或者一个,替换值可以是一个字符串或者一个每次匹配都要调用的回调函数。

原字符串不会改变。

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

参数:regexp (pattern)

HTML5的web存储

localStorage 对象

保存数据:localStorage.setItem(key,value);

读取数据:localStorage.getItem(key);

删除单个数据:localStorage.removeItem(key);

删除所有数据:localStorage.clear();

得到某个索引的key:localStorage.key(index);

sessionStorage 对象

sessionStorage 方法针对一个 session 进行数据存储。当用户关闭浏览器窗口后,数据会被删除。

函数的防抖(debounce)与节流(throttle)

函数防抖(debounce)

短时间内多次触发同一事件,只执行最后一次,或者只执行最开始的一次,中间的不执行。


// 非立即执行版
function debounce(func, wait) {
    let timer;
    return function() {
  let context = this; // 注意 this 指向
      let args = arguments; // arguments中存着e
         
      if (timer) clearTimeout(timer);
 
      timer = setTimeout(() => {
        func.apply(this, args)
      }, wait)
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值