前端Node.js 基础

一 .Node.js 基础

目录

Node开发概述
Node运行环境搭建
Node.js快速入门

1. Node开发概述

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

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

1.2 服务器端开发要做的事情

实现网站的业务逻辑
数据的增删改查

1.3 为什么选择Node

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

1.4 Node是什么

Node是一个基于Chrome V8引擎的JavaScript代码运行环境。

运行环境


1.png

浏览器(软件)能够运行JavaScript代码,浏览器就是JavaScript代码的运行环境
Node(软件)能够运行JavaScript代码,Node就是JavaScript代码的运行环境

2. Node运行环境搭建

2.1 Node.js运行环境安装

官网:https://nodejs.org/en/

Current 拥有最新特性 实验版LTS = Long Term

Support 长期支持版 稳定版

2.2 Node环境安装失败解决办法

1. 错误代号2502、2503

失败原因:系统帐户权限不足。

解决办法:
以管理员身份运行powershell命令行工具
输入运行安装包命令 msiexec /package node安装包位置

2. 执行命令报错

失败原因:Node安装目录写入环境变量失败
解决办法:将Node安装目录添加到环境变量中

2.3 PATH环境变量

存储系统中的目录,在命令行中执行命令的时候系统会自动去这些目录中查找命令的位置。

3. Node.js快速入门

3.1 Node.js 的组成

JavaScript 由三部分组成,ECMAScript,DOM,BOM。

Node.js是由ECMAScript及Node 环境提供的一些附加API组成的,包括文件、网络、路径等等一些更加强大的 API。

2.png

3.2 Node.js基础语法

所有ECMAScript语法在Node环境中都可以使用。
在Node环境下执行代码,使用Node命令执行后缀为.js的文件即可

3.3 Node.js全局对象global

在浏览器中全局对象是window,在Node中全局对象是global。
Node中全局对象下有以下方法,可以在任何地方使用,global可以省略。
console.log() 在控制台中输出
setTimeout() 设置超时定时器
clearTimeout() 清除超时时定时器
setInterval() 设置间歇定时器
clearInterval() 清除间歇定时器




二.模块加载及第三方包

目录

Node.js模块化开发
系统模块
第三方模块
package.json文件
Node.js中模块的加载机制

1. Node.js模块化开发

1.1 JavaScript开发弊端

JavaScript在使用时存在两大问题,文件依赖命名冲突

3.png

1.2 生活中的模块化开发

4.png

1.3 软件中的模块化开发

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

5.png

1.4 Node.js中模块化开发规范

Node.js规定一个JavaScript文件就是一个模块,模块内部定义的变量和函数默认情况下在外部无法得到
模块内部可以使用exports对象进行成员导出, 使用require方法导入其他模块。

6.png

1.5 模块成员导出exports

// a.js
// 在模块内部定义变量
let version = 1.0;
// 在模块内部定义方法
const sayHi = name => `您好, ${name}`;
// 向模块外部导出数据 
exports.version = version;
exports.sayHi = sayHi;

1.6 模块成员的导入require

// b.js
// 在b.js模块中导入模块a
let a = require('./b.js');
// 输出b模块中的version变量
console.log(a.version);
// 调用b模块中的sayHi方法 并输出其返回值
console.log(a.sayHi('黑马讲师')); 

导入模块时后缀可以省略

1.7 模块成员导出的另一种方式module.exports

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

exportsmodule.exports的别名(地址引用关系),导出对象最终以module.exports为准

1.8 模块导出两种方式的联系与区别

7.png

exports是module.exports的别名 他们指向同一块儿内存空间 都是往同一块儿空间添加属性值
他们默认指向的是同一块儿内存空间

当exports对象和moudle.exports对象指向的不是同一个对象时 以module.exports为准

// 当exports对象和moudle.exports对象指向的不是同一个对象时 以module.exports为准
module.exports = {
    name: 'zhangsan'
}

exports = {
    age: 20
}

2. 系统模块

2.1 什么是系统模块

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

8.png

2.2 系统模块fs 文件操作

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

读取文件内容

