美文网首页前端JavaScript
node简单了解(1)

node简单了解(1)

作者: 晚月川 | 来源:发表于2020-05-02 10:41 被阅读0次

    node开发

    • 为什么要学习服务器端开发基础?

      • 能够和后端程序员更加紧密配合
      • 网站业务逻辑前置,学习前端技术需要后端技术支撑(AJAX)
      • 扩展知识视野,能够站在更高的角度审视整个项目
    • 服务器端开发要做的事情

      • 实现网站的业务逻辑
      • 数据的增删改查
    • 为什么选择Node?

      • 使用JavaScript语法开发后端应用
      • 一些公司要求前端工程师掌握Node开发
      • 生态系统活跃,有大量开源库可以使用
      • 前端开发工具大多基于Node开发
    • Node是什么?

      • Node是一个ChromeV8引擎的JavaScript代码运行环境
        • 浏览器(软件):能够运行JavaScript代码,浏览器就是JavaScript代码的运行环境
        • Node(软件):能够运行JavaScript代码,Node就是JavaScript代码的运行环境

    Node.js运行环境安装

    官网:https://node.js.org/en/

    • LTS = Long Term Support 长期支持版,稳定版
    • Current

    Node环境安装失败解决办法

    • 错误代码:2502、2503(失败原因:系统账户权限不足)解决办法:
      • 以管理员身份运行powershell命令工具
      • 输入运行安装包命令msiexec/package node安装包位置\安装包名称
    • 执行命令报错(失败原因:Node安装目录写入环境变量失败)
      • 解决办法:将Node安装目录添加到环境变量中
    • 系统环境变量PATH的作用
      • 存储系统中的目录,在命令行中执行命令的时候系统会自动去这些目录中查找命令的位置

    Node.js快速入门

    • JavaScript由三部分组成:ECMAScript、DOM、BOM
    • Node.js是由ECMAScript及Node环境提供的一些附加API组成的,包括文件、网络、路径等等一些更加强大的API

    Node.js基础语法:所有的ECMAScript语法在Node环境中都可以使用

    Node.js模块化开发

    JavaScript开发弊端:JavaScript在使用时存在两大问题,文件依赖命名冲突

    • 一个功能就是一个模块,多个模块可以组成完整的应用,抽离一个模块不会影响其它功能的运行

    Node.js模块化开发规范:

    • Node.js规定一个JavaScript文件就是一个模块,模块内部定义的变量和函数默认情况下在外部无法得到
    • 模块内部可以使用exports对象进行成员导出,使用require方法导入其他模块
    /* 模块成员进行导出 */
    // a.js
    // 在模块内部定义变量
    let version = 1.0;
    // 在模块内部定义方法
    const sayHi = name => `你好,${name}`;
    // 向模块外部导出数据
    exports.version = version;
    exports.sayHi = sayHi;
    
    /* 模块成员进行导入 */
    // b.js
    // 在b.js模块中导入模块a
    let a = require('./b.js');
    // 输出b模块中的version变量
    console.log(a.version);
    // 调用b模块中的sayHi方法,并输出其返回值
    console.log(a.sayHi('张三'));
    

    模块导入时,后缀名是可以省略的

    模块成员导出的另一种方式:exportsmodule.exports的别名(地址引用关系),当exports对象和module.exports对象指向的不是同一个对象时,导出对象是最终以module.exports为准

    module.exports.version = version;
    module.exports.sayHi = sayHi;
    

    系统模块

    Node运行环境提供的API,因为这些API都是以模块化的方式进行开发的,所以我们又称Node运行环境提供的API为系统模块

    • 例如:文件模块包含:读取文件、写入文件、创建文件夹

    系统模块fs文件操作

    • f:file文件
    • s:system系统,文件操作系统

    读取文件操作

    const fs = require('fs');
    
    // 读取文件内容
    fs.reaFile('文件路径/文件名称'[,'文件编码'],callBack);
    

    ========================
    读取文件语法示例

    // 读取上一级CSS目录中的base.css
    fs.readFile('../css/base.css','utf-8'(err,doc) => {
        // 如果文件读取发生错误 err的值为一个对象 包含错误信息
        // 如果文件读取正确 err为null
        // doc参数为文件内容
        if(err==null){
            // 在控制台中输出文件内容
            console.log(doc);
        }
    });
    

    写入文件内容

    fs.writeFile('文件路径/文件名称','数据',callBack);
    

    ========================
    写入文件示例

    const content = '<h3>正确使用fs.writeFile写入文件内容</h3>';
    // 如果要写入的文件不存在,会自动创建此文件
    fs.writeFile('../index.html',content,err => {
        if(err !== null) {
            console.log(err);
            return;
        }
        console.log('文件写入成功');
    });
    

    系统模块path 路径操作

    • 为什么要进行路径拼接?
      • 不同的操作系统的路径分隔符不统一
      • Windows是/\
      • Linux是/
    path.join('路径','路径',...)
    
    /* 示例: */
    // 导入path模块
    const path = require('path');
    // 路径拼接
    let finialPath = path.join('itcast','a','b','c.css');
    console.log(finialPath); // 输出结果 itcast\a\b\c.css
    

    相对路径&&绝对路径

    • 大多数情况下使用绝对路径,因为相对路径有时候相对的是命令行工具的当前工作目录
    • 在读取文件或者设置文件路径时都会选择绝对路径
    • 使用__dirname获取当前文件所在的绝对路径

    第三方模块

    别人写好的,具有特定的功能的,我们能够直接使用的模块即第三方模块。由于第三方模块通常都是由多个文件组成并且被放置在一个文件夹中,所以又名

    第三方模块有两种存在形式

    • 以js文件形式存在,提供实现项目具体功能的api接口
    • 以命令行工具形式存在,辅助项目开发
    • 获取第三方模块
      • npmjs.com:第三方模块的存储和分发仓库
      • npm(mode package manager):node的第三方模块管理工具
      • 下载:npm install 模块名称
      • 卸载:`npm uninstall package 模块名称
    • 全局安装与本地安装
      • 命令行工具:全局安装
      • 库文件:本地安装

    第三方模块 nodemon

    nodemon是一个命令行工具,用以辅助项目开发

    • 在Node.js中,每次修改文件都要在命令行工具中重新执行该文件,非常繁琐
    • nodemon使用步骤
      • 使用npm install nodemon -g 下载它(-g代表全局安装)
      • 在命令行工具中使用nodemon命令替代node命令执行文件

    第三方模块 nrm

    nrm(npm registry manager):npm下载地址切换工具

    • npm默认的下载地址在国外,国内下载速度慢
    • 使用步骤
      • 使用npm install nrm -g 下载它
      • 查询可下载的地址列表 nrm ls
      • 切换npm下载地址 nrm use 下载地址名称

    相关文章

      网友评论

        本文标题:node简单了解(1)

        本文链接:https://www.haomeiwen.com/subject/nqtkghtx.html