通过js看类似C#中的回掉
2016-04-27 23:00
260 查看
我认为并行有两种形式,第一种是异步,第二种是多线程,目的都是为了实现并行,只不过异步和多线程都是手段而已
第一种异步
异步,执行完函数或方法后,不必阻塞性地等待返回值或消息,只需要向系统委托一个异步过程,那么当系统接收到消息时,系统会自动触发委托的异步过程,从而完成一个完整的流程
第二种多线程
多线程,由于同步函数在请求API数据的时候,由于网络等原因,不能很快的完成,因此会发生进程阻塞(直到本身函数执行完成,下面的函数才会执行),因此,往往是新建一个进程,让它执行这个过程,主线程管理用户界面,不会出现UI假死的情况
今天先说第一种,C#中都有异步方法,如下图中的Socket就是我去发送数据,我就不管了我继续做我下面的其他事情,如果我发送的数据得到了系统的回复,那么会自动触发SendCallback这个函数,我们在js中看看怎么理解什么叫“系统会自动触发委托的异步过程”这句话
![](https://images2015.cnblogs.com/blog/42037/201604/42037-20160427225544877-445010727.png)
JS DEMO
首先我在js中定义了一个游戏类叫GameControl,里面有个叫saveResult的方法
其次我又写了个saveGameResult保存游戏分数的方法,在这个方法里我又闭包包含了一个叫做alertGameEnd的方法
当我调用saveGameResult(99)的时候,因为99大于0会调用GameControl类里面的saveResult的方法,又因为99大于98,会调用alertGameEnd这个方法,且给alertGameEnd方法传递2个参数,一个是status,一个是message如下图所示
![](https://images2015.cnblogs.com/blog/42037/201604/42037-20160427225611892-791537509.jpg)
![](https://images2015.cnblogs.com/blog/42037/201604/42037-20160427225631955-1433056713.jpg)
![](https://images2015.cnblogs.com/blog/42037/201604/42037-20160427225642377-493855427.jpg)
跟上面的C#中的SendCallback类似,js 中先委托一个alertGameEnd方法,当满足一定条件时,就会调用alertGameEnd方法,就跟自动触发SendCallback一样
第一种异步
异步,执行完函数或方法后,不必阻塞性地等待返回值或消息,只需要向系统委托一个异步过程,那么当系统接收到消息时,系统会自动触发委托的异步过程,从而完成一个完整的流程
第二种多线程
多线程,由于同步函数在请求API数据的时候,由于网络等原因,不能很快的完成,因此会发生进程阻塞(直到本身函数执行完成,下面的函数才会执行),因此,往往是新建一个进程,让它执行这个过程,主线程管理用户界面,不会出现UI假死的情况
今天先说第一种,C#中都有异步方法,如下图中的Socket就是我去发送数据,我就不管了我继续做我下面的其他事情,如果我发送的数据得到了系统的回复,那么会自动触发SendCallback这个函数,我们在js中看看怎么理解什么叫“系统会自动触发委托的异步过程”这句话
![](https://images2015.cnblogs.com/blog/42037/201604/42037-20160427225544877-445010727.png)
JS DEMO
<script> //定义一个js类 var GameControl=(function(game){ game.GameAlert= function(){ alert('123'); } //保存分数 game.saveResult= function(scroe,callback){ //如果分数大于0了,调用传递进来的函数且给函数传递参数 if (scroe > 98) { if (typeof callback === "function") { callback({ "status": true, "message": "" }); } return; } } return game; })(GameControl || {}); //保存游戏分数方法 var saveGameResult = function (score) { var alertGameEnd = function(data) { if (data.status == true) { alert('游戏结束了'); } else { alert('游戏未结束'); } } //如果分数大于0了,调用GameControl类里面的saveResult方法去保存游戏分数,注意第二个参数是把方法传递进去了 if (score > 0) { GameControl.saveResult(score, alertGameEnd); } } //调用保存游戏分数方法 saveGameResult(99); </script>
首先我在js中定义了一个游戏类叫GameControl,里面有个叫saveResult的方法
其次我又写了个saveGameResult保存游戏分数的方法,在这个方法里我又闭包包含了一个叫做alertGameEnd的方法
当我调用saveGameResult(99)的时候,因为99大于0会调用GameControl类里面的saveResult的方法,又因为99大于98,会调用alertGameEnd这个方法,且给alertGameEnd方法传递2个参数,一个是status,一个是message如下图所示
![](https://images2015.cnblogs.com/blog/42037/201604/42037-20160427225611892-791537509.jpg)
![](https://images2015.cnblogs.com/blog/42037/201604/42037-20160427225631955-1433056713.jpg)
![](https://images2015.cnblogs.com/blog/42037/201604/42037-20160427225642377-493855427.jpg)
跟上面的C#中的SendCallback类似,js 中先委托一个alertGameEnd方法,当满足一定条件时,就会调用alertGameEnd方法,就跟自动触发SendCallback一样
相关文章推荐
- POJO与JSON的序列化与反序列化
- 通过js看类似C#中的回掉
- 字符串与json之间的相互转化
- flash和js通过什么类如何交互?
- jstree的基本使用例子
- json小计
- Javascript 将json字符串解析成js 对象的四种方法
- js map
- javascript实现jsonp跨域访问
- js中运算符&& 和 || 的使用记录
- javascript json prase get key by index get value by index
- JavaScript API 设计原则
- 将JavaScript 插入网页的方法
- JSP注释 声明 输出表达式 脚本
- JavaScript与HTML_DOM
- JSON.parse()和JSON.stringify()
- JavaScript语法
- JavaScript学习汇总
- (转载)Javascript 严格模式详解
- 78_Json解析