应用场景:客户端请求 服务端需要先从本地磁盘中读取文件,再放回
参数中带有中括号:参数为可选参数
callback:回调函数
回调函数作用?读取文件内容需要时间,不能通过api返回值直接拿到读取结果,所以需要定义回调函数,硬盘会在在文件操作结束通过回调函数以参数的形式通知系统

fs.reaFile('文件路径/文件名称'[,'文件编码'], callback);

// 1.通过模块的名字fs对模块进行引用
const fs = require('fs');

// 2.通过模块内部的readFile读取文件内容
fs.readFile('./01.helloworld.js', 'utf8', (err, doc) => {
    // 如果文件读取出错err 是一个对象 包含错误信息
    // 如果文件读取正确 err是 null
    // doc 是文件读取的结果
    if (err) {
     console.log(err);
     return;
    }
    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('文件写入成功');
 });

2.3 系统模块path 路径操作

为什么要进行路径拼接

不同操作系统的路径分隔符不统一
/public/uploads/avatar
Windows 上是 \ /
Linux 上是 /

2.4 路径拼接语法

path.join('路径', '路径', ...)
const fs = require('fs');
const path = require('path');

console.log(__dirname);
console.log(path.join(__dirname, '01.helloworld.js'))

/*
数据结果如下
/Users/dufangyi/Desktop/11-16 前后端交互/11-13node+express/day01/code

/Users/dufangyi/Desktop/11-16 前后端交互/11-13node+express/day01/code/01.helloworld.js
*/

fs.readFile(path.join(__dirname, '01.helloworld.js'), 'utf8', (err, doc) => {
    console.log(err)
    console.log(doc)
});

2.5 相对路径VS绝对路径

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

3.第三方模块

3.1 什么是第三方模块

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

第三方模块有两种存在形式:
以js文件的形式存在,提供实现项目具体功能的API接口。
以命令行工具形式存在,辅助项目开发

3.2 获取第三方模块

npmjs.com:第三方模块的存储和分发仓库


9.png
  • 如何安装node第三方模块?
    npm (node package manager) : node的第三方模块管理工具
    下载:npm install 模块名称
    卸载:npm unintall package 模块名称

  • 全局安装与本地安装
    命令行工具:全局安装
    库文件:本地安装

3.3 第三方模块 nodemon

nodemon是一个命令行工具,用以辅助项目开发。
在Node.js中,每次修改文件都要在命令行工具中重新执行该文件,非常繁琐

使用步骤
使用npm install nodemon –g 下载它
在命令行工具中用nodemon命令替代node命令执行文件

3.4 第三方模块 nrm

nrm ( npm registry manager ):npm下载地址切换工具
npm默认的下载地址在国外,国内下载速度慢
使用步骤
使用npm install nrm –g 下载它
查询可用下载地址列表 nrm ls
切换npm下载地址 nrm use 下载地址名称

3.5 第三方模块 Gulp

基于node平台开发的前端构建工具
将机械化操作编写成任务, 想要执行机械化操作时执行一个命令行命令任务就能自动执行了
用机器代替手工,提高开发效率。

3.6 Gulp能做什么

项目上线,HTML、CSS、JS文件压缩合并
语法转换(es6、less ...)
公共文件抽离(比如网站的头部抽取)
修改文件浏览器自动刷新

3.7 Gulp使用

1、使用npm install gulp下载gulp库文件
2、在项目根目录下建立gulpfile.js文件
3、重构项目的文件夹结构 src目录放置源代码文件 dist目录放置构建后文件
4、在gulpfile.js文件中编写任务.
5、在命令行工具中执行gulp任务

3.8 Gulp中提供的方法

gulp.src():获取任务要处理的文件
gulp.dest():输出文件
gulp.task():建立gulp任务
gulp.watch():监控文件的变化

1.编写gulpfile.js

const gulp = require('gulp');
  // 使用gulp.task()方法建立任务
 gulp.task('first', () => {
    // 获取要处理的文件
    gulp.src('./src/css/base.css') 
    // 将处理后的文件输出到dist目录
    .pipe(gulp.dest('./dist/css'));
 });

