最近查一个bug,原因是JS中的Replace方法造成的,当将一个字符串中有处需要替换时,一般会用到JS中的Replace方法,Replace方法的第一个参数如果是传的字符串,只会替换第一处。代码如下:
复制代码
代码如下:
var
str
=
"0CEA65D5-DB8E-4876-A6F8-C88AC7F0E185,E846C244-8A19-4374-879B-0B1DC08D1747,6CB3EBA4-1E22-4E4D-8800-AE31130B6F5D"
alert(str.replace(",","','"))
上面的代码本意是将用逗号隔开的GUID的逗号替换成',',但实际结果只将第一个逗号替换了。
解决这个问题只需将replace的第一个参数使用正则的方式即可,代码如下:
复制代码
代码如下:
var
reg
=
new
RegExp(",","g")
var
str
=
"0CEA65D5-DB8E-4876-A6F8-C88AC7F0E185,E846C244-8A19-4374-879B-0B1DC08D1747,6CB3EBA4-1E22-4E4D-8800-AE31130B6F5D"
alert(str.replace(reg,"','"))
结果如下:
以上所述就是文本的全部内容了,希望对大家学习javascript能够有所帮助。
replace(/\//g, '') 的作用是把/替换成''。
用法如下:
比如:var aa= "adsdd/sdsd12/"
bb=aa.replace(/\//g, '')
那么bb=adsddsdsd12
js简介
JavaScript一种直译式脚本语言,是一种动态类型、弱类型、基于原型的语言,内置支持类型。它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在HTML(标准通用标记语言下的一个应用)网页上使用,用来给HTML网页增加动态功能。
组成部分
javascript组成一个完整的 JavaScript 实现是由以下 3 个不同部分组成的:
核心(ECMAScript)、文档对象模型(Document Object Model,简称DOM)、浏览器对象模型(Browser Object Model,简称BOM)。
<!DOCTYPE html><html>
<head>
<title>test</title>
<script>
function replace(tag, value) {
return String.prototype.replace.call(value, tag, arguments[2])
}
function format() {
var html = document.body.innerHTML
var tag = "salutation|invoice|time|item|threaten"
var reg = new RegExp("(<span[^>]*id[=\"\'\\s]+(" + tag + ")[\"\'\\s]+>)((?:(?!<\\/span>)[\\s\\S])*)(<\\/span>)", "gi")
html = replace(reg, html, function(a, a1, a2, a3, a4) {
var str = ""
if (a2 == "salutation") {
str = "Mr. Smith"
} else if (a2 == "invoice") {
str = 123
} else if (a2 == "item" || a2 == "time") {
str = 'flux capacitor'
} else if (a2 == "threaten") {
str = 'Please do not make me angry.'
}
tag = tag.replace(new RegExp("\\|?" + a2 + "\\|?", "g"), "|").replace(/^\||\|$/g, "")
var result = a1 + str + a4
return result
})
//改变每个span后所有单词的首字母改为大写
reg = /(<span[^>]*>)((?:(?!<\/span>)[\s\S])*)(<\/span>)/ig
html = replace(reg, html, function(a, b, m, n) {
return b + replace(/([a-z])([^\r\n\f\x20\t]*)/gi, m, function(c, d, e) {
return d.toUpperCase() + e
}) + n
})
//如果tag不存在则弹出警告框“不存在”
tag ? alert(tag.replace(/\|/g, ",") + "不存在") : 0
document.body.innerHTML = html
}
//编写一个函数clearit(),从页面中删除所有包含在标记id =“buttons”的内容
function clearit() {
var btns = document.getElementById("buttons")
btns.innerHTML = ""
}
</script>
</head>
<body>Dear <span id="salutation">Name</span>:
<p>It has come to our attentation that your invoice <span id="invoice">ID</span>
has yet to be paid.It has now been <span id="time">some time</span> since you received <span id="item">the material</span> from Evil Incorporated. Please remit payment immediately. <span id="threaten"></span>
</p>Yours sincerely.
<br />
<br />
<br />J.Smith,Accounting
<div id="buttons">
<center>
<button onclick="format()">Format</button>
<button onclick="clearit()">Clear</button>
</center>
</div>
</body>
</html>