今天在做表单验证时,用到失焦事件,但失焦后并没达到效果。于是有了该问题。
函数只要是要调用它进行执行的,都必须加括号。此时,函数实际上等于函数的返回值或者执行效果,当然,有些没有返回值,但已经执行了函数体内的行为,就是说,加括号的,就代表将会执行函数体代码。
不加括号的,都是把函数名称作为函数的指针,一个函数的名称就是这个函数的指针,此时不是得到函数的结果,因为不会运行函数体代码。它只是传递了函数体所在的地址位置,在需要的时候好找到函数体去执行。
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);
})
简单点说,带括号的是函数调用,直接执行函数;不带括号的是绑定事件,事件触发再执行。 复杂点说,带括号的是把返回值赋值给事件,不带括号的是把函数体所在地址位置赋值给事件。