我已经在互联网上搜索了这个答案。我有一个字符串数组,看起来像这样:
[0] Cinnamon+Chocolate+Twists
[1] 3.25+Ounce+Croissant
我需要从这些字符串中删除所有“+”字符,而是插入一个空格。以下代码不起作用:
nameProduct[1] = nameProduct[1].replace("+"," ");
我尝试了.replace方法的几种变体,但没有运气。有什么想法吗?
答案 0 :(得分:10)
你必须使用带有g
lobal标志的正则表达式来替换角色的每一个出现(是的,JavaScript在这方面表现得很奇怪(或者让我们说意外,取决于你来自哪种其他语言) )):
nameProduct[1] = nameProduct[1].replace(/\+/g," ");
使用循环为每个元素执行此操作。
<强>更新强>
不要使用document.write
来创建HTML。 Your code需要大量的重构,但这超出了这个问题。数据处理正确,但生成的HTML不是:
<input type="text" size="40" name="Product1401" value="Cinnamon" chocolate="" twists="" readonly="">
你看,引号有问题。文本的其他部分被识别为属性。
略有改进的版本(仅此部分):
var nameProduct = hashes[i].split('=');
var tr = document.createElement('tr');
var td = document.createElement('td');
var input = document.createElement('input');
input.type = "text";
input.size = 40;
input.name = nameProduct[0]
nameProduct[1] = nameProduct[1].replace(/%/g, '');
nameProduct[1] = nameProduct[1].replace(/2C/g, '');
nameProduct[1] = nameProduct[1].replace(/2F/g, '');
nameProduct[1] = nameProduct[1].replace(/28/g, '');
nameProduct[1] = nameProduct[1].replace(/29/g, '');
nameProduct[1] = nameProduct[1].replace(/\+/g, " ");
input.value = nameProduct[1];
input.readOnly = true;
td.appendChild(input);
tr.appendChild(td);
document.getElementById('gradient-style').tBodies[0].appendChild(tr);