javascript中利用柯里化函数实现bind方法【推荐】


Posted in Javascript onApril 29, 2016

• 柯理化函数思想:一个js预先处理的思想;利用函数执行可以形成一个不销毁的作用域的原理,把需要预先处理的内容都储存在这个不销毁的作用域中,并且返回一个小函数,以后我们执行的都是小函数,在小函数中把之前预先存储的值进行相关的操作处理即可;

• 柯里化函数主要起到预处理的作用;

• bind方法的作用:把传递进来的callback回调方法中的this预先处理为上下文context;

/**
* bind方法实现原理1
* @param callback [Function] 回调函数
* @param context [Object] 上下文
* @returns {Function} 改变this指向的函数
*/
function bind(callback,context) {
  var outerArg = Array.prototype.slice.call(arguments,2);// 表示取当前作用域中传的参数中除了fn,context以外后面的参数;
  return function (){
    var innerArg = Array.prototype.slice.call(arguments,0);//表示取当前作用域中所有的arguments参数;
    callback.apply(context,outerArg.concat(innerArg));
  }
}
/**
* 模仿在原型链上的bind实现原理(柯理化函数思想)
* @param context [Object] 上下文
* @returns {Function} 改变this指向的函数
*/
Function.prototype.mybind = function mybind (context) {
  var _this = this;
  var outArg = Array.prototype.slice.call(arguments,1);
  // 兼容情况下
  if('bind' in Function.prototype) {
    return this.bind.apply(this,[context].concat(outArg));
  }
  // 不兼容情况下
  return function () {
    var inArg = Array.prototype.slice.call(arguments,0);
    inArg.length === 0?inArg[inArg.length]=window.event:null;
    var arg = outArg.concat(inArg);
    _this.apply(context,arg);
  }
}

以上这篇javascript中利用柯里化函数实现bind方法【推荐】就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
兼容IE和FF的js脚本代码小结(比较常用)
Dec 06 Javascript
JS判断对象是否存在的10种方法总结
Dec 23 Javascript
js修改原型的属性使用介绍
Jan 26 Javascript
Javascript中的关键字和保留字整理
Oct 16 Javascript
JavaScript程序设计之JS调试
Dec 09 Javascript
原生js实现倒计时--2018
Feb 21 Javascript
js数字计算 误差问题的快速解决方法
Feb 28 Javascript
JS 学习总结之正则表达式的懒惰性和贪婪性
Jul 03 Javascript
javascript获取图片的top N主色值方法详解
Jan 26 Javascript
vscode中vue-cli项目es-lint的配置方法
Jul 30 Javascript
jQuery事件多次绑定与解绑问题实例分析
Feb 19 jQuery
基于Node的Axure文件在线预览的实现代码
Aug 28 Javascript
jQuery Ajax 实例代码 ($.ajax、$.post、$.get)
Apr 29 #Javascript
一个字符串中出现次数最多的字符 统计这个次数【实现代码】
Apr 29 #Javascript
JS弹出层遮罩,隐藏背景页面滚动条细节优化分析
Apr 29 #Javascript
老生常谈遮罩层 滚动条的问题
Apr 29 #Javascript
弹出遮罩层后禁止滚动效果【实现代码】
Apr 29 #Javascript
一系列Bootstrap导航条使用方法分享
Apr 29 #Javascript
Bootstrap实现下拉菜单效果
Apr 29 #Javascript
You might like
phpMyAdmin 安装教程全攻略
2007/03/19 PHP
基于PHP后台的Android新闻浏览客户端
2016/05/23 PHP
PHP网站自动化配置的实现方法(必看)
2017/05/27 PHP
php检测mysql表是否存在的方法小结
2017/07/20 PHP
关于laravel框架中的常用目录路径函数
2019/10/23 PHP
类似CSDN图片切换效果脚本
2009/09/17 Javascript
JS 判断undefined的实现代码
2009/11/26 Javascript
使用 Node.js 做 Function Test实现方法
2013/10/25 Javascript
node.js中的fs.utimesSync方法使用说明
2014/12/15 Javascript
Javascript基础教程之数据类型转换
2015/01/18 Javascript
基于JavaScript实现瀑布流效果(循环渐近)
2016/01/27 Javascript
JS实现兼容各种浏览器的获取选择文本的方法【测试可用】
2016/06/21 Javascript
防止Node.js中错误导致进程阻塞的办法
2016/08/11 Javascript
微信小程序 Template详解及简单实例
2017/01/05 Javascript
JavaScript日期对象(Date)基本用法示例
2017/01/18 Javascript
浅谈Vue SSR 的 Cookies 问题
2017/11/20 Javascript
写gulp遇到的ES6问题详解
2018/12/03 Javascript
Electron 调用命令行(cmd)
2019/09/23 Javascript
[51:17]Mski vs VGJ.S Supermajor小组赛C组 BO3 第三场 6.3
2018/06/04 DOTA
Python 文件重命名工具代码
2009/07/26 Python
Python解析树及树的遍历
2016/02/03 Python
Python中logging实例讲解
2019/01/17 Python
python二进制读写及特殊码同步实现详解
2019/10/11 Python
使用darknet框架的imagenet数据分类预训练操作
2020/07/07 Python
AmazeUI中模态框的实现
2020/08/19 HTML / CSS
四年级下册教学反思
2014/02/01 职场文书
小班重阳节活动方案
2014/02/08 职场文书
竞选班干部的演讲稿
2014/04/24 职场文书
保证书范文大全
2014/04/28 职场文书
社区健康教育工作方案
2014/06/03 职场文书
党的群众路线教育实践活动宣传标语口号
2014/06/06 职场文书
公安机关正风肃纪剖析材料
2014/10/10 职场文书
2015年城市管理工作总结
2015/05/23 职场文书
药房管理制度范本
2015/08/06 职场文书
党员干部学习十八届五中全会精神心得体会
2016/01/05 职场文书
Go语言编译原理之源码调试
2022/08/05 Golang