zoukankan      html  css  js  c++  java
  • node.js学习笔记

    • node.js不能直接用import,至少在node v6的版本中,是不直接支持 import 语法的,也不支持 export,但是支持 require和exports
    • 首先我们应该来聊聊node的事件机制。
      你可曾使用过gulp,感受过其中的on('change')的强大?node.js中有个叫事件分发器的东西EventEmitter (待更)
      从http这个模块的角度讲,它有着data,end,error事件。
    • 其实所要做的,不过是实现非阻塞和同步
      我们做准备,做那些我们知道他们将要发生但是还未发生的事情,所谓未雨绸缪。
      我们不会一直等待一个事情结束,我们选择控制事件结束所要发生的事情。
    • Node通常不会直接返回数据,这样会导致阻塞,因为这样可能在等待某个资源的时候发生阻塞
    • Node对事件的定义
      1.发生一次的事件 res.on('end',callback)
      2.发生多次的事件req.on('data',callback)
      3.只产生一次回调(我们会遇见这种情况,只执行一次回调的情况,尽管有多次事件的返回) a.once('某次事件',callback)
    • 关于exports和require
      http://blog.csdn.net/chenyufeng1991/article/details/54807974
    • 关于exports和module.exports
      这是我的两种写法
    module.exports={
      // to do
    }
    exports.get_json_data=function(){
      // to do
    }
    

    先看这篇好文章: http://www.cnblogs.com/wbxjiayou/p/5767632.html
    其实,Module.exports才是真正的接口,exports只不过是它的一个辅助工具。最终返回给调用的是Module.exports而不是exports。
    所有的exports收集到的属性和方法,都赋值给了Module.exports。当然,这有个前提,就是Module.exports本身不具备任何属性和方法。如果,Module.exports已经具备一些属性和方法,那么exports收集来的信息将被忽略
    这就像是!!美女单身,你可以跑去追她,但是美女要是已经有了一个男朋友,你是不能加过去的!!!
    module.exports是真正的接口,exports只不过是它的辅助工具。推荐使用exports导出。

    • 关于express插件的安装,其实吧,如果自己配置express是不需要安装express-generator这个就像是Vue里面的Vue和Vue-cli的关系一样!!!

    因为express把命令行工具分离了出来,所以如果不安装express-generator的话,输入express的时候会显示找不到命令。
    npm install express -gd
    npm install -gd express-generator

    我们首先安装后node平台,单清晰地理解这一整个过程的大概框架。(具体情节这里不再阐述)。
    之后,创建一个文件夹,名为school,在这个文件夹里面创建:student.js ,teacher.js ,aclass.js ,index.js。

    • student文件内容如下:
    function add (student){
    	console.log('Add student:'+student);
    }
    exports.add=add;   //在这里暴露student的方法给其他js文件调用。
    
    • teacher文件内容如下
    function add (teacher){
    	console.log('Add Teacher:'+teacher);
    }
    exports.add=add;  //大致上和学生文件时一模一样的,只是为了理解大概过程而写,所以很简单,易看懂
    
    • aclass文件内容如下
    var student=require('./student');
    var teacher=require('./teacher');
    teacher.add('Scott');
    function add(teacherName,students){
    	teacher.add(teacherName);
    
    	students.forEach(function(item,index){
    		student.add(item);
    	});
    };
    // var a=['212','abac','2121fsf'];
    // add('hhh',a); 
    //这句话是我单独测试这个aclass功能用的,命令行进入当前文件夹,输入node aclass,发现可以执行出效果,
    //不过为了体现模块化,我们要将它暴露出接口,然后由其他文件中被调用
    exports.add=add;
    // module.exports=add;
    
    • 最后,是我们的入口文件,也是我们一直迟迟不X的原因(=。=),index.js
    // 这是个路口文件,我终于懂了它的方法,茅塞顿开
    var aclass=require('./aclass');
    aclass.add('xxx',['白富美','高富帅']);
    

    命令行进入所在文件夹,node index就能得到我们理想中的输出。

  • 相关阅读:
    关于HTML(七)--------HTML废弃的标签
    关于HTML(六)--------canvas
    抓包神器之Charles,常用功能都在这里了(转自https://blog.csdn.net/mxw2552261/article/details/78645118)
    混合开发的坑(7) ---输入文本时,键盘遮挡
    关于HTML(五)---------meta标签
    关于HTML(四)---------使用data-的好处
    关于HTML(三)---------xhtml和html的区别
    关于HTML(二)---------浏览器的标准模式和怪异模式
    关于HTML(一)---------HTML5新特性2
    关于HTML(一)---------HTML5新特性1
  • 原文地址:https://www.cnblogs.com/can-i-do/p/6979779.html
Copyright © 2011-2022 走看看