什么是正则?
    正则表达式(regular expression)是一个描述字符规则的对象。可以用来检查一个字符串是否含有某个字符,将匹配的字符做替换或者从某个字符串中取出某个条件的子串等。
    
    正则表达式:
    正则表达式其实就是一种规则,其实把正则称作规则表达式更为恰当。正则的语法基于一种古老的perl语言。

为什么使用正则表达式?

我们学习正则表达式的原因非常简单,目的就是能够帮助我们快速的匹配字符串。

我们可以通过下面的代码来简单的体会一下:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>使用正则表达式的理由</title>
</head>
<body> </body>
<script>
// 例如我们现在有这样一个需求,将一个字符串当中的数字拿出
var str = "12 ,90,abc,admin-root30369,....."; // 创建一个空的数组
var arr = [];
var tmp = ''; // 开启循环处理数据
for(var i=0;i<str.length;i++){
// 判断字符串中的内容是否为数字
if(str.charAt(i) >= '0' && str.charAt(i) <= '9'){
tmp += str.charAt(i);
}else{
if(tmp){
arr.push(tmp);
tmp = '';
}
}
} // 打印
console.log(arr);
</script>
</html>

在看看正则的方式:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>通过正则取出字符串当中的数字</title>
</head>
<body> </body>
<script> var str = "12 ,90,abc,admin-root30369,.....";
var n = /\d+/g;
console.log(str.match(n)); </script>
</html>

emmmmmmmmmmmmmmmm,所以你说用谁嘛

如何创建一个正则表达式

<script>
// 定义一个正则表达式的三种方式:
var re1 = /abc/; // 定义正则最简单的方式,通过直接量的形式直接创建. 两个斜杠当中就是正则的内容. var re2 = new RegExp(/abc/); // 定义正则的第二种形式,也可以变化成下面的写法
var re2_two = new RegExp("abc"); // 等同于上面的写法 var re3 = RegExp("hello"); // 使用的是转换函数创建的正则 </script>

在上面的代码中,我们通过三种形式分别创建了正则表达式,无论是从哪个方面来说,都推荐使用第一种写法。

