<!DOCTYPE html>
<html>
<head>
<title>title</title>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no" name="viewport"> <script src="jquery.min.js"></script>
<script src="bootstrap.min.js"></script>
<script src="vue.min.js"></script>
</head> <body>
<div id="app">
<input type="text" v-model="x">
<input type="button" value="验证" @click="validate">
</div> <script> var vm = new Vue({
el: '#app',
data:{
x: '100000000'
},
methods: {
validate: function(){ }
}
}); //常用方法:
//reg.test(str);
//str.match(reg); 返回匹配完的结果字符串 //参考文档W3CSchool:http://www.w3school.com.cn/jsref/jsref_obj_regexp.asp
//原则:默认是贪婪匹配(匹配出的字串即最长匹配子串) var reg1 = /abc/; //查找模式串'abc' var reg2 = new RegExp("abc"); var reg3 = new RegExp(reg2); //创建Reg2的副本给Reg3 var reg4 = RegExp(reg2); //直接把reg4指向reg2,操作reg4等于直接操作reg2 var reg5 = /abc/i; //执行对大小写不敏感的匹配 var reg6 = /abc/g; //执行全局匹配,在查找到第一个后不会停止 var reg7 = /abc/m; //执行多行匹配,当待匹配字符串具有换行符\n时,能够进行多行匹配 var reg8 = /[0-9][0-9][0-9]/g; //匹配连续三位是任意数字的字串,查找到一个以后不会停止 var reg9 = /[0-9A-z][cd][d]/g; //匹配出的字串第一位是任意数字或字母,第二位是c或d,第三位是d,并为全局匹配 var reg10 = /[^a]/; //匹配第一个非a的字串 var reg11 = /[a|b]/; //匹配第一个a或b的字串 var reg12 = /(abc|bcd)[0-9]/; //匹配第一个abc+任意数字或bcd+任意数字 var reg13 = /\w/; // \w等价于:[0-9A-z_]
// \W等价于:^\w var reg14 = /\d/; // \d等价于:[0-9] var reg15 = /[\w\d]/; //可以在表达式写元字符!! // \s等价于:[\n\t\f\r\v ] 换行符+换页符+回车符+制表符+垂直制表符+空格 var reg16 = /\bc/; //表示C作为单词边界,且是单词头部 var reg17 = /\u597d/; //Unicode编码也能匹配汉字 \u597d:好 var reg18 = /\w{2,}/g; //匹配所有任意2个以上任意字符 var GoogleEmailValidate = /[\s\S]*@gmail.com/; //判断是否是谷歌邮箱的字符串 var reg19 = /(\w)\1\1\1/; // 小括号内是子表达式,而\1指引用第一个子表达式的内容(反向引用)
// 整个表达式意思是:字符串以xxxx(x为任意字符)的形式匹配
// Tip:子表达式匹配的内容会出现在结果数组中,可以当数组使,前提是不是全局匹配! // 关于split方法,如果含有子表达式,则结果数组中保留分割条件字符,否则分割条件字符不保留
// 关于replace方法,如果参数不是正则表达式,则替换不是全局替换,若是全局的正则表达式匹配,才会进行全局替换
// str.replace(new RegExp('/(\w)\1(\w)\2/'), "$2$2$1$1") $1$2是反向引用了前面表达式中的子表达式 // 将the-first-name变为驼峰命名theFirstName,原理是将'-f'替换为'F'
// var reg = /-(\w)/g;
/* str.replace(reg, function($, $1){
return $1.toUpperCase();
}) function是匹配一次执行一次,若是全局匹配,则会执行一到多次
*/ //正向断言:
var reg20 = /a(?=b)/g; //匹配任何出现在b之前的a,但不包括b //调整为非贪婪匹配
var reg21 = /a*?/g; //包含任意多个a的子串,但'?'表示用非贪婪方式(匹配出的子串能少则少),最后匹配到多个空字串 //字符串去重
// var reg = /(\w)\1*/g;
/* str.replace(reg, "$1");
*/ //2014百度题:将表示金额的字符串替换成:100.000.000的形式;
//var reg = /(?=(\B)(\d{3})+$)/g; 匹配出:\d{3}+ 以3为个数的倍数的一个或多个数字
// $ 结尾的
// \B 非单词边界 防止出现.100.000.000
// ?=n 紧跟
//组合成:匹配 紧跟 以3为个数的倍数的一个或多个数字结尾的 且是 非单词边界的 空字符串
//str.replace(reg, "."); </script>
</body>
</html>

参考文档注释中有,就是W3CSchool的官方文档,感兴趣的朋友可以测一测玩玩,感受一哈RegExp的强大,最后一个百度面试题当时号称史上最难,我没测出来,希望了解的朋友提点一下我,谢谢了...

