JavaScript通过事件代理高亮显示表格行的方法
作者:bea
本文实例讲述了JavaScript通过事件代理高亮显示表格行的方法。分享给大家供大家参考。具体实现方法如下: <!DOCTYPE html><html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>Highlight Rows</title><style type="text/c
本文实例讲述了JavaScript通过事件代理高亮显示表格行的方法。分享给大家供大家参考。具体实现方法如下:
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Highlight Rows</title>
<style type="text/css">
table {
background-color: lightgreen;
}
#third {
background-color: yellow;
}
</style>
</head>
<body>
<!-- Demonstrating "Event Delegation" to highlight table' rows
on mouseover.
Arguments can be passed via the delegate.
My site:andrew.dx.am -->
<table id="thetable" summary="highlight demo">
<tr><td>Just one</td><td>.. no another</td></tr>
<tr><td>Second</td><td>.. no another</td></tr>
<tr id="third"><td>A third</td><td>.. no another</td></tr>
<tr><td>Fourth for luck</td><td>.. no another</td></tr>
</table>
<script type="text/javascript">
var addEvent = function (elem, eventType, func) {
if ( elem.addEventListener )
addEvent = function (elem, eventType, func) {
elem.addEventListener(eventType, func, false);
};
else if ( elem.attachEvent )
addEvent = function (elem, eventType, func) {
elem.attachEvent('on' + eventType, func);
};
addEvent(elem, eventType, func);
};
var delegateEvent = function (elem, childElems, eventType, func, args) {
addEvent(elem, eventType, function (e) {
var evt = e || window.event;
var elem = evt.target || evt.srcElement;
if ( elem.nodeName.toLowerCase() == childElems.toLowerCase() ) {
func(elem, args);
}
});
};
function highlightRows(obj, args) {
if (args && args.over) {
obj.prevColour = obj.parentNode.style.backgroundColor;
obj.parentNode.style.backgroundColor = args.colour;
if (args.index && obj.title == "")
obj.title = "Row " + obj.parentNode.rowIndex;
} else {
obj.parentNode.style.backgroundColor = "";
if (obj.title.indexOf("Row ") + 1)
obj.title = "";
}
}
function init() {
delegateEvent(document.getElementById('thetable'), 'td', 'mouseover',
highlightRows, {'colour': 'lightblue', 'over': true,
'index': true});
delegateEvent(document.getElementById('thetable'), 'td', 'mouseout',
highlightRows, {'over': false});
}
addEvent(window, 'load', init);
</script>
</body>
</html>
希望本文所述对大家的javascript程序设计有所帮助。
有用 | 无用
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Highlight Rows</title>
<style type="text/css">
table {
background-color: lightgreen;
}
#third {
background-color: yellow;
}
</style>
</head>
<body>
<!-- Demonstrating "Event Delegation" to highlight table' rows
on mouseover.
Arguments can be passed via the delegate.
My site:andrew.dx.am -->
<table id="thetable" summary="highlight demo">
<tr><td>Just one</td><td>.. no another</td></tr>
<tr><td>Second</td><td>.. no another</td></tr>
<tr id="third"><td>A third</td><td>.. no another</td></tr>
<tr><td>Fourth for luck</td><td>.. no another</td></tr>
</table>
<script type="text/javascript">
var addEvent = function (elem, eventType, func) {
if ( elem.addEventListener )
addEvent = function (elem, eventType, func) {
elem.addEventListener(eventType, func, false);
};
else if ( elem.attachEvent )
addEvent = function (elem, eventType, func) {
elem.attachEvent('on' + eventType, func);
};
addEvent(elem, eventType, func);
};
var delegateEvent = function (elem, childElems, eventType, func, args) {
addEvent(elem, eventType, function (e) {
var evt = e || window.event;
var elem = evt.target || evt.srcElement;
if ( elem.nodeName.toLowerCase() == childElems.toLowerCase() ) {
func(elem, args);
}
});
};
function highlightRows(obj, args) {
if (args && args.over) {
obj.prevColour = obj.parentNode.style.backgroundColor;
obj.parentNode.style.backgroundColor = args.colour;
if (args.index && obj.title == "")
obj.title = "Row " + obj.parentNode.rowIndex;
} else {
obj.parentNode.style.backgroundColor = "";
if (obj.title.indexOf("Row ") + 1)
obj.title = "";
}
}
function init() {
delegateEvent(document.getElementById('thetable'), 'td', 'mouseover',
highlightRows, {'colour': 'lightblue', 'over': true,
'index': true});
delegateEvent(document.getElementById('thetable'), 'td', 'mouseout',
highlightRows, {'over': false});
}
addEvent(window, 'load', init);
</script>
</body>
</html>
希望本文所述对大家的javascript程序设计有所帮助。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- jQuery实现返回顶部效果的方法
- jquery读取xml文件实现省市县三级联动的方法
- Jquery动态添加输入框的方法
- jquery任意位置浮动固定层插件用法实例
- JQuery控制Radio选中方法分析
- 究竟什么是Node.js?Node.js有什么好处?
- js实现发送验证码后的倒计时功能
- JS实现两表格里数据来回转移的方法
- 原生JS和JQuery动态添加、删除表格行的方法
- jQuery实现html表格动态添加新行的方法
- jquery实现用户打分评分特效
- nodejs实现遍历文件夹并统计文件大小
- 用Node.js通过sitemap.xml批量抓取美女图片
- javascript转换静态图片,增加粒子动画效果
- jQuery实现限制textarea文本框输入字符数量的方法
- nodejs实现获取某宝商品分类
- Nodejs实现批量下载妹纸图
- javascript实现行拖动的方法
- JavaScript操作Cookie方法实例分析