用JavaScript封装bind函数
phpcn_u699
phpcn_u699 2017-03-06 13:16:07
0
2
790
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)); }}


      최신 다운로드
      더>
      웹 효과
      웹사이트 소스 코드
      웹사이트 자료
      프론트엔드 템플릿
      회사 소개 부인 성명 Sitemap
      PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!