正则表达式常见用例

正则表达式常见用例

大家好,又见面了,我是全栈君。

正则表达式是用于匹配字符串中字符组合的模式。在js中,正则表达式也是对象,这些对象被用于RegExp的exec和test方法,以及String的match、replace、search和split方法
可以使用2种方法之一构建一个正则表达式
(1)正则表达式字面量   /pattern/flags   flags:修饰符   const regex = /ab+c/;
(2)调用RegExp对象的构造函数 new RegExp(pattern [, flags])   let regex = new RegExp(“ab+c”);

例1

var str = “Hi, do you 1234 your abc?”;
stringObject.replace(regexp/substr,replacement)
返回值:一个新的字符串 
var str1 = str.replace(/abc/,”123″);
alert(str1);//”Hi, do you know your 123?”
var str1 = str.replace(/\d+/,”asde”); //str1 = “Hi, do you asde your abc?”;

 

例2、

(1)验证输入框的数值,只能输入1-10的数字(验证输入框的值是不是/^([1-9]|10)$/)

function test(){

       var text = document.getElementById(“text”).value;
       if(/^([1-9]|10)$/.test(text)){

            alert(“ok”)
           }else{

           alert(“no”)
             }
       }

(2)验证输入框的值是否全为数字

    function test() {

        var text = document.getElementById(“text”).value;
        if (/^[1-9]+$/.test(text)) {

            // 验证的时候/^[1-9]+$/不能写成/^[1-9]$/g,在文本替换的时候可以写成/^[1-9]$/g
            alert(“ok”)
        } else {

            alert(“no”)
        }
    }

(3)替换输入框中的数字为空

   function test() {

        var text = document.getElementById(“text”).value;
       下面两种方法都行

        document.getElementById(“text”).value = text.replace(/[1-9]/g,””);

        document.getElementById(“text”).value = text.replace(/[1-9]+/,””);

    }

 例3、

 var str = “foobar”;
 var str1 = str.replace(/(foo)(bar)/,’$2 $1′);
 alert(str1);//bar foo

例4、 

var str = “foo bar foo bar  aaaaa”;
var str1 = str.replace(/(foo) (bar) \1 \2/,’lily’);
alert(str1);//lily aaaaa

例5、 a{n}匹配了前面一个字符刚好发生了n次。 

var str = “caaandy”;
var str1 = str.replace(/a{2}/,’ll’);
alert(str1);//cllandy

 例6、

a{n,m}n 和 m 都是整数。匹配前面的字符至少n次,最多m次。如果 n 或者 m 的值是              0, 这个值被忽略。

var str = “caaandy”;
var str1 = str.replace(/a{1,2}/,’kk’);
alert(str1);//ckkandy

 

例7、

[xyz]一个字符集合。匹配方括号的中任意字符,包括转义序列。你可以使用破折号(-)来指定一个字符范围。对于点(.)和星号(*)这样的特殊符号在一个字符集中没有特殊的意义。他们不必进行转义,不过转义也是起作用的。

var str = “abcde”;
var str1 = str.replace(/[abc]/,”);
alert(str1);//bcde,在找到符合条件的匹配后不再进行匹配,如匹配a后,不再继续匹配,除非                          加上修饰符g
var str1 = str.replace(/[abc]/g,”);
alert(str1);//de

 

例8、

 [^xyz]一个反向字符集合。它匹配任何没有包含在方括号中的字符。你可以使用破折号            (-)来指定一个字符范围。任何普通字符在这里都是起作用的。

var str = “abcde”;
var str1 = str.replace(/[^abc]/,”);//[^abc]也可写成[^a-c]
alert(str1);//abce,在找到符合条件的匹配后不再进行匹配,如匹配a后,不再继续匹配,除非          加上修饰符g
var str1 = str.replace(/[^abc]/g,”);
alert(str1);//abc 

 例9、

\b 匹配一个词的边界。一个词的边界就是一个词不被另外一个词跟随的位置或者不是另一个词汇字符前边的位置。注意,一个匹配的词的边界并不包含在匹配的内容中。换句话说,一个匹配的词的边界的内容的长度是0。(不要和[\b]混淆了)

