javascript - 若干个同名方法同时存在也可以被执行是什么原因?
ringa_lee
ringa_lee 2017-04-11 11:05:34
[JavaScript讨论组]
<p onclick="test({i});">test {i}</p>

<script>
function test(i) {
    alert(i);
}

将以上代码循环到页面上显示,如:

<?php for($i=0; $i<10; $i++): ?>
    ...上面那段代码...
<?php endfor; ?>

感到有些意外,这时页面上已经同时存在10个相同的test方法了,当点击某个p时,居然会执行对应的test方法,而且都正确地把i给打印出来了,有大神深究过为什么吗?

ringa_lee
ringa_lee

ringa_lee

全部回复(3)
伊谢尔伦

每一次for循环打印一个同名的js方法,就会重写一次,所以以最后一次为准.

如:

function test(){
    alert(1);
}
function test(){
    alert(2);
}

这时候会执行后一个test(),alert(2),第一个就会被覆盖,所以你的代码中test()执行的是最后一次重写的test().
而你for循环的变量i每次循环都是不一样的,执行的结果就是test(i),即alert(i).

注意:在javascript中如果定义了2个或2个以上的相同名字的函数,则只有最后定义的函数才有效。

PHP中文网

test函数是相同的,但你绑定的onclick事件处理函数传入的参数i是不同的啊

巴扎黑

就是一直调用一个方法而已阿。

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

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