• Node.js 笔记02


    一、关于命令

    常用命令:

    dir 列出当前目录下面所有的文件
    cd 目录名  进入到指定的目录,. 当前目录,  .. 进入上级目录,cd . 当前目录, cd .. 上级目录
    md 目录名  创建文件夹
    rd 目录名   删除文件夹
    cd.>文件名.后缀名  创建文件,cd.>a.txt
    del 文件名   删除文件
    cls   清除屏幕,
    exit  退出命令行
    
    

    二、进程和线程

    请参考python学习笔记中的线程和进程

    进程:我们写的代码和程序都是放在进程里面的, 相当于工厂中的车间;

    线程:计算机中的最小计算单位, 负责执行进程中的程序,相当于车间中的一条条流水线。

    单线程:js是单线程,时间片分割

    多线程:根据任务决定开启几条线程

    Node服务器,是单线程,但是很健壮, 后台拥有一个I/O线程池进行调度,分布式服务器部署。

    三、安装Node.js

    安装就是官网下,然后下一步下一步,安装完成后会自动配置环境变量,如果不行就自己配置一下,完成后 node -v 一下,显示版本,说明安装成功了。

    使用:

    在webstorm 里创建一个 js文件,点击运行即可,如果报错 报错: Program path not specified

    这样设置:

    设置完成后如果不行,就重启一下

    四、Node开发模块化

    • 在Node.js 中,从文件角度看, 每个JS文件就是一个模块; 从结构看, 多个JS文件之间可以相互require, 共同实现了一个功能, 这整体上也是一个模块

    • 一个模块中定义的变量, 函数等, 都只能在这个文件内部有效; 当需要从此JS文件外部引用这些变量, 函数时, 必须使用exports进行暴露, 使用者通过require引用

    • 在Node中,每一个js文件中的js代码都是独立运行在一个小闭包中, 而不是全局作用域,所以一个模块的中的变量和函数在其他模块中无法访问,即 全局变量私有化, 避免全局污染

    myFun.js ,这是封装好的模块

    // 求和
    exports.sum = (...numbers)=>{
        let result = 0;
        numbers.forEach((number)=>{
            result += number;
        });
    
        return result;
    }
    
    // 求平均数
    exports.avg = (...numbers)=>{
        let result = 0;
        numbers.forEach((number)=>{
            result += number;
        });
    
        return result/numbers.length;
    }
    
    exports.name = 'gudon';
    // module.exports.name = 'gudon'; 
    // 一般还是使用 module.exports.xxx = xxx 吧,区别在下面总结。
    
    

    test.js: 在 tset.js 中调用

    let func = require('./myFun.js')  //当前文件夹, ./ 必须要加
    
    console.log(func.sum(1, 2, 3, 4, 5));  // 15
    console.log(func.avg(1, 2, 3, 4, 5));  // 3
    console.log(func.name);  // gudon
    

    node.js 有内建模块,底层由C++编写,我们自己可以写文件模块,如 myFun.js

    exports 和 require:这两个其实是函数参数,

    1. 当node在执行模块中的代码时,它会首先在代码的最顶部,添加如下代码 function (exports, require, module, ____filename, ____dirname) {

    2. 在代码的最底部,添加 }

    3. 所以模块中的代码都是包装在一个函数中执行的,并且在函数执行的同时传递进了5个实参:
      exports: 该对象用来将函数内部的局部变量或局部函数暴露到外部
      require: 用来引入外部的模块
      module: 代表的是当前模块本身, exports就是module的属性; 我们既可以使用 exports 导出,也可以使用module.exports导出
      __filename: 当前模块的完整路径

      __dirname: 当前模块所在文件夹的完整路

    五、exports 和 module.exports的区别

    1. 值类型和引用类型

    2、

    exports只能使用.语法来向外暴露内部变量:exports.xxx = xxx;

    module.exports既可以通过.语法,也可以直接赋值一个对象:

    • module.exports.xxx = yyy;
    • module.exports = {xxx: yyy};

    六、包和包管理器

    1.包(package)

    CommonJS规范:

    CommonJS规范的提出,主要是为了弥补JavaScript没有模块化标准的缺陷.

    CommonJS规范为JS希望JS能够在任何地方运行

    CommonJS的包规范允许我们将一组相关的模块组合到一起,形成一组完整的工具, 这组工具就叫做包。

    包结构:(实际上就是一个压缩文件,解压以后还原为目录)

    package.json 描述文件
    bin 可执行二进制文件
    lib js代码
    doc 文档
    test 单元测试

    包描述文件 package.json:描述包的相关信息,以供外部读取分析,它是一个JSON格式的文件 – package.json, 位于包的根目录下,描述信息比如有:

    name、description、version、keywords、maintainers、contributors、bugs、licenses、repositories、dependencies、homepage、os、cpu、engine、builtin、directories、implements、scripts、author、bin、main、devDependencies

    • package.json文件中, 不能加入任何注释

    2.包管理器(NPM)

    Node Package Manager, 就像是360软件管家一样

    另外,处理 npm,还有 Yarm

    Yarn 是 Facebook, Google, Exponent 和 Tilde 开发的一款新的 JavaScript 包管理工具。目的是解决这些团队使用 npm 面临的少数问题,及npm的问题:安装的时候无法保证速度/一致性,安全问题,因为 npm 安装时允许运行代码。但是npm 会进行一些更新来完善的。

    常用命令:
    npm –v 查看版本
    npm version 查看所有模块的版本
    npm search 包名 / 部分包名 搜索包
    npm init 初始化package.json文件
    npm install / i 包名 安装包,在外部使用,在webStorm中使用
    npm remove / r 包名 删除包
    npm install / i 包名 --save 安装包并添加到依赖中
    npm install 根据package.json下载当前项目所依赖的包,npm install bootstrap --save 安装 bootstrap包,安装完后 package.json 的 dependencies 会有显示,也可以在 package.json里删除或增加,然后 npm install 来更新包。npm install bootstrap --save-dev ,这样安装的话,就是在开发过程中可以用,上线后就不用了,这样添加后, package.json 会在

    "devDependencies": {
      "bootstrap": "^4.1.3"
    }
    

    里出现。

    npm install 包名 -g 全局安装包, 用于一些编译根据, 比如: gulp, webpack等

    另外:如果在页面中引入node_modules中某个模块, 优先从当前目录引入, 如果没有, 则往上级查找, 直到根目录

    CNPM:一个完整 npmjs.org 镜像,你可以用此代替官方版本(只读),同步频率目前为 10分钟 一次以保证尽量与官方服务同步,https://npm.taobao.org/

    使用方式:npm install -g cnpm --registry=https://registry.npm.taobao.org

  • 相关阅读:
    浅谈隔板法
    最短路spaf及dijkstra模板
    P1219 最优贸易
    P1211 街道赛跑
    图结构模板
    P1218 过路费
    使用Asp.net Identity 创建用户 、登录代码
    asp.net identity 介绍
    响应式图像
    glyphicon 图标的使用
  • 原文地址:https://www.cnblogs.com/friday69/p/10092374.html
Copyright © 2020-2023  润新知