javascript - js jq 中的作用域问题
黄舟
黄舟 2017-04-10 17:16:54
[JavaScript讨论组]

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml&quot; xml:lang="en">
<head>

<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<title>作用域</title>
<style>

p{ width: 300px; height: 300px; margin: 0 auto; background: pink;}

</style>
<script src='jquery-1.11.2.min.js'></script>
<script>

$(function() {
    
var a=true;
if(a==true){
    alert('ok')
    $('p').click(function(event) {
        alert('第一次'+a);
        a=!a;
        alert('第1.1次'+a);
            $('p').click(function(event) {
            alert('第二次'+a)
        });
    });
}

});

</script>

</head>
<body>

<p></p>

</body>
</html>

不知道为什么当a是false的时候 第一个点击事件也能执行

黄舟
黄舟

人生最曼妙的风景,竟是内心的淡定与从容!

全部回复(2)
PHP中文网

你的代码逻辑稍有问题,看:
p 点击的时候,如果 a 为真,则····
你的:
a 为真的时候,点击 p 则····

这样试试:

var a = true,
    $test = $('p'); 
$test.click(function (e) {
    e.preventDefault();
    if (a) {
        // 执行一次
        console.log('第一次' + a);

        // 更改变量的值 a = false;
        a = !a;

        // 继续执行,输出:第1.1次false
        console.log('第1.1次' + a);
    } else {
        // 点击无效
        console.log('全局变量已更改,点击无效');
    }

    // 禁止穿透执行
    e.stopPropagation();
    return false;
});
PHP中文网

第一次进去 进行了事件绑定

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

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