innerHTML应用

2016-02-19 11:57 1 1 收藏

图老师小编精心整理的innerHTML应用希望大家喜欢,觉得好的亲们记得收藏起来哦!您的支持就是小编更新的动力~

【 tulaoshi.com - Web开发 】


blank的blog:http://www.planabc.net/
innerHTML 属性的使用非常流行,因为他提供了简单的方法完全替代一个 HTML 元素的内容。另外一个方法是使用 DOM Level 2 API(removeChild, createElement, appendChild)。但很显然,使用 innerHTML 修改 DOM tree 是非常容易且有效的方法。然而,你需要知道 innerHTML 有一些自身的问题:当 HTML 字符串包含一个标记为 defer 的 script 标签(script defer/script)时,如 innerHTML 属性处理不当,在 Internet Explorer 上会引起脚本注入攻击。 设置 innerHTML 将会破坏现有的已注册了事件处理函数的 HTML 元素,会在某些浏览器上引起内存泄露的潜在危险。
还有几个其他次要的缺点,也值得一提的:你不能得到刚刚创建的元素的引用,需要你手动添加代码才能取得那些引用(使用 DOM APIs)。 你不能在所有浏览器的所有 HTML 元素上设置 innerHTML 属性(比如,Internet Explorer 不允许你在表格的行元素上设置innerHTML 属性)。
我更关注与使用 innerHTML 属性相关的安全和内存问题。很显然,这不是新问题,已经有能人围绕这些中的某些问题想出了方法。
Douglas Crockford 写了一个 清除函数 ,该函数负责中止由于 HTML 元素注册事件处理函数引起的一些循环引用,并允许垃圾回收器(garbage collector)释放与这些 HTML 元素关联的内存。
从 HTML 字符串中移除 script 标签并不像看上去那么容易。一个正则表达式可以达到预期效果,虽然很难知道是否覆盖了所有的可能性。这里是我的解决方案:
/script[^]*[Ss]*?/script[^]*/ig
现在,让我们将这两种技术结合在到一个单独的 setInnerHTML 函数中,并将 setInnerHTML 函数绑定到 YUI 的 YAHOO.util.Dom 上:
YAHOO.util.Dom.setInnerHTML = function (el, html) {
el = YAHOO.util.Dom.get(el);
if (!el || typeof html !== 'string') {
return null;
}
// 中止循环引用
(function (o) {
var a = o.attributes, i, l, n, c;
if (a) {
l = a.length;
for (i = 0; i l; i = 1) {
n = a[i].name;
if (typeof o[n] === 'function') {
o[n] = null;
}
}
}
a = o.childNodes;
if (a) {
l = a.length;
for (i = 0; i l; i = 1) {
c = o.childNodes[i];
// 清除子节点
arguments.callee(c);
// 移除所有通过YUI的addListener注册到元素上所有监听程序
YAHOO.util.Event.purgeElement(c);
}
}
})(el);
// 从HTML字符串中移除script,并设置innerHTML属性
el.innerHTML = html.replace(/script[^]*[Ss]*?/script[^]*/ig, "");
// 返回第一个子节点的引用
return el.firstChild;
};
如果此函数还应有其他任何内容或者在正则表达式中遗漏了什么,请让我知道。
很明显,在网页上还有很多其他注入恶意代码的方法。setInnerHTML 函数仅能在所有 A-grade 浏览器上规格化 script 标签的执行行为。如果你准备注入不能信任的 HTML 代码,务必首先在服务器端过滤,已有许多库可以做到这点。
原文:Julien Lecomte 的 《The Problem With innerHTML》

来源:https://www.tulaoshi.com/n/20160219/1599233.html

延伸阅读
应用宝怎么导出apk应用   首先,您需要到应用宝官网(sj.qq.com)下载应用宝PC版,然后在电脑中安装应用宝。安装完成后,启动应用宝并将手机用数据线与电脑相连接。 完成应用宝的初始化工作,保证应用宝在下载完手机驱动、安装手机端应用宝后能够正确地识别您的手机,识别完成后在界面左边点击我的应用,如图所示。 在...
网络下载。 程序的主角是一个ActiveX控件:WebBrowser。当然,缺省状态下VB的工具箱中并没有它,我们得手工加入,方法是:右击工具箱,在出现的快捷菜单中选择部件...,确保在弹出的对话框中选中控件标签,找到Microsoft Internet Controls,在它前面的小框中打钩,然后确定。此时你会发现工具箱中多了两个小图标,其中,地球图标代表的控件正...
标签: Web开发
DIV class=box id=top_barWeb Tools--Ajax Version /DIVBR DIV class="box general"    天气预报: INPUT id=Weather size=17 value=北京   INPUT onclick=getWeather() type=button value="提 交" name=submit   SPAN id=Disp_Weather/SPAN/DIV DIV class="box general"  IP地址查询: INPUT id=Ip...
标签: windows系统
Win8应用与应用商店   在Win8打开的那一瞬间,那些翻动着的方块一定会吸引住所有人的目光,这就是Win8的重要组成部分Win8应用。 在Win8系统中,Win8应用是一个无论如何也不能跳过的话题,这些应用在日常使用中能够为用户带来极大的便捷,同时也让办公方式更加灵活。利用Win8应用,用户可以在传统PC上用传统的操控方式体验平板...
1、创建高级对象 使用构造函数来创建对象 构造函数是一个函数,调用它来例示并初始化特殊类型的对象。可以使用 new 关键字来调用一个构造函数。下面给出了使用构造函数的新示例。 var myObject = new Object(); // 创建没有属性的通用对象。 var myBirthday = new Date(1961, 5, 10); // 创建一个 Date 对象。 var myCar = new Car(); //...

经验教程

613

收藏

34
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部