JavaScript replace字符串替换函数的用法

replace JavaScript">

var strM = "javascript is a good script language";

//在此我想将字母a替换成字母A

alert(strM.replace("a","A"));

这样只能替换第一个“a”字母

var strM = "javascript is a good script language";

//在此将字母a全部替换成字母A

alert(strM.replace(/a/g,"A"));

这样可以替换所有“a”字母。其中g为全局标志

JavaScript--正则表达式

正则表达式(regular expression)对象包含一个正则表达式模式(pattern)。它具有用正则表达式模式去匹配或代替一个串(string)中特定字符(或字符集合)的属性(properties)和方法(methods)。

正则表达式构造函数: new RegExp("pattern"[,"flags"]);

参数说明:

pattern -- 一个正则表达式文本

flags -- 如果存在,将是以下值:

g: 全局匹配

i: 忽略大小写

gi: 以上组合

在构造函数中,一些特殊字符需要进行转意(在特殊字符前加"\")。正则表达式中的特殊字符:

字符  含意

\ 转意,即通常在"\"后面的字符不按原来意义解释,如/b/匹配字符"b",当b前面加了反斜杆后/\b/,转意为

匹配一个单词的边界。

-或-

对正则表达式功能字符的还原,如"*"匹配它前面元字符0次或多次,/a*/将匹配a,aa,aaa,加了"\"后,/a\*/

将只匹配"a*"。

^  匹配一个输入或一行的开头,/^a/匹配"an A",而不匹配"An a"

$  匹配一个输入或一行的结尾,/a$/匹配"An a",而不匹配"an A"

*  匹配前面元字符0次或多次,/ba*/将匹配b,ba,baa,baaa

+  匹配前面元字符1次或多次,/ba*/将匹配ba,baa,baaa

?  匹配前面元字符0次或1次,/ba*/将匹配b,ba

(x)  匹配x保存x在名为$1...$9的变量中

x|y  匹配x或y

{n}  精确匹配n次

{n,}  匹配n次以上

{n,m}  匹配n-m次

[xyz]  字符集(character set),匹配这个集合中的任一一个字符(或元字符)

[^xyz]  不匹配这个集合中的任何一个字符

[\b]  匹配一个退格符

\b  匹配一个单词的边界

\B  匹配一个单词的非边界

\cX  这儿,X是一个控制符,/\cM/匹配Ctrl-M

\d  匹配一个字数字符,/\d/ = /[0-9]/

\D  匹配一个非字数字符,/\D/ = /[^0-9]/

\n  匹配一个换行符

\r  匹配一个回车符

\s  匹配一个空白字符,包括\n,\r,\f,\t,\v等

\S  匹配一个非空白字符,等于/[^\n\f\r\t\v]/

\t  匹配一个制表符

\v  匹配一个重直制表符

\w  匹配一个可以组成单词的字符(alphanumeric,这是我的意译,含数字),包括下划线,如[\w]匹配"$5.98"

中的5,等于[a-zA-Z0-9]

\W  匹配一个不可以组成单词的字符,如[\W]匹配"$5.98"中的$,等于[^a-zA-Z0-9]。

说了这么多了,我们来看一些正则表达式的实际应用的例子:

HTML代码的屏蔽

function mask_HTMLCode(strInput) {

var myReg = /<(\w+)>/;

return strInput.replace(myReg, "<$1>");

}

E-mail地址验证:

function test_email(strEmail) {

var myReg = /^[_a-z0-9]+@([_a-z0-9]+\.)+[a-z0-9]{2,3}$/;

if(myReg.test(strEmail)) return true;

return false;

}

正则表达式对象的属性及方法:

预定义的正则表达式拥有有以下静态属性:input, multiline, lastMatch, lastParen, leftContext,

rightContext和$1到$9。其中input和multiline可以预设置。其他属性的值在执行过exec或test方法后被根据

不同条件赋以不同的值。许多属性同时拥有长和短(perl风格)的两个名字,并且,这两个名字指向同一个值。(

JavaScript模拟perl的正则表达式)

正则表达式对象的属性:

属性 含义

$1...$9 如果它(们)存在,是匹配到的子串

$_ 参见input

$* 参见multiline

$& 参见lastMatch

$+ 参见lastParen

$` 参见leftContext

$''          参见rightContext

constructor     创建一个对象的一个特殊的函数原型

global        是否在整个串中匹配(bool型)

ignoreCase     匹配时是否忽略大小写(bool型)

input        被匹配的串

lastIndex      最后一次匹配的索引

lastParen      最后一个括号括起来的子串

leftContext     最近一次匹配以左的子串

multiline      是否进行多行匹配(bool型)

prototype      允许附加属性给对象

rightContext    最近一次匹配以右的子串

source        正则表达式模式

lastIndex      最后一次匹配的索引

正则表达式对象的方法:

方法 含义

compile       正则表达式比较

exec        执行查找

test        进行匹配

toSource      返回特定对象的定义(literal

representing),其值可用来创建一个新的对象。重载Object.toSource方法得到的。

toString      返回特定对象的串。重载Object.toString方法得到的。

valueOf       返回特定对象的原始值。重载Object.valueOf方法得到

例子:

var myReg = /(w+)s(w+)/;

var str  = "John Smith";

var newstr = str.replace(myReg, "$2, $1");

document.write(newstr);

将输出"Smith, John"

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容