为了账号安全,请及时绑定邮箱和手机立即绑定

如何替换div元素内的文本?

如何替换div元素内的文本?

交互式爱情 2019-11-11 15:29:37
我需要动态设置DIV元素内的文本。什么是最好的浏览器安全方法?我有可用的prototypejs和scriptaculous。<div id="panel">  <div id="field_name">TEXT GOES HERE</div></div>该函数将如下所示:function showPanel(fieldName) {  var fieldNameElement = document.getElementById('field_name');  //Make replacement here}
查看完整描述

3 回答

?
慕妹3242003

TA贡献1824条经验 获得超6个赞

我将使用update支持纯文本,HTML代码段或任何定义toString方法的JavaScript对象的Prototype 方法。


$("field_name").update("New text");

Element.update文档


查看完整回答
反对 回复 2019-11-11
?
慕妹3146593

TA贡献1820条经验 获得超9个赞

您可以简单地使用:


fieldNameElement.innerHTML = "My new text!";


查看完整回答
反对 回复 2019-11-11
?
慕村225694

TA贡献1880条经验 获得超4个赞

function showPanel(fieldName) {

  var fieldNameElement = document.getElementById("field_name");

  while(fieldNameElement.childNodes.length >= 1) {

    fieldNameElement.removeChild(fieldNameElement.firstChild);

  }

  fieldNameElement.appendChild(fieldNameElement.ownerDocument.createTextNode(fieldName));

}

这样做的好处:


它仅使用DOM,因此该技术可移植到其他语言,并且不依赖于非标准的innerHTML

fieldName可能包含HTML,这可能是尝试的XSS攻击。如果我们知道它只是文本,那么我们应该创建一个文本节点,而不是让浏览器将其解析为HTML。

如果要使用javascript库,请使用jQuery,并执行以下操作:



  $("div#field_name").text(fieldName);

请注意,@ AnthonyWJones的注释是正确的:“ field_name”不是特别描述性的ID或变量名。


查看完整回答
反对 回复 2019-11-11
  • 3 回答
  • 0 关注
  • 1258 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信