一、前言
正则表达式是匹配模式,要么是匹配字符,要么匹配位置。
其实在开发中很少用到匹配位置,本篇文章主要包含:
二、什么是位置
位置:相邻字符之间的位置。
三、如何匹配位置
在ES5中,共有6个锚:^, $, \b, \B, ("text-align: center">
3.1 ^和$
^(脱字符)匹配开头,在多行匹配中匹配行开头。
$(美元符)匹配结尾,在多行匹配中匹配行结尾。
比如:我们把字符串的开头和结尾用#替换(位置可以替换成字符的):
var result = "hello".replace(/^|$/g, '#'); console.log(result); // "#hello#"
多行匹配模式(有修饰符m)时,二者是行的概念,我们需要注意:
var result = "I\nlove\njavascript".replace(/^|$/gm, '#'); console.log(result); // #I#// #love#// #javascript#
3.2 \b和\B
\b是单词边界,具体就是\w和\W之间的位置,也包括\w与^之间的位置,和\w和$之间的位置。
比如考察文件名"[JS] Lesson_01.mp4"中的\b,如下:
var result = "[JS] Lesson_01.mp4".replace(/\b/g, '#'); console.log(result); // "[#JS#] #Lesson_01#.#mp4#"
首先,我们知道\w是字符组[0-9a-zA-Z]的简写,即使字母数字或者下划线中任何一个字符。而\W是字符组[^0-9a-zA-Z]的简写,即\W是\w以外的任何一个字符。
我们再来看#是怎么来的:
第 1 个,两边字符是 "[" 与 "J",是 \W 与 \w 之间的位置。
第 2 个,两边字符是 "S" 与 "]",也就是 \w 与 \W 之间的位置。
第 3 个,两边字符是空格与 "L",也就是 \W 与 \w 之间的位置。
第 4 个,两边字符是 "1" 与 ".",也就是 \w 与 \W 之间的位置。
第 5 个,两边字符是 "." 与 "m",也就是 \W 与 \w之间的位置。
第 6 个,位于结尾,前面的字符 "4" 是 \w,即 \w 与 $ 之间的位置。
知道了\b概念后,那\B就好理解了,\b是单词边界,\B是非单词边界
var result = "[JS] Lesson_01.mp4".replace(/\B/g, '#'); console.log(result); // "#[J#S]# L#e#s#s#o#n#_#0#1.m#p#4"
3.3 ("htmlcode">
而("htmlcode">
二者的学名分别是 中文翻译分别是 正向先行断言 和 负向先行断言 。 ES5 之后的版本,会支持 positive lookbehind 和 negative lookbehind。 具体是 ("color: #ff0000">四、位置特性 对于位置的理解,我们可以累计额成空字符""。 比如"hello"字符串等价于如下形式: 也等价于 因此,把 /^hello$/ 写成 /^^hello$$$/,是没有任何问题的: 也就是说,字符之间的位置,可以写成多个。 注:把 位置 理解 空字符 ,是对位置非常有效的理解方式 五、相关案例 5.1不匹配任何东西的正则 /.^/ 正则要求 只有一个字符,但是该字符后面是开头 ,而这样的字符串是不存在的。 5.2数字的千分位分隔符表示法 比如吧12345678,变成12,345,678。 分析:那就是需要把相应的位置替换成"," 5.2.1弄出来最后一个逗号 正则:/("htmlcode">
5.2.4支持其他形式 如果要把 "12345678 123456789" 替换成 "12,345,678 123,456,789"。 此时我们需要修改正则,把里面的开头 ^ 和结尾 $,修改成 \b: 5.2.5货币格式化 千分符表示法一个常见的应用就是货币格式化。 把这个字符串: 格式化: 实现: 5.3验证密码的问题 密码长度6-12,由数字,小写字母,大写字母组成,但必须至少包括2种字符。 写成多个正则来判断,比较容易,但是要写成一个正则就比较困难。 来看看我们对于位置的理解是否深刻。 5.3.1简化 暂时不考虑"必须至少包含2种字符"这个条件,可以容易写出: 5.3.2判断是否包含有某一种字符 假设,要求我们必须包含数字,怎么整?此时我们可以使用("htmlcode">
可视化形式: 分析: 上面正则看起来好复杂,只需要理解第二步,/("htmlcode">
可视化形式: 总结 以上所述是小编给大家介绍的javascript正则表达式学习之位置匹配,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
var result = "hello".replace(/("he#l#lo"
var result = "hello".replace(/("#h#ell#o#"
positive lookahead
和 negative lookahead。
"hello" == "" + "h" + "" + "e" + "" + "l" + "" + "l" + "" + "o" + "";
"hello" == "" + "" + "hello"
var result = /^^hello$$$/.test("hello");
console.log(result);
// true
var result = "12345678".replace(/("htmlcode">
var result = "12345678".replace(/("htmlcode">
var result = "123456789".replace(/("htmlcode">
var regex = /("12345678".replace(regex, ',')console.log(result);
// "12,345,678"result = "123456789".replace(regex, ',');
console.log(result);// "123,456,789"
var string = "12345678 123456789",regex = /("12,345,678 123,456,789"
$ 1888.00
function format (num) {return num.toFixed(2).replace(/\B(",").replace(/^/, "$ ");
};
console.log( format(1888) );
// "$ 1,888.00"
var regex = /^[0-9A-Za-z]{6,12}$/;
var regex = /("htmlcode">
var regex = /("htmlcode">
var regex = /(("1234567") );
// false 全是数字console.log( regex.test("abcdef") );
// false 全是小写字母console.log( regex.test("ABCDEFGH") );
// false 全是大写字母console.log( regex.test("ab23C") );
// false 不足6位console.log( regex.test("ABCDEF234") );
// true 大写字母和数字console.log( regex.test("abcdEF234") );
// true 三者都有
RegExp:/(("text-align: center">
var regex = /("htmlcode">
var regex = /("1234567") );
// false 全是数字console.log( regex.test("abcdef") );
// false 全是小写字母console.log( regex.test("ABCDEFGH") );
// false 全是大写字母console.log( regex.test("ab23C") );
// false 不足6位console.log( regex.test("ABCDEF234") );
// true 大写字母和数字console.log( regex.test("abcdEF234") );
// true 三者都有
RegExp:/("text-align: center">
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 羽泉《给未来的你&天黑天亮》[WAV+CUE][968M]
- 庄心妍《我也许在等候》[低速原抓WAV+CUE]
- 王雅洁《小调歌后2》[原抓WAV+CUE]
- 中国武警男声合唱团《辉煌之声1天路》[DTS-WAV分轨]
- 紫薇《旧曲新韵》[320K/MP3][175.29MB]
- 紫薇《旧曲新韵》[FLAC/分轨][550.18MB]
- 周深《反深代词》[先听版][320K/MP3][72.71MB]
- 李佳薇.2024-会发光的【黑籁音乐】【FLAC分轨】
- 后弦.2012-很有爱【天浩盛世】【WAV+CUE】
- 林俊吉.2012-将你惜命命【美华】【WAV+CUE】
- 晓雅《分享》DTS-WAV
- 黑鸭子2008-飞歌[首版][WAV+CUE]
- 黄乙玲1989-水泼落地难收回[日本天龙版][WAV+CUE]
- 周深《反深代词》[先听版][FLAC/分轨][310.97MB]
- 姜育恒1984《什么时候·串起又散落》台湾复刻版[WAV+CUE][1G]