关于RegExp的一些使用的练习(代码加注释)的更多相关文章

  1. Sublime Text对Python代码加注释的快捷键

    一直在Coursera上补基础课,发现很多课程都用Python作为教学语言,学了一下感觉果然好,简直是用英语在写代码.(我建Python目录的时候发现去年学过一点点Python,居然一点都不记得了= ...

  2. python代码加注释--6

    备注:#用来注释代码,#后面的内容会被python解释器忽略

  3. C#各种文件操作的代码与注释

    C#各种文件操作的代码与注释,具体看下面代码: using System; using System.Collections.Generic; using System.Linq; using Sys ...

  4. python学习之——计算给出代码中注释、代码、空行的行数

    题目:计算给出代码中注释.代码.空行的行数 来源:网络 思路:注释行以 ‘#’开头,空行以 ‘\n’ 开头,以此作为判断 def count_linenum(fname): fobj = open(f ...

  5. 第三次阅读赵炯博士的《linux内核代码完全注释》:序

    这是我第三次阅读linux内核代码完全注释了,当然前两次也没有读完,第一次读到第五章,第二次第七章. 所以说,赵炯博士对我最大的帮助时介绍了intel386的结构,以及内核编程的方法. 至于真正的内核 ...

  6. 教你怎么用Mono Cecil - 动态注入 (注意代码的注释)

    原文 教你怎么用Mono Cecil - 动态注入 (注意代码的注释) 使用 Mono Cecil 进行反编译:using Mono.Cecil; using Mono.Cecil.Cil; //.. ...

  7. 打开地图文件和shape文件代码加载Mxd文档

    代码加载Mxd文档 用代码添加Mxd文档,用到AxMapControl.LoadMxFile(sFilePath),我们只要将Mxd文档的路径传给这个方法即可 /// <summary>  ...

  8. 【转载】一行代码加载网络图片到ImageView——Android Picasso

    原文链接:一句代码加载网络图片到ImageView——Android Picasso  注意:此处使用下面代码需要先配置一下gradle,下载所需包. 具体操作如下图: compile 'com.sq ...

  9. Sublime Text 代码块注释

    插件:Doc​Blockr /*回车:创建一个代码块注释 /**回车:在自动查找函数中的形参等等.

随机推荐

  1. Batch Normalization层

    Batch Normalization的加速作用体现在两个方面:一是归一化了每层和每维度的scale,所以可以整体使用一个较高的学习率,而不必像以前那样迁就小scale的维度:二是归一化后使得更多的权 ...

  2. Win10设置vs2010总是以管理员身份运行

    有的项目用vs打开后直接运行总是要求提升权限,如下图       1.第一步(这样的方式只能是先运行vs,然后再打开项目,这样才是以管理员的身份运行的.但是如果是通过sln文件的快捷方式打开的,却不是 ...

  3. Ubuntu12.04下安装、使用、卸载MySQL

    转自:http://blog.csdn.net/yimi0903/article/details/11800713 一.安装 Step1:安装MySQL-server,mysql-client 执行以 ...

  4. 深度学习之Batch归一化

    前言            以下内容是个人学习之后的感悟,转载请注明出处~ Batch归一化 在神经网络中,我们常常会遇到梯度消失的情况,比如下图中的sigmod激活函数,当离零点很远时,梯度基本为0 ...

  5. NHibernate从入门到精通系列——NHibernate环境与结构体系

    内容摘要 NHibernate的开发环境 NHibernate的结构体系 NHibernate的配置 一.NHibernate的开发环境 NHibernate的英文官方网站为:http://nhfor ...

  6. Count Subsets

    题意: 给一集合 $S = \{ 1,2, ... , n \} $,取两个S的子集 A和B,使得A不是B的子集,且B不是A的子集. 解法: 1.牛顿展开 我们采用容斥,显然有 $$ans(n) = ...

  7. HTML5的LocalStorage实现记住密码

    HTML5 提供了两种在客户端存储数据的新方法: localStorage - 没有时间限制的数据存储 sessionStorage - 针对一个 session 的数据存储 localStorage ...

  8. httpclient:实现有验证码的模拟登陆

    //1.这种方式是先把验证码的图片下载到本地.并且根据网页解析获得token值//2.手动在控制台输入验证码//3.因为验证码图片已经下载下来,后面就可以使用图像文字识别package DoubanS ...

  9. python 数据可视化

    一.基本用法 import numpy as np import matplotlib.pyplot as plt x = np.linspace(-1,1,50) # 生成-1到1 ,平分50个点 ...

  10. 牛客 - 17968 - xor序列 - 线性基

    https://ac.nowcoder.com/acm/problem/17968 下面是错误的做法,因为题目要求必须使用x,而y在check的时候不一定用到等价于x的线性基来构成. 正确的做法是直接 ...