字符串.replace(oldstr, newstr)函数 和 字符串.match(正则)函数

    字符串的replace函数的功能:将老字符串替换成新字符串
 
    可以利用此函数,将老字符串表示成正则表达式,对字符串进行替换
 
    如:字符串中的abc替换成“哈哈”,如果正则后面没有g,则只替换一个,如果没有i,则大写不会替换
    var str = “abc123abc456abbcdABCefaacbcdbcabc";
    var reg = /abc/g;
    console.log(str.replace(reg,"哈哈"));
 
 
    字符串match函数的功能:提取所有的想要的东西
    返回一个数组,包含所有符合条件的字符
 
 
    \d    匹配所有的数字
 
    var reg = /\d/g;
    console.log(str.match(reg))    //打印字符串中所有的数字
 
    +     若干,量词,表示多少个都可以,至少1个,无上限
 
    var reg = /\d+/g;
    console.log(str.match(reg))    //打印字符串中所有的数字,连续
 
    |     或,类似于js中的 ||
    var reg = /abc|bbc|cbc|dbc/g
    console.log(str.match(reg));   //打印字符串中的abc,bbc,cbc,dbc
    var reg = /[a-c]bc/g
 
    [ ]    中元符
    var reg = /[a-z]/              //匹配所有字母
    [0-9] == \d
 
    ^     排除(除了)
    var reg = /[^0-9]/             //表示除了数字之外所有
 
    .   代表所有,不建议使用
    var reg = /<.+>/g
    console.log(str.replace(reg,""))              //过滤,表示尖括号里面的东西不要,但是?
    正则的贪婪定律:
    var reg = /<[^<>]+>/g
    console.log(str.replace(reg,"”))              //表示尖括号里面的东西不要,真
 
    转义字符:
    \d    ——    [0-9]         数字
    \w    ——    [a-z0-9_]     数字,字母,下划线
    \s    ——    空白字符(空格)   
 
    \D    ——    [^0-9]        非数字
    \W    ——    [^a-z0-9_]    非数字,字母,下划线
    \S    ——    非空白字符
 
    量词:限定符,可以指定正则表达式的一个给定组,必须要出现多少次才能满足匹配
    *     匹配前面的子表达式零次或多次
    +     匹配前面的子表达式至少一次或多次
    ?     匹配前面的子表达是零次或一次
    {n}   匹配确定n次
    {n,}  至少匹配n次
    {n,m} 至少匹配n次,最多匹配m次

正则的方法

正则.test(字符串)方法,返回值是true和false

正则.test(字符串)有一个特性,就是只要字符串的一部分符合要求,那么就会返回true

解决方法:
^开始
$结束
    // 使用正则:
// 通过方法使用
// 正则自身的:
// reg.test(str); 验证
// reg.exec(str); 查找
// 字符的方法:
// str.match(reg); 查找
// str.replace(reg,newStr); 替换
// str.search(reg) 查找
exec()找到了返回数组,找不到反回null
 test的特性:验证,局部验证,只要验证的字符的某一部分符合正则,都是true
    // qq号:腾讯
// var str = "704206198";
// var reg = /^[1-9]\d{5,11}$/;
// console.log(reg.test(str)); // 邮政编码
// var str = "152100";
// var reg = /^\d{6}$/;
// console.log(reg.test(str)); // 固定电话
// var str = "0504-59271632-123";
// var str = "0504-59271632";
// var str = "59721632";
// var str = "59721632-123";
// var reg = /^(0\d{2,3}-)?[1-9]\d{6,7}(-\d{1,4})?$/;
// console.log(reg.test(str)); // 复杂邮箱
// var str = "asd34_d@1000phone.com.cn";
// var reg = /^\w{1,10}@[0-9a-z]{2,10}(\.[a-z]{2,3}){1,2}$/;
// console.log(reg.test(str)); // URL
// var str = "https://baidu.com";
// var str = "http://www.baidu.com";
// var str = "www.baidu.com";
// var str = "mp3.baidu.com";
// var str = "baidu.com.cn";
// var reg = /^(https?:\/\/)?([0-9a-z]{1,10}\.)?[0-9a-z]{2,10}(\.[a-z]{2,3}){1,2}$/;
// console.log(reg.test(str));
正则表达式手册

常规检测方式:

1.中文检测
unicode编码中文监测:/^[\u2E80-\u9FFF]+$/ 2.用户名检测
正则:/^[a-z0-9_-]{3,16}$/ 3.邮箱检测
/^([a-z0-9_\.-]+)@([\da-z\.-]+)\.([a-z\.]{2,6})$/
可以多次出现 (字母数字下划线.-)@可以出现多个(数字字母.-).2到6位字母或.
/^[a-z\d]+(\.[a-z\d]+)*@([\da-z](-[\da-z])?)+(\.{1,2}[a-z]+)+$/
可以有多个(字母数字)可有多个可无(.多个(字母数字))@可以多个(数字字母可 有1次可无(-数字字母))可以有多个(1或2个.多个字母) abc123@123abc.com 4.URL检测
/^(https?:\/\/)?([\da-z\.-]+)\.([a-z\.]{2,6})([\/\w\.-]*)*\/?$/
有1次或0次(http有1次或0次s : //) 可以多个(数字字母.-) . 2到6位(字母.) 可多个或0个 (可以多个或0个 /数字字母下划线.-) 可0或1次/ http://sh.op-ta.l.baidu.com 5.HTML标签检测
/^<([a-z]+)([^<]+)*(?:>(.*)<\/\1>|\s+\/>)$/
<多个(字母)可多个或0个(除了<的所有字符) />
<多个(字母)可多个或0个(除了<的所有字符)>多个任意字符 </重复第一部分的多个字母> 自定义的html标签
/<[^<>]+>/g

JavaScript基础10——正则的更多相关文章

  1. JavaScript基础10——node对象

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  2. JavaScript基础入门10

    目录 JavaScript 基础入门10 正则表达式 为什么使用正则表达式? 正则表达式的应用场景 如何创建一个正则表达式 基础语法 具有特殊意义的转义字符 量词 字符类 贪婪模式 练习 邮箱验证 中 ...

  3. javascript基础修炼(10)——VirtualDOM和基本DFS

    1. Virtual-DOM是什么 Virtual-DOM,即虚拟DOM树.浏览器在解析文件时,会将html文档转换为document对象,在浏览器环境中运行的脚本文件都可以获取到它,通过操作docu ...

  4. Web前端基础(10):JavaScript(四)

    1. 伪数组arguments arguments代表的是实参.有个讲究的地方是:arguments只在函数中使用. 1.1 返回参数个数 返回函数实参的个数:arguments.length 例子: ...

  5. JavaScript基础

    JavaScript基础 JavaScript是一门编程语言,浏览器内置了JavaScript语言的解释器,所以在浏览器上按照JavaScript语言的规则编写相应代码之,浏览器可以解释并做出相应的处 ...

  6. 前端之JavaScript基础

    前端之JavaScript基础 本节内容 JS概述 JS基础语法 JS循环控制 ECMA对象 BOM对象 DOM对象 1. JS概述 1.1. javascript历史 1992年Nombas开发出C ...

  7. 一步步学习javascript基础篇(3):Object、Function等引用类型

    我们在<一步步学习javascript基础篇(1):基本概念>中简单的介绍了五种基本数据类型Undefined.Null.Boolean.Number和String.今天我们主要介绍下复杂 ...

  8. 第三篇:web之前端之JavaScript基础

    前端之JavaScript基础   前端之JavaScript基础 本节内容 JS概述 JS基础语法 JS循环控制 ECMA对象 BOM对象 DOM对象 1. JS概述 1.1. javascript ...

  9. JavaScript基础视频教程总结(081-090章)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...

随机推荐

  1. 报错 xxx@1.0.0 dev D:\> webpack-dev-server --inline --progress --configbuild/webpack.dev.conf.js

    是因为node_modules有意外改动,导致依赖库不完整. 解决:1.删除项目下的node_modules,在你的项目目录下 重新执行npm install,这会重新生成node_modules, ...

  2. Java学习:线程实现方式

    线程实现方式 并发与并行 并发:指两或多个事件在同一个时间段内发生 并行:指两或多个事件在同一个时刻发生(同时发生) 进程的概念 内存:所有的应用程序都需要进入到内存中执行 临时存储RAM 硬盘:永久 ...

  3. Linux命令注释—HDFS运维

    HDFS运维—命令注释 1 实验背景 HDFS是大数据其他组件的基础,Hive的数据存储在HDFS中,Mapreduce.Spark 等计算数据也存储在HDFS 中,HBase 的 region 也是 ...

  4. Replication:事务复制 Subscriber的主键列是只读的

    在使用Transactional Replication时,Subscriber 被认为是“Read-Only”的 , All data at the Subscriber is “read-only ...

  5. 带着canvas去流浪系列之八 碰撞【华为云技术分享】

    [摘要] canvas动画-碰撞仿真 示例代码托管在:http://www.github.com/dashnowords/blogs 经过前面章节相对枯燥的练习,相信你已经能够上手canvas的原生A ...

  6. (Manjaro)VirtualBox异常修复:RTR3InitEx failed with rc=-1912 (rc=-1912)

    引言 VirtualBox运行异常好几天,其中尝试一些操作都没有解决. 版本说明 系统版本:4.19.88-1-MANJARO Vbox镜像:kali-linux-2019.4-vbox-amd64. ...

  7. Docker安装Consul集群

    Docker 安装Consul集群 使用windows 环境,Docker desktop community 构建consul集群. 1.docker 容器网络 docker安装后,默认会创建三种网 ...

  8. docker学习之路-build asp.net core 2.2产生 warning MSB3245: Could not resolve this reference.错误的解决办法

    在docker build的时候有时我们可以直接使用dotnet publish来发布,但是如果用docker构建镜像的时候却会出现下面的错误: 解决办法:https://stackoverflow. ...

  9. linuxmint安装Tools找不到Tools的压缩包问题

    安装Linuxmint之后按照惯例安装Tools,打开桌面上的Tools光盘之后找不到压缩包. PS:因为已经装好了,就不上图了,按照下面的步骤做就没有问题了. 1:找到vmware的安装目录下的li ...

  10. 常用的本地存储-----cookie篇

    1.引言 随着浏览器的处理能力不断增强,越来越多的网站开始考虑将数据存储在「客户端」,那么久不得不谈本地存储了. 本地存储的好处: 一是避免取回数据前页面一片空白,如果不需要最新数据也可以减少向服务器 ...