首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何重写appendChild()?

如何重写appendChild()?
EN

Stack Overflow用户
提问于 2013-01-11 02:53:45
回答 2查看 5K关注 0票数 10
代码语言:javascript
复制
appendChild = function(message) {
    console.log("intercepted!");
}

使用上面的代码似乎不起作用。

有人知道吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-01-11 02:55:26

您可能想要替换Element.prototype.appendChild,但这可能不是一个好主意。

此示例在插入的元素中添加文本intercepted

代码语言:javascript
复制
var f = Element.prototype.appendChild;
Element.prototype.appendChild = function(){f.apply(this, arguments);arguments[0].innerHTML="!Intercepted!"; };
document.body.appendChild(document.createElement("div"));

Demonstration

票数 16
EN

Stack Overflow用户

发布于 2015-03-19 20:47:31

不建议覆盖本机函数,但如果这样做,请确保同时返回附加的元素,以防止使用本机"appendChild“函数的返回值的代码出现问题:

代码语言:javascript
复制
window.callbackFunc = function(elem, args) {
  // write some logic here
}
window.f = Element.prototype.appendChild;
Element.prototype.appendChild = function() {
    window.callbackFunc.call(this, arguments);
    return window.f.apply(this, arguments);
};
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14265219

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档