jquery监听div内容的变化具体实现思路 - Web前端
作者:98wpeu发布时间:2026-05-22分类:网页前端技术浏览:8
我们做电子商务,javascript框架采用的是JQuery,在开发过程中遇到了上面标题列出的问题:如何监听div内容的变化。
先给出最终代码(后续进行相关分析):
复制代码 代码如下:
vartitle = $("b.facility");
var title = $('#title');//the element I want to monitor
title.bind('DOMnodeInserted', function(e) {
alert('element now contAIns: ' + $(e.target).html());
});
解决问题的思路如下:
我们先回顾一下jQuery事件中的change()方法定义和用法:
当元素的值发生改变时,会发生 change 事件。
该事件仅适用于文本域(text field),以及 Textarea 和 select 元素。
change() 函数触发 change 事件,或规定当发生 change 事件时运行的函数。
注释:当用于 select 元素时,change 事件会在选择某个选项时发生。当用于 text fIEld 或 text area 时,该事件会在元素失去焦点时发生。
但是问题出现了关于div内容的改变change方法中只字不提,我们如何处理那?
后续百度关键词: jquery div 内容发生变化:无果;
继续,bing关键词:jquery how to listen div change 找到一篇相关文档http://stackoverflow.com/questions/2712124/JQuery-listen-to-changes-within-a-div-and-act-accordingly
粗略的明白是采用自定义事件的方式去处理问题,采纳代码如下:
复制代码 代码如下:
$('#laneconfigdisplay').bind('contentchanged', function() {
// do something after the div content has changed
alert('woo');
});
// 这样会调用上面的函数
$('#laneconfigdisplay').trigger('contentchanged');
但是contentchanged是什么内容没有说明,继续追溯
bing关键词:jquery how to listen div change 找到一篇相关文档
继续,bing关键词:jquery contentchanged 找到一篇相关文档HTTP://stackoverflow.com/questions/1449666/create-a-jquery-special-event-for-content-changed
这篇文章详细说明了contentchanged内容定义,采纳代码如下:
复制代码 代码如下:
jQuery.fn.watch = function( id, fn ) {
returnthis.each(function(){
var self = this;
var oldVal = self[id];
$(self).data(
'Watch_timer',
SetInterval(function(){
if(self[id] !== oldVal) {
fn.call(self, id, oldVal, self[id]);
oldVal = self[id];
}
},100)
);
});
returnself;
};
jQuery.fn.unwatch = function( id ) {
returnthis.each(function(){
clearinterval( $(this).data('watch_timer') );
});
};
创建自定义事件
复制代码 代码如下:
jQuery.fn.valuechange = function(fn) {
returnthis.bind('valuechange', fn);
};
jQuery.event.special.valuechange = {
setup: function() {
jQuery(this).watch('value', function(){
jQuery.event.handle.call(this, {type:'valuechange'});
});
},
teardown: function() {
jQuery(this).unwatch('value');
}
};
貌似这样的解决是完美的但是后续再继续查看到时候,发现有更简洁的方式,代码如下:
复制代码 代码如下:
var title = $("b.facility");
var title = $('#title');//the element I want to monitor
title.bind('domNodeInserted', function(e) {
alert('element now contains: ' + $(e.target).HTML());
});
感觉这应该是我需要代码,do it !fine
相关推荐
- jquery easyui中treegrid用法的简单实例 - Web前端
- jquery实现checkbox 全选/全不选的通用写法 - Web前端
- Jquery中ajax方法data参数的用法小结 - Web前端
- jquery获取元素索引值index()示例 - Web前端
- jQuery之字体大小的设置方法 - Web前端
- jquery实现动态菜单的实例代码 - Web前端
- jquery和雅虎的yql服务实现天气预报服务示例 - Web前端
- 在每个匹配元素的外部插入新元素的方法 - Web前端
- jQuery中bind,live,delegate与one方法的用法及区别解析 - Web前端
- jquery.cookie() 方法的使用(读取、写入、删除) - Web前端
- 网页前端技术排行
- 最近发表
-
- WordPress随机显示特色图片插件:Random Post Thumbnails
- KeePass实现Chrome浏览器自动填充密码方法一
- LNMP一键包nginx 301强制跳转到https教程
- KeePass实现Chrome浏览器自动填充密码方法二
- #建站# 免费的VPS管理软件Xshell8/Xftp8中文版下载
- 使用Xshell 8连接VPS教程_电脑登录vps的方法
- WordPress评论界面添加烟花????效果
- 不同浏览器书签同步方案:坚果云+Floccus_详细使用教程
- iOS端KeePassXC客户端APP:Strongbox Password Safe
- 给WordPress评论中的Gravatar头像图片添加ALT属性