2.终端全局安装gulp命令
npm install gulp-cli -g --registry=https://registry.npm.taobao.org

3.运行gulp任务
gulp first

3.9 Gulp插件

gulp是轻内核的第三方模块 提供方法很少,提供的内容都是通过插件方式完成

gulp-htmlmin :html文件压缩
gulp-csso :压缩css
gulp-babel :JavaScript语法转化
gulp-less: less语法转化
gulp-uglify :压缩混淆JavaScript
gulp-file-include 公共文件包含
browsersync 浏览器实时同步

插件使用下载
npm 下载
引入
使用

4. package.json文件

4.1 node_modules文件夹的问题

1.文件夹以及文件过多过碎,当我们将项目整体拷贝给别人的时候,,传输速度会很慢很慢.
2.复杂的模块依赖关系需要被记录,确保模块的版本和当前保持一致,否则会导致当前项目运行报错

拷贝给别人项目时候 node_modules文件夹不用拷贝 node项目会根据项目描述文件下载package.json中依赖的模块

4.2 package.json文件的作用

项目描述文件,记录了当前项目信息,例如项目名称、版本、作者、github地址、当前项目依赖了哪些第三方模块等。
使用npm init -y命令生成。

4.3 项目依赖

在项目的开发阶段和线上运营阶段,都需要依赖的第三方包,称为项目依赖
使用npm install 包名命令下载的文件会默认被添加到 package.json 文件的 dependencies 字段中

{
    "dependencies": {
        "jquery": "^3.3.1“
    }
 } 

4.4 开发依赖

在项目的开发阶段需要依赖,线上运营阶段不需要依赖的第三方包,称为开发依赖
使用npm install 包名 --save-dev命令将包添加到package.json文件的devDependencies字段中

{
    "devDependencies": {
        "gulp": "^3.9.1“
    }
 } 


4.5 package-lock.json文件的作用

锁定包的版本,确保再次下载时不会因为包版本不同而产生问题
加快下载速度,因为该文件中已经记录了项目所依赖第三方包的树状结构和包的下载地址,重新安装时只需下载即可,不需要做额外的工作

5. Node.js中模块加载机制

5.1 模块查找规则-当模块拥有路径但没有后缀时

require('./find.js');
require('./find');

1.require方法根据模块路径查找模块,如果是完整路径,直接引入模块。
2.如果模块后缀省略,先找同名JS文件再找同名JS文件夹
3.如果找到了同名文件夹,找文件夹中的index.js
4.如果文件夹中没有index.js就会去当前文件夹中的package.json文件中查找main选项中的入口文件
5.如果找指定的入口文件不存在或者没有指定入口文件就会报错,模块没有被找到

5.2 模块查找规则-当模块没有路径且没有后缀时

require('find');

1.Node.js会假设它是系统模块
2.Node.js会去node_modules文件夹中
3.首先看是否有该名字的JS文件
4.再看是否有该名字的文件夹
5.如果是文件夹看里面是否有index.js
6.如果没有index.js查看该文件夹中的package.json中的main选项确定模块入口文件
7.否则找不到报错

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容

  •   前端技术的发展主要还是Javascript推动,当HTML+CSS+Javascript的发展到jQuery的...
    杨强AT南京阅读 252评论 0 1
  • 1.课程介绍与开发环境搭建 主要包括nodejs 基础知识web 服务器异步 同步 阻塞 非阻塞 课程基础java...
    shadow123阅读 661评论 0 0
  • 1. node.js模块概述 为了让node.js的文件可以相互调用,node.js提供了一个简单的模块系统。模块...
    flionel阅读 502评论 4 4
  • 个人博客搭建完成,欢迎大家来访问哦黎默丶lymoo的博客 什么是node.js JavaScript是一个脚本语言...
    黎默丶lymoo阅读 415评论 0 4
  • 在现在的前端开发中,前后端分离、模块化开发、版本控制、文件合并与压缩、mock数据等等一些原本后端的思想开始...
    Charlot阅读 5,433评论 1 32