调用函数后加括号与不加括号的区别--需要立刻执行带括号,等待触发不带括号

今天在做表单验证时,用到失焦事件,但失焦后并没达到效果。于是有了该问题。

原文链接:http://t.csdn.cn/61idG

函数只要是要调用它进行执行的,都必须加括号。此时,函数实际上等于函数的返回值或者执行效果,当然,有些没有返回值,但已经执行了函数体内的行为,就是说,加括号的,就代表将会执行函数体代码。

不加括号的,都是把函数名称作为函数的指针,一个函数的名称就是这个函数的指针,此时不是得到函数的结果,因为不会运行函数体代码。它只是传递了函数体所在的地址位置,在需要的时候好找到函数体去执行。
 

function checkUsername() {
            alert("校验用户名");
            return true;
        }

        //校验密码
        function checkPassword() {
            alert("校验密码");
            return false;
        }

        $(function () {
            //当表单提交时,调用所有校验方法
            $("#registerForm").submit(function () {
                return checkUsername()&&checkPassword();
                //如果这个方法没有返回值,或者返回为true,则表单提交,如果返回为false,表单不提交
            });
            //当某一个组件失去焦点时调用对应的校验方法
            $("#username").blur(checkUsername());
        })

当失去焦点时,网页无反应。

checkUsername()去掉括号后,运行正确

//校验用户名
        function checkUsername() {
            alert("校验用户名");
            return true;
        }

        //校验密码
        function checkPassword() {
            alert("校验密码");
            return false;
        }

        $(function () {
            //当表单提交时,调用所有校验方法
            $("#registerForm").submit(function () {
                return checkUsername()&&checkPassword();
                //如果这个方法没有返回值,或者返回为true,则表单提交,如果返回为false,表单不提交
            });
            //当某一个组件失去焦点时调用对应的校验方法
            $("#username").blur(checkUsername);
        })

简单点说,带括号的是函数调用,直接执行函数;不带括号的是绑定事件,事件触发再执行。 复杂点说,带括号的是把返回值赋值给事件,不带括号的是把函数体所在地址位置赋值给事件。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值