JavaScript基础10——正则
为什么使用正则表达式?
我们学习正则表达式的原因非常简单,目的就是能够帮助我们快速的匹配字符串。
我们可以通过下面的代码来简单的体会一下:
<!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(正则)函数
正则的方法
正则.test(字符串)方法,返回值是true和false
正则.test(字符串)有一个特性,就是只要字符串的一部分符合要求,那么就会返回true
// 使用正则:
// 通过方法使用
// 正则自身的:
// reg.test(str); 验证
// reg.exec(str); 查找
// 字符的方法:
// str.match(reg); 查找
// str.replace(reg,newStr); 替换
// str.search(reg) 查找
// 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——正则的更多相关文章
- JavaScript基础10——node对象
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- JavaScript基础入门10
目录 JavaScript 基础入门10 正则表达式 为什么使用正则表达式? 正则表达式的应用场景 如何创建一个正则表达式 基础语法 具有特殊意义的转义字符 量词 字符类 贪婪模式 练习 邮箱验证 中 ...
- javascript基础修炼(10)——VirtualDOM和基本DFS
1. Virtual-DOM是什么 Virtual-DOM,即虚拟DOM树.浏览器在解析文件时,会将html文档转换为document对象,在浏览器环境中运行的脚本文件都可以获取到它,通过操作docu ...
- Web前端基础(10):JavaScript(四)
1. 伪数组arguments arguments代表的是实参.有个讲究的地方是:arguments只在函数中使用. 1.1 返回参数个数 返回函数实参的个数:arguments.length 例子: ...
- JavaScript基础
JavaScript基础 JavaScript是一门编程语言,浏览器内置了JavaScript语言的解释器,所以在浏览器上按照JavaScript语言的规则编写相应代码之,浏览器可以解释并做出相应的处 ...
- 前端之JavaScript基础
前端之JavaScript基础 本节内容 JS概述 JS基础语法 JS循环控制 ECMA对象 BOM对象 DOM对象 1. JS概述 1.1. javascript历史 1992年Nombas开发出C ...
- 一步步学习javascript基础篇(3):Object、Function等引用类型
我们在<一步步学习javascript基础篇(1):基本概念>中简单的介绍了五种基本数据类型Undefined.Null.Boolean.Number和String.今天我们主要介绍下复杂 ...
- 第三篇:web之前端之JavaScript基础
前端之JavaScript基础 前端之JavaScript基础 本节内容 JS概述 JS基础语法 JS循环控制 ECMA对象 BOM对象 DOM对象 1. JS概述 1.1. javascript ...
- JavaScript基础视频教程总结(081-090章)
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...
随机推荐
- 关于mysql的null相关查询的一些坑
我们先看一下效果,然后在解释,示例如下: mysql> create table test5 (a int not null,b int,c varchar(10)); Query OK, 0 ...
- linux - 用户配置文件
用户配文件: 1用户信息文件 /etc/passwd 2 影子文件 /etc/shadow 3 组信息文件 /etc/group 4 组密码文件 /etc/gshadow 1 用户信息文件 / ...
- SQL系列(五)—— 排序(order by)
对查询结果进行排序是日常应用开发中最为常见的需求,在SQL中通过order by实现.order by是select语句中一部分,即子句. 1.order by 1.1 单列排序 其实,检索出的数据并 ...
- MySQL“慢SQL”定位
MySQL"慢SQL"定位 数据库调优我个人觉得必须要明白两件事 1.定位问题(你得知道问题出在哪里,要不然从哪里调优呢) 2.解决问题(这个没有基本的方法来处理,因为不同的问题处 ...
- Redis和数据库一致性
1.实时同步 对强一致要求比较高的,应采用实时同步方案,即查询缓存查询不到再从DB查询,保存到缓存: 更新缓存时,先更新数据库,再将缓存的设置过期(建议不要去更新缓存内容,直接设置缓存过期 ...
- c++打印实心菱形,空心三角形,十字星,空心正方形,实心平行四边形
今天翻资料的时候,无意间发现了一个文件,是刚接触编程的时候用c++写的一段程序,我称之为"图形打印机",想着把所有图形都打印出来,后来发现其实每种图形的代码都是一个思路,就不想做重 ...
- Big Data Hubris:"大数据傲慢"问题
大数据的傲慢与偏见— 读后心得 数据模型研究者必看的书 原文链接: https://medium.com/@iven00000000/%E5%A4%A7%E6%95%B8%E6%93%9A%E7%9A ...
- Eclipse集成Git做团队开发
在日常开发工作中,我们通常使用版本控制软件管理团队的源代码,常用的SVN.Git.与SVN相比,Git有分支的概念,可以从主分支创建开发分支,在开发分支测试没有问题之后,再合并到主分支上去,从而避免了 ...
- 剑指前端(前端入门笔记系列)——DOM(元素大小)
DOM——元素大小 DOM中没有规定如何确定页面中与元素的大小,IE率先映入了一些属性来确定页面中元素的大小,以便开发人员使用,目前,所有主要的浏览器都已经支持这些属性了. 1.偏移量(单位为 ...
- 剑指前端(前端入门笔记系列)——DOM(元素节点)
DOM(元素节点) 本文介绍了元素节点的基本操作:增删改查 增 新增一个元素节点分为两步(二者缺一不可),第一步:创建元素节点,第二步:将创建的元素节点插入到指定元素节点中(也就是插入指定元素节点 ...