学习
实践
活动
专区
工具
TVP
写文章

JavaScript·JavaScript 正则技巧

JS 正则技巧 何为正则?一句话总结:正则是匹配模式,要么匹配字符,要么匹配位置。 字符匹配 模糊匹配 正则除了精确匹配,还能实现模糊匹配,模糊匹配又分为横向模糊和纵向模糊。 引用分两种:在 JavaScript 里引用和在正则里引用。分组和分支结构是括号最直接的功能,强调括号内是一个整体,即提供子表达式。 : "2018-01-01", groups: undefined] console.log(RegExp.$1, RegExp.$2, RegExp.$3) // 2018 01 01 扩展:在 JavaScript 正则的拆分 结构和操作符 JavaScript正则表达式由字符字面量、字符组、量词、锚、分组、选择分支、反向引用等结构组成。 、*、+ 3 位置和序列 ^、$、\元字符、一般字符 4 管道符 ` ` 5 元字符 JavaScript 正则里用到的元字符有 ^、$、.、*、+、?

24320
  • 广告
    关闭

    【玩转 GPU】有奖征文

    精美礼品等你拿!

  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JavaScript(RegExp正则匹配)

    前言 正则表达式是一个描述字符模式的对象。JavaScript的RegExp对象和String对象定义了使用正则表达式来执行强大的模式匹配和文本检索与替换函数的方法。 在JavaScript中,正则表达式是由一个RegExp对象表示的.当然,可以使用一个RegExp()构造函数来创建RegExp对象, 也可以用JavaScript 1.2中的新添加的一个特殊语法来创建 JavaScript采用的是Perl语言正则表达式语法的一个相当完整的子集. 1.直接量字符  我们已经发现了,在正则表达式中所有的字母字符和数字都是按照字面意思与自身相匹配的.JavaScript正则表达式还通过以反斜杠(\)开头的转义序列支持某些非字母字符.例如,序列 "\ 例如:要匹配词 "javascript" ,我们可以使用正则表达式 /^ javascript $/.

    1.3K50

    javascript正则函数都有哪些

    javascript中的正则函数有:1.test,检测一个字符串是否匹配某个模式;2.match,在字符串内检索指定的值;3.replace,在字符串中替换字符;4.search,检索字符串中指定的子字符串 ; 添加描述 javascript中的正则函数有以下几种 1.test javascript中test函数的作用是用于检测一个字符串是否匹配某个模式。 var patt1 = new RegExp("world");var result = patt1.test(str);document.write(result); //返回true 2.match javascript document.write(str.match("worlld")) //返回null 3.replace javascript中replace函数的作用是用于在字符串中替换字符。 4.search javascript中search函数的作用是用于检索字符串中指定的子字符串。 search函数使用方法: var str="Hello world!"

    25120

    javascript 正则命名分组

    本文作者:IMWeb zzbozheng 原文出处:IMWeb社区 未经同意,禁止转载 前言 以往我们只是习惯于通过数组下标来访问正则匹配到的分组,但分组达到4、5个时,标识起来就会非常麻烦。 V8早已实现了正则命名分组提案,只是我们很少使用,本文将介绍JS的正则命名分组。 后面维护代码的同学阅读起来,还要根据下标找到正则里面对应的括号,并且要再次阅读括号里面的正则才知道含义。 当你调整正则捕获分组的数量、顺序或嵌套时,你必要还要对下面的代码做调整。 所有这些问题,都可以通过正则命名分组来解决。 现在的玩法 现在你只需要给分组里面一个命名标识即可: (?<year>\d{4}) 这里,我们用变量year标记了上一个捕获组#1。 该名称必须是合法的JavaScript标识符。 匹配后,您可以通过matchObj.groups.year访问捕获的字符串。

    35930

    JavaScript 正则命名分组

    前言 以往我们只是习惯于通过数组下标来访问正则匹配到的分组,但分组达到4、5个时,标识起来就会非常麻烦。V8早已实现了正则命名分组提案,只是我们很少使用,本文将介绍JS的正则命名分组。 ? 过去 假设要使用正则匹配一个日期的年月日,以往我们会这样做: const RE_DATE = /(\d{4})-(\d{2})-(\d{2})/; const matchObj = RE_DATE.exec - 后面维护代码的同学阅读起来,还要根据下标找到正则里面对应的括号,并且要再次阅读括号里面的正则才知道含义。 - 当你调整正则捕获分组的数量、顺序或嵌套时,你必要还要对下面的代码做调整。 所有这些问题,都可以通过正则命名分组来解决。 现在 现在你只需要给分组里面一个命名标识即可: (?<year>\d{4}) 这里,我们用变量year标记了上一个捕获组#1。 该名称必须是合法的JavaScript标识符。 匹配后,您可以通过matchObj.groups.year访问捕获的字符串。 让我们通过命名分组重写前面的代码: const RE_DATE = /(?

    1.1K10

    javascript正则表达式

    正则表达式一直是一个令人头疼但却又是十分重要的一个东西。熟练的使用正则表达式可以让你的工作事半功倍。接下来,一起来看看正则表达式是什么吧! 正则表达式概念 正则表达式,又称规则表达式。 正则表达式的基本语法 var reg = / pattern / flags; 就像上面的,正则表达式是由两个/符号包裹起来的,两个/里面的(上面的pattern)就是需要的任何简单或者是复杂的正则表达式 下面根据JavaScript正则表达式的速查表中的分类来对每一下进行一个说明。 var text = "abcdefg"; var res = text.match(reg); console.log(res); // null JavaScript中需要使用 \ 的特殊符号有:( 正则表达式替换 正则表达式替换主要是替换一些字符。主要以下几个,可是在replace中使用。

    39430

    JavaScript正则表达式

    正则表达式(Regular Expression)使用单个字符串来描述、匹配一系列符合某个句法规则的字符串搜索模式,是用于匹配字符串中字符组合的模式。 一、JS 如何创建正则表达式? 接收两个参数,第一个是正则表达式,第二个是要进行替换的字符串。正则表达式如果设置的修饰符g,则进行全局替换,否则只替换匹配的第一个子串。 如果第一个参数不是正则表达式,则直接搜索该字符串,而不是将其转换为正则表达式。 global 是一个只读布尔值,用以说明这个正则表达式是否带有修饰符g。 ignoreCase 是一个只读布尔值,用以说明这个正则表达式是否带有修饰符i。 当调用 exec() 的正则表达式对象具有修饰符g时,它将把当前正则表达式对象的 lastIndex 属性设置为紧挨着匹配子串的字符位置。

    48310

    JavaScript正则表达式

    正则表达式是一种文本模式,模式描述在搜索文本时要匹配的一个或多个字符串。 JavaScript通过RegExp来支持正则表达式。正则表达式创建方式 var reg=/pattern/flags。 其中pattern可以是任何简单或者复杂的正则表达式,可以包含字符串、分组、限定符、向前查找以及方向引用。每个正则表达式可以带有一个或者多个标记,用以表达正则表达式的行为。 var pattern6 = new RegExp("\\.at","gi"); 通过RegExp函数定义的正则表达式与字面量定义的有点不同。 index表示匹配项的位置,input表示应用正则表达式的字符串。 如果 exec() 找到了匹配的文本,则返回一个结果数组。否则,返回 null。 JavaScript的模式匹配有一定局限性,如向后查找,并集和交集等。

    471100

    JavaScript正则表达式

    之前好一段时间,自己很抵触“正则表达式”。一是,对其了解甚浅,不能很完整的掌握;再者,觉得好多需要正则的,要不网上可以找到,要不可以使用其他方式去实现。总之,对于正则毫无心得。 最近,看完了《JavaScript忍者秘籍》这本书,对正则有了全新的认识,自己也尝试了总结了一些,在开发中,让好多事情变得事半功倍。 正则表达式是一个拆分字符串并查询相关信息的过程。 正则表达式通常被称为一个模式(pattern),是一个用简单方式描述或者匹配一系列符合某个语法规则的字符串。 一、创建正则表达式 ECMAScript通过RegExp类型来支持正则表达式。 1. 注意:在开发过程中,如果正则是已知的,则优先选择字面量语法;而构造器方式则是用于运行时,通过动态构建字符串来构建正则表达式。 keys[key]); } return result.join("&"); } compress("foo=1&foo=2&blah=3"); // "foo=1,2&blah=3" 《JavaScript

    47281

    JavaScript——正则表达式

    正则表达式 正则表达式是用于匹配字符串字符组合的模式,在JavaScript中,正则表达式也是对象。 其他语言也会使用正则表达式,本阶段我们主要是利用 JavaScript 正则表达式完成表单验证。 特点灵活性、逻辑性和功能性非常的强。可以迅速地用极简单的方式达到字符串的复杂控制。 \w+)*实际开发,一般都是直接复制写好的正则表达式. 但是要求会使用正则表达式并且根据实际情况修改正则表达式. 比如用户名: /^[a-z0-9_-]{3,16}/在JavaScript中的使用创建正则表达式在JavaScript中,可以通过俩种方式创建一个正则表达式 通过调用RegExp对象的构造函数创建 var 特殊字符非常多,可以参考: MDN:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Guide/Regular_Expressions jQuery

    13830

    JavaScript——正则表达式

    正则表达式 正则表达式是用于匹配字符串字符组合的模式,在JavaScript中,正则表达式也是对象。 其他语言也会使用正则表达式,本阶段我们主要是利用 JavaScript 正则表达式完成表单验证。 特点 灵活性、逻辑性和功能性非常的强。 可以迅速地用极简单的方式达到字符串的复杂控制。 \w+)*$ 实际开发,一般都是直接复制写好的正则表达式. 但是要求会使用正则表达式并且根据实际情况修改正则表达式. 比如用户名: /^[a-z0-9_-]{3,16}$/ 在JavaScript中的使用 创建正则表达式 在JavaScript中,可以通过俩种方式创建一个正则表达式 通过调用RegExp对象的构造函数创建 特殊字符非常多,可以参考: MDN:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Guide/Regular_Expressions jQuery

    12110

    正则表达式-JavaScript

    正则表达式-JavaScript 什么是正则表达式 正则表达式是用于匹配字符串中字符组合的模式。在 JavaScript中,正则表达式也是对象。 正则表达式存在于大部分的编程语言,就算是在写shell时也会不经意的用到正则。 比如大家最喜欢的rm -rf ./*,这里边的*就是正则的通配符,匹配任意字符。 在JavaScript也有正则表达式的实现,差不多就长这个样子:/\d/(匹配一个数字)。 个人认为正则所用到的地方还是很多的,比如模版字符的替换、解析URL,表单验证 等等一系列。 正则表达式在JavaScript中的实现 JavaScript中的语法 赘述那些特殊字符的作用并没有什么意义,浪费时间。 推荐MDN的文档:基础的正则表达式特殊字符 关于正则表达式,个人认为以下几个比较重要: 贪婪模式与非贪婪模式 P.S.

    74150

    关注

    腾讯云开发者公众号
    10元无门槛代金券
    洞察腾讯核心技术
    剖析业界实践案例
    腾讯云开发者公众号二维码

    相关产品

    • 静态网站托管

      静态网站托管

      静态网站托管(WH)是由腾讯云开发提供的便捷、稳定、高拓展性的托管服务。您无需自建服务器,自带CDN加速,一键即可部署网站应用。同时,通过JS SDK可直接操作数据库、云函数等,将静态网站扩展为带有后台服务端的全栈网站。

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭

      扫码关注腾讯云开发者

      领取腾讯云代金券