zoukankan      html  css  js  c++  java
  • nodejs之入门

    一、安装:

    去官网下载稳定版本,安装即可。

     安装后执行node -v,显示node版本,然后输入node回车,然后输出console.log(111);,正常输出即可。

    二、入门介绍:

    1、nodejs是一门后端语言,是基于chrome的V8引擎,JavaScript运行在服务器平台上的一门语言。简单来说就是能够运行于服务器的JavaScript。

    2、nodejs系统是基于CommonJS规范,CommonJS规范是同步加载模块,而AMD规范是异步加载模块。

    3、nodejs支持部分es6语法,在文件顶部添加"use strict"即可。

    4、直接在命令行下执行node 文件名字即可,执行该js文件

    5、模块的导出和引入:

    (1)、模块分类:

    • 原生(核心)模块:该模块在Node.js源代码编译的时候编译进了二进制执行文件,加载的速度最快,例如http、fs等
    • 文件模块:文件模块是动态加载的,加载速度比原生模块慢。

    (2)、模块的导出:module.exports 或者 exports

    "use srict";
    
    function add(a, b) {
        return a + b;
    }
    // 此方法导出,引入后的直接就是add函数,可以直接使用
    module.exports = add;
    // 此两种方法导出,引入后的是一个对象,对象有一个方法属性add,通过xxx.add的方法使用
    exports.add = add;
    module.exports = add;

    module.exports 和 exports的区分:每个模块js文件被nodejs封装后,都会存在两个变量module和exports。

    module是一个对象,有一个对象属性exports,即module.exports,其初始值为一个空对象。

    然后exports指向module.exports的引用,即exports = module.exports。

    最后require每次引入的都是module.exports,而不是exports,所以我们对module.exports直接赋值或者添加属性都可以正常导出,我们为exports添加属性也是可以的,因为exports指向module.exports,

    但是我们为exports直接赋值是不可以正常导出的,因为此行为导致exports不在指向module.exports,module.exports根本不受任何影响,最后导出的modulee.exports是一个空对象。

    (3)、模块的引入:require(参数)

    参数共四种:

    • http、fs、path等原生模块(直接通过名称引入)     const fs = require('fs'); 
    • ./mod 或 ../mod,相对路径的文件模块(通过相对路径引入)     const add = require('./math/add.js'); (其中.js后缀可以省略,默认即是js文件)
    • /pathtomodule/mod,绝对路径的文件模块(通过绝对路径引入)     const add = require('E:/nodejs/math/add.js'); 
    • react,文件模块(在node_module中寻找)(通过名称引入)   const postcss = require('postcss'); 

    引入流程:

    Node.js系统针对原生模块的文件模块存在缓存机制,当我们第一次引入模块后,便对该模块进行缓存,我们再次引入该模块时,直接从缓存获取使用。

    所以引入一个模块mode的流程就是,先区分mod是原生模块还是文件模块,然后到对应模块缓存中查看有没有该mod,如果有直接获取使用,如果没有则正常引入,然后缓存该mod。

    6、nodejs的包管理工具npm

    npm一些命令:

    npm init:初始化包,帮用户在当前目录生成一个package.json文件

    npm install:嵌入包模块(可以先嵌入cnpm,然后使用cnpm install,淘宝镜像,比npm快一些)

    • npm install 模块名:安装本地模块
    • npm install 模块名 -g: 安装全局模块
    • npm install 模块名 --save: 把安装的模块更新到package.json中
    • npm install 模块名 -dev:模块安装到package.json的devDependencies中

    npm uninstall 模块名:卸载模块

    package.json

    {
        // 包的名字
        "name": "mypack",
        // 包的版本号
        "version": "1.0.0",
        // 木块被引用的入口文件,默认为index.js
        "main": "index.js"
        // 项目运行所依赖的模块
        // "dependencies": {},
        // 指定项目开发所需要的模块
        // "devDependencies": {},   
    }

    /*
    版本号:
    指定版本:1.2.1,遵循"大版本.中版本.小版本"
    波浪号(tilde)+指定版本:~1.2.2,表示安装1.2.x的最新版本(不低于1.2.2),但是不安装1.3.x,安装时不改变大版本号和次要版本号
    插入号(caret)+指定版本:^1.2.2,表示安装1.x.x的最新版本(不低于1.2.2),但是不安装2.x.x,安装时不改变大版本号(如果大版本号是0,则和波浪号行为相同,因为此时处于开发阶段,即使次要版本号该改变,也可能带来程序的不兼容)
    lateest:安装最新版本
    */

    三、例子demo

    exam01:

    // add.js
    "use srict";
    
    module.exports = function (a, b) {
        return a + b;
    }
    // index.js
    "use srict";
    
    const add = require('./add');
    
    console.log(add(11, 22)); // 33

    在index.js目录下执行node index,打印结果33即可

    ----------------------------------end

  • 相关阅读:
    [刷题] PTA 7-32 说反话-加强版
    [算法] 堆
    [笔记] 《c++ primer》显示器程序 Chapter7
    [笔记] 《c++ primer》书店程序 Chapter7
    [c++] <vector>
    [笔记] 《c++ primer》书店程序 Chapter2
    [笔记] 《c++ primer》书店程序 Chapter 1
    253. Meeting Rooms II
    461. Hamming Distance
    252. Meeting Rooms
  • 原文地址:https://www.cnblogs.com/Walker-lyl/p/7249080.html
Copyright © 2011-2022 走看看