var str = “abc def abd”;
var str1 = str.replace(/\b/,’k’);
alert(str1);//”kabc def abd”  
var str1 = str.replace(/\b/g,’k’);
console.log(str1);//”kabck kdefk kabdk” 
var str1 = str.replace(/\ba/g,’k’);
console.log(str1);//”kbc def kbd” 
var str1 = str.replace(/^a/g,’k’);
console.log(str1);//”kbc def abd”  ^与\b的区别:  ^是匹配字符串的开始,\b是匹配单词的        边界

例10、 

var myRe = /d(b+)d/g;
var myArray = myRe.exec(“cdbbdbsbz”);
console.log(“The value of lastIndex is ” + myRe.lastIndex);//The value of lastIndex is 5

var myArray = /d(b+)d/g.exec(“cdbbdbsbz”);
//当发生/d(b+)d/g使用两个不同状态的正则表达式对象,lastIndex属性会得到不同的值。如果你需要访问一个正则表达式的属性,则需要创建一个对象初始化生成器,你应该首先把它赋值给一个变量。
console.log(“The value of lastIndex is ” + /d(b+)d/g.lastIndex);//The value of lastIndex is 0

转载于:https://my.oschina.net/u/2612473/blog/1592175

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/107816.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 360天擎忘记密码怎么卸载_天擎关闭密码

    360天擎忘记密码怎么卸载_天擎关闭密码360天擎卸载密码_如何卸载360企业版1、首先任务管理器,找到360,然后停用,2、然后找到服务,找到360服务,然后停用,3、再然后,进入控制面板卸载页面,卸载360天擎4、第2步成功后,在执行第三步,服务和任务管理器都停用以后,才能卸载;5、如果停用刷新不显示的话,重新启动;6、服务里面,看到的360服务,需要进入属性后才能编辑。…

    2022年9月25日
    0
  • win10\Win10系统禁止自动更新[通俗易懂]

    win10\Win10系统禁止自动更新[通俗易懂]win10专业版禁止自动更新(本人亲测无误后发布)解决方案:1.按下“windows+R”打开win10运行框;2.在运行框中输入“gpedit.msc”命令打开win10的本地组策略编辑器;3.在左侧:计算机配置菜单栏找到“管理模板”,紧接着点开当前菜单找到”windows组件“;4.最后在”Windows组件“中:找到Windows更新菜单栏点开:选中”配置自动更新“右键…

    2022年6月2日
    30
  • JAVA面试题及答案整理(最新版)

    JAVA面试题及答案整理(最新版)这些Java技术栈整理成册(包括:VM,JAVA集合,JAVA多线程并发,JAVA基础,Spring原理,微服务,Netty与RPC,网络,日志,Zookeeper,Kafka,RabbitMQ,Hbase,MongoDB,Cassandra,设计模式,负载均衡,数据库,一致性哈希,JAVA算法,数据结构,加密算法,分布式缓存,Hadoop,Spark,Storm,YARN,机器学习,云计算),对你的面试大有帮助,让你offer到手,高薪也有!JVM 线程 JVM内存区域

    2022年7月7日
    21
  • U盘中毒了?教你如何删除System Volume Information这个顽固文件夹「建议收藏」

    U盘中毒了?教你如何删除System Volume Information这个顽固文件夹「建议收藏」不得不说cmd命令很好用呢。最近我的U盘中毒了,格式化都删除不了SystemVolumeInformation这个顽固的文件夹,真心伤不起哇!还好现在解决了问题。看来以后得好好对待U盘,不能乱用了。本篇文章教大家如何删除SystemVolumeInformation这个顽固文件夹。希望对你有用。我的电脑是win10,win+R搜索cmd,启用cmd命令编辑器,并输入以下命令:attrib…

    2022年9月17日
    0
  • web前端 html+css+javascript网页设计实例 企业网站制作

    web前端 html+css+javascript网页设计实例 企业网站制作(案例源码链接在文章末尾,仅供学习参考)一、在浏览器中的运行结果:二、部分代码1.HTML:<!DOCTYPEhtml><html><headlang=”en”><metacharset=”UTF-8″><title>启乐官网</title><linkrel=”stylesheet”href=”style.css”/><scriptsrc=”myjs.j

    2022年6月16日
    32
  • 路径分析图「建议收藏」

    路径分析图「建议收藏」1.数据格式将环境数据和生物数据按下图形式放入一个表格中,首列为样品名,首行为环境理化因子或者相关生物参数名称。数据选择适当的标准化,例如,除pH外,所有环境数据进行log处理。2….

    2022年8月24日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号