搜索
javascript - 请看下这段代码中函数的问题
PHPz
PHPz 2017-04-11 12:59:45
[JavaScript讨论组]
var trs = document.getElementsByTagName('tr');
for(var i = 0;i < trs.length;i++){       
        trs[i].onmouseover = function(){
            this.style.backgroundColor = 'grey';
        }
        trs[i].onmouseout = function(){
            this.style.backgroundColor = 'white';
        }       
}

请问函数中的this为什么不能换成trs[i]

PHPz
PHPz

学习是最好的投资!

全部回复(5)
ringa_lee

如果函数中的this换成trs[i],对应的绑定事件触发时,i已经变成trs.length了,这样就不是对应的元素了。

巴扎黑

闭包问题呀..

PHP中文网
因为换成i,最终都是执行trs[trs.length]这个东西啦,闭包问题;
直接this多好
PHP中文网

i会停留在最终值trs.length上
于是变成了hover只改变trs[trs.length]的样式
当然,这个元素是没有的,index溢出

ringa_lee

楼上讲的对,就是for循环执行完了,i变成了trs.length。此时你再去触发函数,显然就不是你想要的当前元素背景变色了

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号