关于语法,就不在这里多说了,有兴趣的同学可以看这里
https://github.com/nswbmw/N-blog/wiki/_pages ,或这里
http://www.nodebeginner.org/index-zh-cn.html。
说道NodeJS,很多人都会提到它的高性能,一方面,它使用了V8作为Javascript引擎,同时,它还是基于事件驱动,非阻塞I/O.
打个比方,前台向服务器发起了一次get请求,请求一个index.html页面,服务器收到请求后,会到磁盘去读取index.html文件,在读取的过程中,也就是访问I/O的过程中,服务器不会傻傻的等待着数据的返回,而是监听着下一次的请求,磁盘这边呢,等到数据访问完毕,会回调一个在请求读取数据时传递过来的回调函数,然后由回调函数来反馈给客户端结果。
在这里,函数作为了一等公民,以信使的方式在方法间穿梭。回调函数也算是nodejs中的一大特色吧。几乎nodejs提供的每个方法都有一个函数作为参数。说到这里,可能会有很多同学对回调函数不甚了解,下面就来具体地说一下回调函数。
先用Ajax举个例子:
$.post('/url', {name:'XiaoMing'}, function(data){ console.log('收到响应');//1 }); console.log('ajax发送结束');//2
看到这里,这两个console.log()的打印顺序是怎样的呢?
实际情况是,先执行的2,后执行的1;
也就是说发送完post请求后,不会等待这服务器响应完毕后再继续执行代码,而是再传递过一个function过去,等到数据请求完毕,再来回调这个function,在这里,这个function就是个回调函数。
再有,比如笔者在访问Parse云端数据库的时候,有一个请求数据的操作:
function visit_database(callback){ var need_data = null; var LessonObj = Parse.Object.extend('Lesson'); var LessonQuery = new Parse.Query(LessonObject); LessonQuery.get(uuid, { success: function(data){ need_data = data; callback(data.get('name')); }, error: function(data,error){ console.log('error' + error); } }); return need_data; }
如果想在另一个函数中使用visit_database()函数的返回值,直接这样写:
function use_data(){ var data = visit_database(); }
是得不到从数据库中查询出来的data的,因为这是一个异步的过程:在执行查询的时候,visit_database()就已经把返回值返回给use_data()中的data变量了,因此这个时候是什么也没有的,那么如果想要得到这个数据呢;就需要把use_data作为回调函数传入到visit_database函数中去,那就是这样做:
function use_data(a){ var data = a; } visit_database(use_data);
这样use_data函数被传入到visit_database方法内部,在访问数据成功后来回调use_data函数。