对js中回调函数的一些看法


Posted in Javascript onAugust 29, 2016

最近在忙公司android的项目,所以也就很少抽时间来写些东西了。刚闲下来,我就翻了翻之前看的东西。做了android之后更加感觉到手机端开发的重要性,现在做native App  和Web App是主流,也就是说现在各种基于浏览器的web app框架也会越来越火爆了,做js的也越来越有前途。我也决定从后端开发渐渐向前端开发和手机端开发靠拢,废话不说了,我们来切入正题“js的回调函数”相关的东西。

说起回调函数,好多人虽然知道意思,但是还是一知半解。至于怎么用,还是有点糊涂。网上的一些相关的也没有详细的说一下是怎么回事,说的比较片面。下面我只是说说个人的一点理解,大牛勿喷。我们来看一下一个粗略的一个定义“函数a有一个参数,这个参数是个函数b,当函数a执行完以后执行函数b。那么这个过程就叫回调。”,这句话的意思是函数b以一个参数的形式传入函数a并执行,顺序是先执行a ,然后执行参数b,b就是所谓的回调函数。我们先来看下面的例子。

function a(callback){
   alert('a');
   callback.call(this);//或者是 callback(), callback.apply(this),看个人喜好

  }
  function b(){
    alert('b');
  }
  //调用
  a(b);

这样的结果是先弹出 'a',再弹出‘b'。这样估计会有人问了“写这样的代码有什么意思呢?好像没太大的作用呢!”

是的,其实我也觉得这样写没啥意思,“如果调用一个函数就直接在函数里面调用它不就行了”。我这只是给大家写个小例子,做初步的理解。真正写代码的过程中很少用这样无参数的,因为在大部分场景中,我们要传递参数。来个带参数的:

function c(callback){
   alert('c');
   callback.call(this,'d');

  }
  
//调用
c(function(e){

  alert(e);
});

这个调用看起来是不是似曾相识,这里e参数被赋值为'd',我们只是简单的赋值为字符窜,其实也可以赋值为对象。Jquery里面是不是也有个e参数,下面我们就来讲讲
Jquery里面的e参数是如何被回调赋值的。

Jquery框架我想大家不陌生了,出来了好久,开发的时候都在用,比较简单,api网上搜起来很方便,上手快。在Jquery框架下,我们有时候要获取事件中的一些参数,比如我要获取当前点击的坐标,点击的元素对象。这个需求在Jquery里面好办  :

 

$("#id").bind('click',function(e){

//e.pageX ,e.pageY ,e.target.....各种数据

 });

 用起来倒是挺方便,其实这个e参数的赋值也是通过回调函数来实现的,这个参数是用回调参数给它赋予了一个对象值,仔细研究过JJquery源码的朋友应该发现了这一点。

还有Ajax里面   $.get('',{},function(data){})    data这个参数也是同样的原理。

我们来看看Jquery事件对象里面是怎么应用回调函数的。

为了方便,我简单的写了一下$相关的一些实现,之前写过“小谈Jquery”里面有比较接近框架实现的方法,我下面只是写一个简易的选择器。

<div id="container"  style="width:200px;height:200px;background-Color:green;">
</div>

<script>
   var  _$=function (id)
        { 
           this.element= document.getElementById(id); 
        }
    _$.prototype={
      bind:function(evt,callback)
      {
        var  that=this;
        if(document.addEventListener)
        {
          this.element.addEventListener(evt, function(e){
            callback.call(this,that.standadize(e));
          } ,false);
        }
        else if(document.attachEvent)
        {
          this.element.attachEvent('on'+evt,function(e){
            callback.call(this,that.standadize(e));
          });
        }
        else
          this.element['on'+evt]=function(e){
            callback.call(this,that.standadize(e));
          };
      },
      standadize:function(e){
         var evt=e||window.event;
         var pageX,pageY,layerX,layerY;
         //pageX 横坐标 pageY纵坐标  layerX点击处位于元素的横坐标  layerY点击处位于元素的纵坐标
         if(evt.pageX)
         {
           pageX=evt.pageX;
           pageY=evt.pageY;
         }
         else
         {
          pageX=document.body.scrollLeft+evt.clientX-document.body.clientLeft;
          pageY=document.body.scrollTop+evt.clientY-document.body.clientLTop;
         }
         if(evt.layerX)
         {

           layerX=evt.layerX;
           layerY=evt.layerY;
         }
         else
         {
           layerX=evt.offsetX;
           layerXY=evt.offsetY;
         }
         return {
          pageX:pageX,
          pageY:pageY,
          layerX:layerX,
          layerY:layerY
         }

      }


    }
    window.$=function(id)
    {
     return new _$(id);

    }


    $('container').bind('click',function(e){

      alert(e.pageX);
    });

    $('container1').bind('click',function(e){

       alert(e.pageX);
    });
</script>

这段代码我们主要看standadize函数的实现,兼容性的代码,就不多说了,返回的是一个对象

return {
pageX:pageX,
pageY:pageY,
layerX:layerX,
layerY:layerY
}

