用JavaScript封装bind函数
phpcn_u699
phpcn_u699 2017-03-06 13:16:07
0
2
859
function bind(fn, obj) {  
  return function() {    
    return fn.apply(obj, arguments);    }}

我的问题是:

1.能不能写成像下面这样

function bind(fn, obj) {  
  return fn.apply(obj, arguments);}

2.如果不能,是为什么,这样写的话与第一段代码有什么区别,会造成什么问题

3.能不能写个栗子举例一下


phpcn_u699
phpcn_u699

모든 응답(2)
数据分析师

JavaScript를 사용하여 바인딩 기능 캡슐화 - PHP 중국어 웹사이트 Q&A - JavaScript를 사용하여 바인딩 기능 캡슐화 - PHP 중국어 웹사이트 Q&A

둘러보고 배워보세요.

巴扎黑

1.不能

2.因为你这个样子,就等于直接执行了fn,而不是生成一个可执行的函数。

3.栗子:

错误栗子:

function bind(fn, obj) {  
 return fn.apply(obj, arguments);}function func(){  
 console.log(this.a);}// 期望结果是 bind(func, { a:1 })() 输出1bind(func, { a:1 }); // 直接输出1

新鲜可食的栗子:

Function.prototype.bind = Function.prototype.bind || function bind(context, ...args){  
 let fn = this;  
 return function(...newArgs){      fn.apply(context, [].concat(args, newArgs));   }}


최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