此问题没有内置的解决方案,这是您的设计和编码模式的问题。
您可以使用发布者/订阅者模式。为此,您可以使用jQuery自定义事件或您自己的事件机制。
第一,
function changeHtml(selector, html) {
var elem = $(selector);
jQuery.event.trigger('htmlchanging', { elements: elem, content: { current: elem.html(), pending: html} });
elem.html(html);
jQuery.event.trigger('htmlchanged', { elements: elem, content: html });
}
现在,您可以按以下方式订阅divhtmlchanging / divhtmlchanged事件,
$(document).bind('htmlchanging', function (e, data) {
//your before changing html, logic goes here
});
$(document).bind('htmlchanged', function (e, data) {
//your after changed html, logic goes here
});
现在,您必须通过此changeHtml()
功能更改div内容更改。因此,您可以监视或可以进行必要的更改,因为绑定包含该信息的回调数据参数。
您必须像这样更改div的html;
changeHtml('#mydiv', '<p>test content</p>');
而且,您可以将其用于除输入元素之外的任何html元素。无论如何,您都可以修改它以与任何元素一起使用。