- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有人尝试在 js 中重新创建 smarty:
// actually from a template file, not hardcoded in the javascript
html = '<span class="{test}">yay</span>';
html = change(html, 'test', 'foo bar');
function change(html, key, value){
html = html.replace('{'+key+'}',value);
html = html.replace('%7B'+key+'%7D',value);
return html;
}
element.innerHTML = html;
在 FF 中这工作正常(如预期的那样):
<span class="foo bar">yay</span>
在 IE 7/8 和可能 6 中...它给了我这个:
<span class="foo" bar="">yay</span>
为什么它会创建额外的属性而不是按照我的预期去做?
最佳答案
Someone tried to recreate smarty in js
我真希望他们不要那样做...!
我怀疑这里发生的事情是代码从元素的 innerHTML
中获取原始 HTML,而不是您上面写的字符串。在这种情况下,IE 会将其 DOM 序列化为 它 认为格式化 HTML 标记的好方法,这可能与它最初提供的标记不太一样。在这种情况下,它可能做的有问题的事情之一是省略引号:
<SPAN class={test}>yay</SPAN>
“但是,那不是有效的 HTML!”,您提示道。 Pfft⟩—⟩就像 IE 关心的那样。
现在进行替换,你会得到:
<SPAN class=foo bar>yay</SPAN>
其中 bar
显然是一个新属性,当您将其写回到 innerHTML
时,将被解析为一个单独的 Attr 节点。
再一次提醒大家不要用正则表达式处理 HTML。当您阅读 innerHTML
时,浏览器没有义务为您提供正确的 HTML,就像您一般不熟练的 HTML 作者一样。
此代码不仅会在这种情况下失败,还会在键中包含正则表达式特殊字符、值中包含替换特殊字符或任何地方的 HTML 特殊字符的任何情况下失败,并且不允许两次使用相同的键,并且对于一些未知的原因试图模板化 URL 编码的字符串(?),如果替换值包含花括号,则可能会搞砸。
如果您可以将其全部保存在 DOM 中,则分配给 span.className
既简单又安全。如果您必须使用 HTML 字符串进行模板化(如果您这样做,您需要查看 HTML 转义以避免困扰大多数 JS 模板系统的 XSS 漏洞),那么您需要将输入的 HTML 模板保留为原始文本字符串,而不是从 DOM 中读取它。
关于javascript - HTML 字符串替换 span 的类在 IE 中不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2449229/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!