当我尝试运行以下代码时,它不会将&lt,>&#34替换为其等效的caharacters
<% if(typeof myTable !== 'undefined'){ %>
<% myTable = myTable.replace('<','<').replace('>', '>').replace('"', '"') %>
<script>
localStorage['text'] += "<%= myTable %>";
</script>
<% myTable = undefined; %>
<% } %>
当我检查myTable的值,在ejs的plceholder标签中替换时,它仍然以原始形式包含这些字符。
myTable = "<table class="table table-bordered table-hover"><thead><tr><th class="col"><p contenteditable="true">Head</p></th><th class="col"><p contenteditable="true">Head</p></th></tr></thead><tbody><tr><td><p contenteditable="true">Null</p></td><td><p contenteditable="true">Null</p></td></tr><tr><td><p contenteditable="true">Null</p></td><td><p contenteditable="true">Null</p></td></tr></tbody></table>"
我该怎么办?
我会尝试存储替换字符串的值
<% myTable = myTable.replace('<','<').replace('>', '>').replace('"', '"') %>
否则它就会丢失。
来自docs
replace()方法在字符串中搜索指定的值或正则表达式,并返回一个新的字符串,其中替换了指定的值。
如果这不起作用,尝试一个未转义的蜂蜇版本:"<%- myTable %>";
(而不是"<%= myTable %>";
)。
您应该注意到g标志并使用myTable = myTable.replace而不是myTable.replace
因为replace方法不会更改源字符串,请参阅:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/replace
请尝试以下代码:
var myTable = "<table class="table table-bordered table-hover"><thead><tr><th class="col"><p contenteditable="true">Head</p></th><th class="col"><p contenteditable="true">Head</p></th></tr></thead><tbody><tr><td><p contenteditable="true">Null</p></td><td><p contenteditable="true">Null</p></td></tr><tr><td><p contenteditable="true">Null</p></td><td><p contenteditable="true">Null</p></td></tr></tbody></table>"
myTable = myTable.replace(/</g,'<').replace(/>/g, '>').replace(/"/g, '"');
console.log(myTable);