【发布时间】:2017-01-01 17:29:15
【问题描述】:
我想劫持(挂钩)Element.prototype 和 Node.prototype 的 innerHTML 和 nodeValue 属性,以便我可以在设置之前做一些事情并采取行动
innerHTML案例:
var ep = Element.prototype;
// {enumerable: true, configurable: true, set , get} // Ch/FF/Op
// {enumerable: true, configurable: false, get: undefined, set: undefined} // Safari
var epDescriptor = Object.getOwnPropertyDescriptor(ep, 'innerHTML');
var epOlderSetter = epDescriptor.set;
/*
Safari throw:
TypeError: Attempting to change the getter of an unconfigurable property.
*/
Object.defineProperty(ep, 'innerHTML', {
set: function(html){
alert('I want to do something befroe ...');
epOlderSetter.call(this, html);
}
})
是的。我知道原因。因为 safari 中的 configurable 是 false 所以 safari 抛出错误。
nodeValue 案例:
var np = Node.prototype;
// {enumerable: true, configurable: true ,get , set} // Ch/FF/Op
// {enumerable: true, configurable: true ,undefined , undefined} // Safari
var npDescriptor = Object.getOwnPropertyDescriptor(np, 'nodeValue');
var npOlderSetter = npDescriptor.set; // undefined
Object.defineProperty(np, 'nodeValue', {
set: function(text){
alert('I want to do something befroe ...');
// because npOlderSetter is undefined , so i can't do this.
// but how can i set the nodeValue to the node ?
// npOlderSetter.call(this, text);
}
})
我想知道是否有解决方法或黑魔法来实现我的两个(或一个)目标?
感谢您的建议
【问题讨论】:
标签: javascript html safari cross-browser frontend