扫码关注官方订阅号
var onSubmit = AppReady.startLogin(userInfo);
这样就会执行一遍 怎么样不执行呢?
ringa_lee
赋值:
var onSubmit = AppReady.startLogin;
想调用时:
onSubmit(userInfo);
var onSubmit = AppReady.startLogin.bind(AppReady)
上面两个回答都没考虑到在 startLogin 可能会调用 this
var onSubmit = AppReady.statLogin;
首先这是一个赋值表达式,如果右边的方法执行没有返回任何结果或者返回空就像这样:return,那就是undefined。如果是这样:return "shjdshajdhaj"(返回基本类型值)或者返回引用类型值 return {fn:function(a){console.log(a)}}->返回一个对象的引用(值为指针)。bind不是调用this,而是改变this指向,返回一个“新”函数(仅仅this指向改变):var x="y_man";var a={x:"x_man"}function changethis(a){console.log(this.x,a)}window.changethis.bind(a)(x);或者这样:window.changethis.bind(a,x)();或者这样:changethis.bind(a)(x);
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
扫描下载App
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
赋值:
想调用时:
上面两个回答都没考虑到在 startLogin 可能会调用 this
var onSubmit = AppReady.statLogin;
首先这是一个赋值表达式,如果右边的方法执行没有返回任何结果或者返回空就像这样:return,那就是undefined。如果是这样:return "shjdshajdhaj"(返回基本类型值)或者返回引用类型值 return {fn:function(a){console.log(a)}}->返回一个对象的引用(值为指针)。bind不是调用this,而是改变this指向,返回一个“新”函数(仅仅this指向改变):
var x="y_man";
var a={
x:"x_man"
}
function changethis(a){
console.log(this.x,a)
}
window.changethis.bind(a)(x);
或者这样:window.changethis.bind(a,x)();
或者这样:changethis.bind(a)(x);