然后再看bind函数里面的代码    callback.call(this,that.standadize(e)),这段代码其实就是给e参数赋值了,是用callback回调实现的。

callback 函数被调用的时候传入的是匿名函数

function(e){

    }

而callback.call(this,that.standadize(e))相当于是执行了这么一段代码 

 

(function(e){
 
})(standadize(e))

 这也是Jquery用回调函数比较经典的地方,e参数就是这么被赋值的,说了这些你们也大概有个了解了,以及怎么使用了。

回调在各种框架中应用的比较多,有时候自己写一些东西的时候也可以根据实际情况用用看。

以上这篇对js中回调函数的一些看法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript 继承实现方法
Aug 26 Javascript
javascript 去字符串空格终极版(支持utf8)
Nov 14 Javascript
Javascript将string类型转换int类型
Dec 09 Javascript
jQuery中:first选择器用法实例
Dec 30 Javascript
关于RequireJS的简单介绍即使用方法
Oct 20 Javascript
jQuery插件fullPage.js实现全屏滚动效果
Dec 02 Javascript
JS简单实现滑动加载数据的方法示例
Oct 18 Javascript
原生JS与jQuery编写简单选项卡
Oct 30 jQuery
使用selenium抓取淘宝的商品信息实例
Feb 06 Javascript
vue用Object.defineProperty手写一个简单的双向绑定的示例
Jul 09 Javascript
vue slots 组件的组合/分发实例
Sep 06 Javascript
vue select 获取value和lable操作
Aug 28 Javascript
Web打印解决方案之普通报表打印功能
Aug 29 #Javascript
jQuery获取select选中的option的value值实现方法
Aug 29 #Javascript
js 判断各种数据类型的简单方法(推荐)
Aug 29 #Javascript
Web打印解决方案之证件套打的实现思路
Aug 29 #Javascript
浅谈js数据类型判断与数组判断
Aug 29 #Javascript
判断js的Array和Object的实现方法
Aug 29 #Javascript
基于MVC+EasyUI的web开发框架之使用云打印控件C-Lodop打印页面或套打报关运单信息
Aug 29 #Javascript
You might like
MVC模式的PHP实现
2006/10/09 PHP
ThinkPHP3.1.x修改成功与失败跳转页面的方法
2017/09/29 PHP
Laravel的Auth验证Token验证使用自定义Redis的例子
2019/09/30 PHP
JavaScript输出当前时间Unix时间戳的方法
2015/04/06 Javascript
JavaScript编写点击查看大图的页面半透明遮罩层效果实例
2016/05/09 Javascript
jQuery页面元素动态添加后绑定事件丢失方法,非 live
2016/06/16 Javascript
AngularJS使用ng-Cloak阻止初始化闪烁问题的方法
2016/11/03 Javascript
AngularJS实现DOM元素的显示与隐藏功能
2016/11/22 Javascript
jquery之基本选择器practice(实例讲解)
2017/09/30 jQuery
vue 表单输入格式化中文输入法异常问题
2018/05/30 Javascript
js html实现计算器功能
2018/11/13 Javascript
利用React Router4实现的服务端直出渲染(SSR)
2019/01/07 Javascript
Vue scrollBehavior 滚动行为实现后退页面显示在上次浏览的位置
2019/05/27 Javascript
利用Angular7开发一个Radio组件的全过程
2019/07/11 Javascript
jquery实现购物车基本功能
2019/10/25 jQuery
JS实现鼠标按下拖拽效果
2020/07/23 Javascript
手机浏览器唤起微信分享(JS)
2020/10/11 Javascript
[59:30]VG vs LGD 2019国际邀请赛淘汰赛 胜者组 BO3 第二场 8.22
2019/09/05 DOTA
python获取当前日期和时间的方法
2015/04/30 Python
Python设计模式编程中Adapter适配器模式的使用实例
2016/03/02 Python
Python探索之创建二叉树
2017/10/25 Python
python 日期排序的实例代码
2019/07/11 Python
CSS3 Columns分列式布局方法简介
2014/05/03 HTML / CSS
HTML最新标准HTML5总结(必看)
2016/06/13 HTML / CSS
加拿大便宜的隐形眼镜商店:Clearly
2016/09/15 全球购物
美国领先的礼品卡网站:GiftCards.com
2016/11/02 全球购物
美国班级戒指、帽子和礼服、毕业产品、年鉴:Balfour
2018/11/01 全球购物
Oasis服装官网:时尚女装在线
2020/07/09 全球购物
师德模范事迹材料
2014/06/03 职场文书
创先争优活动党员公开承诺书
2014/08/29 职场文书
交通局领导班子群众路线教育实践活动对照检查材料思想汇报
2014/10/09 职场文书
2014年图书馆个人工作总结
2014/12/18 职场文书
财务经理岗位职责范本
2015/04/08 职场文书
表扬稿表扬信的格式及范文
2019/06/24 职场文书
python 用递归实现通用爬虫解析器
2021/04/16 Python
Windows11插耳机没反应怎么办? win11耳机没声音的多种解决办法
2021/11/21 数码科技