本篇文章通过超多代码和图解来带大家深入解析Node.js,主要内容包括模块化处理、包的基本应用、Express、跨域、操作Mysql数据库等,希望对大家有所帮助!
Node.js
是一个调用内置ApI
并且基于Chrome V8
引擎的js运行环境,之前自己在本地总结了一些零散的只知识点,今天整合一下发出来。
官网地址: https://nodejs.org/zh-cn/
①基于 Express
框架(http://www.expressjs.com.cn/),可以快速构建 Web 应用。【相关教程推荐:nodejs视频教程、编程教学】
②基于 Electron
框架(https://electronjs.org/),可以构建跨平台的桌面应用
③基于restify
框架(http://restify.com/),可以快速构建 API 接口项目
④读写和操作数据库
、创建实用的命令行工具辅助前端开发、etc…
下载链接:https://nodejs.org/en/
- LTS:长期稳定版
- Current:尝鲜版
查看版本号
:node –v
学习路线:JavaScript 基础语法 Node.js 内置 API 模块(fs、path、http等) 第三方 API 模块(express、mysql 等)
命令
:node js文件名
终端快捷键:
①使用 ↑ 键,可以快速定位到上一次执行的命令
②使用 tab 键,能够快速补全路径
③使用 esc 键,能够快速清空当前已输入的命令
④输入 cls 命令,可以清空终端
定义:把复杂问题简单化,分成一个个小问题。编程领域中的模块化
,就是遵守固定的规则
,把一个大文件拆成独立并互相依赖
的多个小模块
把代码进行模块化拆分的好处:
- 提高了代码的复用性
- 提高了代码的可维护性
- 可以实现按需加载
定义:由Node.js官方提供,如fs、http、path
一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解) fs文件系统模块
(一文带你深入了解Node.js(图文详解))基本用法
// 引用内部模块 const fs = require(&#一文带你深入了解Node.js(图文详解)9;fs&#一文带你深入了解Node.js(图文详解)9;); // 文件读取 fs.readFile(&#一文带你深入了解Node.js(图文详解)9;../files/test-fs.txt&#一文带你深入了解Node.js(图文详解)9;, &#一文带你深入了解Node.js(图文详解)9;utf-8&#一文带你深入了解Node.js(图文详解)9;, (err, results) => { if (err) return console.log(err.message);// 错误信息err null console.log(results); }) // 文件写入 fs.writeFile(&#一文带你深入了解Node.js(图文详解)9;../files/test-fs.txt&#一文带你深入了解Node.js(图文详解)9;, &#一文带你深入了解Node.js(图文详解)9;Node.js&#一文带你深入了解Node.js(图文详解)9;, &#一文带你深入了解Node.js(图文详解)9;utf-8&#一文带你深入了解Node.js(图文详解)9;, (err) => { if (err) return console.log(err.message); console.log(&#一文带你深入了解Node.js(图文详解)9;写入文件成功!&#一文带你深入了解Node.js(图文详解)9;); })
注意点
-
readFile
只能读取已经存在的文件 -
writeFile
写入内容已经有文件,则创建同名文件,再写入文件 -
readFile
需要在writeFile
后面读取,不然出错
(一文带你深入了解Node.js(图文详解))防止动态拼接
-
node
命令自动将当前路径和js脚本文件路径
拼接,而不管.day总复习这个路径
- 我们可以使用
绝对路径
改善
(一文带你深入了解Node.js(图文详解))路径问题
-
./
表示当前目录../
表示父级目录../..
表示祖父目录 - 动态拼接,首部不能出现
./ ../
,否则拼接失败 /…/
一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解) path内置模块
定义:拼接绝对路径
- path.join()
- path.basename()
- path.extname()
const fs = require(&#一文带你深入了解Node.js(图文详解)9;fs&#一文带你深入了解Node.js(图文详解)9;); const path = require(&#一文带你深入了解Node.js(图文详解)9;path&#一文带你深入了解Node.js(图文详解)9;); const fpath = path.join(__dirname, &#一文带你深入了解Node.js(图文详解)9;/../files/test-fs.txt&#一文带你深入了解Node.js(图文详解)9;); fs.readFile(fpath, &#一文带你深入了解Node.js(图文详解)9;utf-8&#一文带你深入了解Node.js(图文详解)9;, (err, results) => { console.log(__dirname); console.log(path.basename(fpath, &#一文带你深入了解Node.js(图文详解)9;.txt&#一文带你深入了解Node.js(图文详解)9;)); console.log(path.extname(fpath)); if (err) return console.log(err.message); console.log(results); }) // test-fs // .txt // Node.js
一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解) http内置模块
定义:Node.js
提供创建web服务器
(一文带你深入了解Node.js(图文详解)) 初始化
// 导入http模块 const http = require(&#一文带你深入了解Node.js(图文详解)9;http&#一文带你深入了解Node.js(图文详解)9;); //创建web服务器实例 const server = http.createServer(); //绑定request事件,监听客户端请求 server.on(&#一文带你深入了解Node.js(图文详解)9;request&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { let str = `路径 ${req.url} 方法 ${req.method}`; console.log(str); // 向客户端发送中文前,设置响应头 res.setHeader(&#一文带你深入了解Node.js(图文详解)9;Content-Type&#一文带你深入了解Node.js(图文详解)9;, &#一文带你深入了解Node.js(图文详解)9;text/html;charset=utf-8&#一文带你深入了解Node.js(图文详解)9;); res.end(str); }) //启动服务器 server.listen(80, () => { console.log(&#一文带你深入了解Node.js(图文详解)9;http://一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)7.0.0.一文带你深入了解Node.js(图文详解)&#一文带你深入了解Node.js(图文详解)9;); })
(一文带你深入了解Node.js(图文详解)) web服务器
- 根据浏览器访问的
url地址
不同,返回相应的绝对路径
const fs = require(&#一文带你深入了解Node.js(图文详解)9;fs&#一文带你深入了解Node.js(图文详解)9;); const http = require(&#一文带你深入了解Node.js(图文详解)9;http&#一文带你深入了解Node.js(图文详解)9;); const path = require(&#一文带你深入了解Node.js(图文详解)9;path&#一文带你深入了解Node.js(图文详解)9;); const server = http.createServer(); let fpath = &#一文带你深入了解Node.js(图文详解)9;&#一文带你深入了解Node.js(图文详解)9;; server.on(&#一文带你深入了解Node.js(图文详解)9;request&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { if (req.url === &#一文带你深入了解Node.js(图文详解)9;/&#一文带你深入了解Node.js(图文详解)9;) { fpath = path.join(__dirname + &#一文带你深入了解Node.js(图文详解)9;/../files/clock/index.html&#一文带你深入了解Node.js(图文详解)9;); console.log(__dirname); console.log(fpath); } else { fpath = path.join(__dirname + &#一文带你深入了解Node.js(图文详解)9;/../files/clock&#一文带你深入了解Node.js(图文详解)9; + req.url); } fs.readFile(fpath, &#一文带你深入了解Node.js(图文详解)9;utf-8&#一文带你深入了解Node.js(图文详解)9;, (err, results) => { if (err) res.end(&#一文带你深入了解Node.js(图文详解)9;404 not find&#一文带你深入了解Node.js(图文详解)9;); res.end(results); }) }) server.listen(80, () => { console.log(&#一文带你深入了解Node.js(图文详解)9;http://一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)7.0.0.一文带你深入了解Node.js(图文详解)&#一文带你深入了解Node.js(图文详解)9;); })
定义:用户自定义的js模块
//引入本地文件 const custom = require(&#一文带你深入了解Node.js(图文详解)9;./0一文带你深入了解Node.js(图文详解)-node.js的使用&#一文带你深入了解Node.js(图文详解)9;);
注意:自定义模块开头必须有./ …/
定义:由第三方
提供,使用前需要下载
//下载外部导入 const moment = require(&#一文带你深入了解Node.js(图文详解)9;moment&#一文带你深入了解Node.js(图文详解)9;);
监听nodemon
npm i nodemon -g
代替node
使用nodedmon
,每次修改内容不需要重启服务器,自动监听
模块作用域定义
:和函数一致,当前模块定义的方法、变量,只能在当前模块
访问,防止变量污染
暴露
:通过module.exports
或者exports
暴露出去,使用 require()
方法导入模块时,导入的结果,永远以module.exports
指向的对象为准
定义: 一次加载缓存,从缓存加载
,内置模块
加载优先级MAX
包:概念像node.js
的第三方模块
,包是基于内置模块
封装出来的,提供了更高级、更方便的 API
,极大的提高了开发效率
npm: 包管理工具
-
npm
安装包
-
js
导入包
- 根据开发文档
使用包
// npm i moment const moment = require(&#一文带你深入了解Node.js(图文详解)9;moment&#一文带你深入了解Node.js(图文详解)9;); const date = moment().format(&#一文带你深入了解Node.js(图文详解)9;YYYY-MM-DD HH:mm:ss&#一文带你深入了解Node.js(图文详解)9;); console.log(date);//一文带你深入了解Node.js(图文详解)0一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)-09-一文带你深入了解Node.js(图文详解)0 一文带你深入了解Node.js(图文详解)0:4一文带你深入了解Node.js(图文详解):一文带你深入了解Node.js(图文详解)4
包的版本号是以“点分十进制”形式进行定义的,总共有三位数字,例如 一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解)4.0
其中每一位数字所代表的的含义如下:
第一文带你深入了解Node.js(图文详解)位数字:
大版本
第一文带你深入了解Node.js(图文详解)位数字:
功能版本
-
第一文带你深入了解Node.js(图文详解)位数字:
Bug修复版本
版本号提升的规则:只要前面的版本号增长了,则后面的版本号归零。
npm i comment@一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解)
-
node_modules
文件夹用来存放所有已安装到项目中的包。require() 导入第三方包时,就是从这个目录中查找并加载包。 -
package-lock.json
配置文件用来记录 node_modules 目录下的每一个包的下载信息,例如包的名字、版本号、下载地址等。 -
package.json
项目的名称、版本号、描述等、用到了哪些包、开发期间使用的包、部署使用的包-
devDependencies
:开发依赖 -
dependencies
:核心依赖
-
- 注意:程序员不要手动修改 node_modules 或 package-lock.json 文件中的任何代码,npm 包管理工具会自动维护它们,今后在项目开发中,一定要把 node_modules 文件夹,添加到 .gitignore 忽略文件中
//安装包 npm i moment //安装全局包 npm i 包名 -g //安装包到开发阶段到devDependencies npm i 包名 -D //安装所有依赖包 npm install //卸载包 npm uninstall moment //查看已经安装的局部包 npm ls //查看全局安装的包 npm ls -g
查看包命令:https://blog.csdn.net/qq_4一文带你深入了解Node.js(图文详解)664096/article/details/一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)797一文带你深入了解Node.js(图文详解)60
//查看当前npm镜像 npm config get registry //nrm镜像工具,安装为全局镜像 nrm ls //切换镜像 nrm use taobao
一个规范的包,它的组成结构,必须符合以下 一文带你深入了解Node.js(图文详解) 点要求:
- 包必须以
单独的目录
而存在 - 包的顶级目录下要必须包含
package.json
这个包管理配置文件 - package.json 中必须包含
name,version,main
这三个属性,分别代表包的名字、版本号、包的入口
发布包到npm
上
- 镜像切换到npm上
-
npm login
登录 - 发布包
npm publish
- 删除包
npm unpublish 包名 --force
资源:
- https://www.npmjs.com/ 网站上搜索自己所需要的包
- https://registry.npmjs.org/ 服务器上下载自己需要的包
Express
:基于Node.js http
进一步封装,更加高级的Web开发框架
对于前端程序员来说,最常见的两种服务器,分别是:
-
Web 网站服务器:专门对外提供
Web 网页资源
的服务器 -
API 接口服务器:专门对外提供
API 接口
的服务器
//导入包 const express = require(&#一文带你深入了解Node.js(图文详解)9;express&#一文带你深入了解Node.js(图文详解)9;); //创建服务器 const app = express(); app.get(&#一文带你深入了解Node.js(图文详解)9;/user&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { res.send({ 男: &#一文带你深入了解Node.js(图文详解)9;一文带你深入了解Node.js(图文详解)8&#一文带你深入了解Node.js(图文详解)9;, age: 一文带你深入了解Node.js(图文详解)8 }); }) app.post(&#一文带你深入了解Node.js(图文详解)9;/user&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { res.send(&#一文带你深入了解Node.js(图文详解)9;post请求&#一文带你深入了解Node.js(图文详解)9;); }) app.get(&#一文带你深入了解Node.js(图文详解)9;/&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { //req.query ?name=zs&age=一文带你深入了解Node.js(图文详解)8 这种数据 //http://一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)7.0.0.一文带你深入了解Node.js(图文详解)?name=zs&age=一文带你深入了解Node.js(图文详解)8 console.log(req.query); }) app.post(&#一文带你深入了解Node.js(图文详解)9;/:id&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { //动态匹配参数 console.log(req.params); }) //启动服务器 app.listen(80, () => { console.log(&#一文带你深入了解Node.js(图文详解)9;http://一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)7.0.0.一文带你深入了解Node.js(图文详解)&#一文带你深入了解Node.js(图文详解)9;); })
定义
:通过路径暴露文件,省去文件路径的描写
const express = require(&#一文带你深入了解Node.js(图文详解)9;express&#一文带你深入了解Node.js(图文详解)9;); const app = express(); //托管静态资源,不需要访问 app.use(&#一文带你深入了解Node.js(图文详解)9;/public&#一文带你深入了解Node.js(图文详解)9;, express.static(&#一文带你深入了解Node.js(图文详解)9;../files/clock&#一文带你深入了解Node.js(图文详解)9;)); app.listen(80, () => { console.log(&#一文带你深入了解Node.js(图文详解)9;http://一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)7.0.0.一文带你深入了解Node.js(图文详解)&#一文带你深入了解Node.js(图文详解)9;); })
推荐VScode插件:postcode
Express 的中文官网: http://www.expressjs.com.cn/
定义
:客户端与服务器映射关系
4.4.一文带你深入了解Node.js(图文详解) 简单挂载
//导入包 const express = require(&#一文带你深入了解Node.js(图文详解)9;express&#一文带你深入了解Node.js(图文详解)9;); //创建服务器 const app = express(); app.get(&#一文带你深入了解Node.js(图文详解)9;/user&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { res.send({ 男: &#一文带你深入了解Node.js(图文详解)9;一文带你深入了解Node.js(图文详解)8&#一文带你深入了解Node.js(图文详解)9;, age: 一文带你深入了解Node.js(图文详解)8 }); }) app.post(&#一文带你深入了解Node.js(图文详解)9;/user&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { res.send(&#一文带你深入了解Node.js(图文详解)9;post请求&#一文带你深入了解Node.js(图文详解)9;); }) //启动服务器 app.listen(80, () => { console.log(&#一文带你深入了解Node.js(图文详解)9;http://一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)7.0.0.一文带你深入了解Node.js(图文详解)&#一文带你深入了解Node.js(图文详解)9;); })
4.4.一文带你深入了解Node.js(图文详解) 模块化路由
为了方便对路由进行模块化的管理
,Express 不建议将路由直接挂载到 app 上,而是推荐将路由抽离为单独的模块
。
将路由抽离为单独模块的步骤
如下:
创建路由
模块
对应的.js
文件调用
express.Router()
函数创建路由对象向路由对象上挂载具体的路由
使用
module.exports
向外共享路由对象使用
app.use()
函数注册路由模块
创建路由对象
const express = require(&#一文带你深入了解Node.js(图文详解)9;express&#一文带你深入了解Node.js(图文详解)9;);//导入包 const router = express.Router();//创建路由对象 //绑定路由规则 router.get(&#一文带你深入了解Node.js(图文详解)9;/user/list&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { res.send(&#一文带你深入了解Node.js(图文详解)9;user list message&#一文带你深入了解Node.js(图文详解)9;); }) router.post(&#一文带你深入了解Node.js(图文详解)9;/user/add&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { res.send(&#一文带你深入了解Node.js(图文详解)9;user add message&#一文带你深入了解Node.js(图文详解)9;); }) //向外导出路由对象 module.exports = router;
使用路由对象
const express = require(&#一文带你深入了解Node.js(图文详解)9;express&#一文带你深入了解Node.js(图文详解)9;); const app = express(); const router = require(&#一文带你深入了解Node.js(图文详解)9;./一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)-模块化路由&#一文带你深入了解Node.js(图文详解)9;); app.use(router); app.listen(80, () => { console.log(&#一文带你深入了解Node.js(图文详解)9;http://一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)7.0.0.一文带你深入了解Node.js(图文详解)&#一文带你深入了解Node.js(图文详解)9;); })
中间件:与路由处理函数不同,必须包含next参数
4.5.一文带你深入了解Node.js(图文详解) 基本使用
const express = require(&#一文带你深入了解Node.js(图文详解)9;express&#一文带你深入了解Node.js(图文详解)9;); const app = express(); //全局中间件的简化形式 app.use((req, res, next) => { console.log(&#一文带你深入了解Node.js(图文详解)9;正在使用全局中间件&#一文带你深入了解Node.js(图文详解)9;); next(); }); app.get(&#一文带你深入了解Node.js(图文详解)9;/&#一文带你深入了解Node.js(图文详解)9;,(req, res) => { res.send(&#一文带你深入了解Node.js(图文详解)9;Get message&#一文带你深入了解Node.js(图文详解)9;); }) app.listen(80, () => { console.log(&#一文带你深入了解Node.js(图文详解)9;http://一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)7.0.0.一文带你深入了解Node.js(图文详解)&#一文带你深入了解Node.js(图文详解)9;); })
注意
多个中间件共享
req,res
,上游设置好,下游的中间件/路由使用中间件
定义先后顺序执行-
局部生效
的中间件,定义在app.get(&#一文带你深入了解Node.js(图文详解)9;/&#一文带你深入了解Node.js(图文详解)9;,中间件,(req, res) => { res.send(&#一文带你深入了解Node.js(图文详解)9;Get message&#一文带你深入了解Node.js(图文详解)9;); })
路由之前
调用中间件next()函数
不能忘,后面不用写内容
4.5.一文带你深入了解Node.js(图文详解) 中间件分类
(一文带你深入了解Node.js(图文详解))应用
const express = require(&#一文带你深入了解Node.js(图文详解)9;express&#一文带你深入了解Node.js(图文详解)9;); const app = express(); //全局中间件 app.use((req, res, next) => { console.log(&#一文带你深入了解Node.js(图文详解)9;全局中间件&#一文带你深入了解Node.js(图文详解)9;); next(); }) //局部中间件 function mw(req, res, next) { console.log(&#一文带你深入了解Node.js(图文详解)9;局部中间件&#一文带你深入了解Node.js(图文详解)9;); next(); } app.get(&#一文带你深入了解Node.js(图文详解)9;/&#一文带你深入了解Node.js(图文详解)9;, mw, (req, res) => { res.send(&#一文带你深入了解Node.js(图文详解)9;server is visting&#一文带你深入了解Node.js(图文详解)9;); }) app.listen(80, () => { console.log(&#一文带你深入了解Node.js(图文详解)9;http://一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)7.0.0.一文带你深入了解Node.js(图文详解)&#一文带你深入了解Node.js(图文详解)9;); })
(一文带你深入了解Node.js(图文详解))路由
定义:绑定到 express.Router()
实例上的中间件
(一文带你深入了解Node.js(图文详解))错误
定义:捕获项目
错误,防止出错,在所有路由之后
定义
const express = require(&#一文带你深入了解Node.js(图文详解)9;express&#一文带你深入了解Node.js(图文详解)9;); const app = express(); app.get(&#一文带你深入了解Node.js(图文详解)9;/&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { throw new Error(&#一文带你深入了解Node.js(图文详解)9;服务器出错&#一文带你深入了解Node.js(图文详解)9;); res.send(&#一文带你深入了解Node.js(图文详解)9;server is visting&#一文带你深入了解Node.js(图文详解)9;); }) //全局中间件 app.use((err, req, res, next) => { console.log(&#一文带你深入了解Node.js(图文详解)9;Error!&#一文带你深入了解Node.js(图文详解)9; + err.message); res.send(&#一文带你深入了解Node.js(图文详解)9;Error!&#一文带你深入了解Node.js(图文详解)9; + err.message); next(); }) app.listen(80, () => { console.log(&#一文带你深入了解Node.js(图文详解)9;http://一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)7.0.0.一文带你深入了解Node.js(图文详解)&#一文带你深入了解Node.js(图文详解)9;); }) //Error!服务器出错
(4)Express 内置
const express = require(&#一文带你深入了解Node.js(图文详解)9;express&#一文带你深入了解Node.js(图文详解)9;); const app = express(); // express.json()解析JSON请求体 app.use(express.json()); //解析application/x-www- app.use(express.urlencoded({ extended: false })); app.post(&#一文带你深入了解Node.js(图文详解)9;/user&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { console.log(req.body); }) app.post(&#一文带你深入了解Node.js(图文详解)9;/book&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { console.log(req.body); }) app.listen(80, () => { console.log(&#一文带你深入了解Node.js(图文详解)9;http://一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)7.0.0.一文带你深入了解Node.js(图文详解)&#一文带你深入了解Node.js(图文详解)9;); }) // http://一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)7.0.0.一文带你深入了解Node.js(图文详解) // { name: &#一文带你深入了解Node.js(图文详解)9;zs&#一文带你深入了解Node.js(图文详解)9;, age: 一文带你深入了解Node.js(图文详解)8 } // [Object: null prototype] { name: &#一文带你深入了解Node.js(图文详解)9;西游记&#一文带你深入了解Node.js(图文详解)9; }
(5)第三方
npm install body-parse
-
require
导入 -
app.use()
为全局
const express = require(&#一文带你深入了解Node.js(图文详解)9;express&#一文带你深入了解Node.js(图文详解)9;); const app = express(); const parser = require(&#一文带你深入了解Node.js(图文详解)9;body-parser&#一文带你深入了解Node.js(图文详解)9;); app.use(parser.urlencoded({ extended: false })); app.post(&#一文带你深入了解Node.js(图文详解)9;/book&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { console.log(req.body); }) app.listen(80, () => { console.log(&#一文带你深入了解Node.js(图文详解)9;http://一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)7.0.0.一文带你深入了解Node.js(图文详解)&#一文带你深入了解Node.js(图文详解)9;); })
注意:Express 内置的 express.urlencoded
中间件,就是基于 body-parser
这个第三方中间件进一步封装出来的。
封装中间件
const querystring = require(&#一文带你深入了解Node.js(图文详解)9;querystring&#一文带你深入了解Node.js(图文详解)9;); function parsebody(req, res, next) { let str = &#一文带你深入了解Node.js(图文详解)9;&#一文带你深入了解Node.js(图文详解)9;; req.on(&#一文带你深入了解Node.js(图文详解)9;data&#一文带你深入了解Node.js(图文详解)9;, (result) => { str += result; }) req.on(&#一文带你深入了解Node.js(图文详解)9;end&#一文带你深入了解Node.js(图文详解)9;, () => { const body = querystring.parse(str); req.body = body; next(); }) } module.exports = parsebody;
测试中间件
const express = require(&#一文带你深入了解Node.js(图文详解)9;express&#一文带你深入了解Node.js(图文详解)9;); const app = express(); const parsebody = require(&#一文带你深入了解Node.js(图文详解)9;./一文带你深入了解Node.js(图文详解)4-自定义中间件&#一文带你深入了解Node.js(图文详解)9;); app.use(parsebody); app.post(&#一文带你深入了解Node.js(图文详解)9;/user&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { res.send(req.body); console.log(req.body); }) app.listen(80, () => { console.log(&#一文带你深入了解Node.js(图文详解)9;http://一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)7.0.0.一文带你深入了解Node.js(图文详解)&#一文带你深入了解Node.js(图文详解)9;); })
const express = require(&#一文带你深入了解Node.js(图文详解)9;express&#一文带你深入了解Node.js(图文详解)9;); const app = express(); const router = require(&#一文带你深入了解Node.js(图文详解)9;./一文带你深入了解Node.js(图文详解)5-接口问题&#一文带你深入了解Node.js(图文详解)9;); app.use(router); app.listen(80, () => { console.log(&#一文带你深入了解Node.js(图文详解)9;http://一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)7.0.0.一文带你深入了解Node.js(图文详解)&#一文带你深入了解Node.js(图文详解)9;); })
4.7.一文带你深入了解Node.js(图文详解) GET接口
const express = require(&#一文带你深入了解Node.js(图文详解)9;express&#一文带你深入了解Node.js(图文详解)9;); const apiRouter = express.Router(); apiRouter.get(&#一文带你深入了解Node.js(图文详解)9;/user&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { const query = req.query; res.send({ status: 0, msg: &#一文带你深入了解Node.js(图文详解)9;GET 请求成功&#一文带你深入了解Node.js(图文详解)9;, data: query }); }) module.exports = apiRouter;
4.7.一文带你深入了解Node.js(图文详解) POST接口
apiRouter.use(express.urlencoded({ extended: false })); apiRouter.post(&#一文带你深入了解Node.js(图文详解)9;/user&#一文带你深入了解Node.js(图文详解)9;, (req, res) => { const body = req.body; res.send({ status: 0, msg: &#一文带你深入了解Node.js(图文详解)9;POST 请求成功&#一文带你深入了解Node.js(图文详解)9;, data: body }); })
4.7.一文带你深入了解Node.js(图文详解) PUT接口
4.7.4 DELETE接口
4.7.5 区别
https://blog.csdn.net/qq_4一文带你深入了解Node.js(图文详解)9一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)85/article/details/一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)985一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)94
https://zhuanlan.zhihu.com/p/一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)5454697
5.一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解) 原理
概念:由Http
响应头构成,决定浏览器
是否阻止js代码
获取资源,在服务器端
配置
5.一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解) 响应头
//只允许特定的域名访问、*代表全部 res.setHeader(&#一文带你深入了解Node.js(图文详解)9;Access-Control-Allow-Origin&#一文带你深入了解Node.js(图文详解)9;, &#一文带你深入了解Node.js(图文详解)9;http://www.baidu.com&#一文带你深入了解Node.js(图文详解)9;); //配置请求头信息 res.setHeader(&#一文带你深入了解Node.js(图文详解)9;Access-Control-Allow-Headers&#一文带你深入了解Node.js(图文详解)9;, &#一文带你深入了解Node.js(图文详解)9;Content-Type,X-Custom-Header&#一文带你深入了解Node.js(图文详解)9;); //配置请求头方法 * 代表全部 res.setHeader(&#一文带你深入了解Node.js(图文详解)9;Access-Control-Allow-Methods&#一文带你深入了解Node.js(图文详解)9;, &#一文带你深入了解Node.js(图文详解)9;GET,POST,DELETE,PUT&#一文带你深入了解Node.js(图文详解)9;);
5.一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解) 分类
(一文带你深入了解Node.js(图文详解))简单请求
- 请求方式:GET、POST、HEAD
-
HTTP 头部信息不超过以下几种字段:
无自定义头部字段
、Accept、Accept-Language、Content-Language、DPR、Downlink、Save-Data、Viewport-Width、Width 、Content-Type(只有三个值application/x-www-form-urlencoded、multipart/form-data、text/plain) - 客户端与服务器只发送
一次请求
(一文带你深入了解Node.js(图文详解))预检请求
- 请求方式:GET、POST、HEAD之外的方式
-
自定义
头部字段 -
OPTION预检
,成功后发送带有数据的请求
概念:只支持GET
请求
定义:组织
、存储
、管理数据
的仓库
6.一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解) 查询
select * from userswhere id>一文带你深入了解Node.js(图文详解) and id <h4> <a id="6一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)__89一文带你深入了解Node.js(图文详解)"></a>6.一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解) 插入</h4><pre class="brush:php;toolbar:false">insert into users(username,password) values(一文带你深入了解Node.js(图文详解)9;jack一文带你深入了解Node.js(图文详解)9;,一文带你深入了解Node.js(图文详解)9;666一文带你深入了解Node.js(图文详解)9;)
6.一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解) 更新
update users set password=一文带你深入了解Node.js(图文详解)9;666666一文带你深入了解Node.js(图文详解)9;where username=一文带你深入了解Node.js(图文详解)9;jack一文带你深入了解Node.js(图文详解)9;
6.一文带你深入了解Node.js(图文详解).4 删除
delete from users where id=9
6.一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解) 初始化
- 导包:
npm i mysql
//引入mysql const mysql = require(&#一文带你深入了解Node.js(图文详解)9;mysql&#一文带你深入了解Node.js(图文详解)9;); //建立数据库连接 const db = mysql.createPool({ url: &#一文带你深入了解Node.js(图文详解)9;一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)7.0.0.一文带你深入了解Node.js(图文详解)&#一文带你深入了解Node.js(图文详解)9;,//数据库IP地址 user: &#一文带你深入了解Node.js(图文详解)9;root&#一文带你深入了解Node.js(图文详解)9;,//账号 password: &#一文带你深入了解Node.js(图文详解)9;一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)456&#一文带你深入了解Node.js(图文详解)9;,//密码 database: &#一文带你深入了解Node.js(图文详解)9;test_db&#一文带你深入了解Node.js(图文详解)9;//操作哪一个数据库 });
6.一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解) 查询
const queryStr = &#一文带你深入了解Node.js(图文详解)9;select * from users&#一文带你深入了解Node.js(图文详解)9;; db.query(queryStr, (err, results) => { if (err) return console.log(err.message); console.log(results); }) PS E:\FED\js\node.js\node.js—资料\day总复习\code> node .\一文带你深入了解Node.js(图文详解)8-mysql操作.js [ RowDataPacket { id: 一文带你深入了解Node.js(图文详解), username: &#一文带你深入了解Node.js(图文详解)9;zz&#一文带你深入了解Node.js(图文详解)9;, password: &#一文带你深入了解Node.js(图文详解)9;一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)&#一文带你深入了解Node.js(图文详解)9;, status: 0 }, RowDataPacket { id: 一文带你深入了解Node.js(图文详解), username: &#一文带你深入了解Node.js(图文详解)9;ls&#一文带你深入了解Node.js(图文详解)9;, password: &#一文带你深入了解Node.js(图文详解)9;abc&#一文带你深入了解Node.js(图文详解)9;, status: 0 }, RowDataPacket { id: 4, username: &#一文带你深入了解Node.js(图文详解)9;jony&#一文带你深入了解Node.js(图文详解)9;, password: &#一文带你深入了解Node.js(图文详解)9;456&#一文带你深入了解Node.js(图文详解)9;, status: 0 } ]
6.一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解) 插入
const user = { username: &#一文带你深入了解Node.js(图文详解)9;superman&#一文带你深入了解Node.js(图文详解)9;, password: &#一文带你深入了解Node.js(图文详解)9;jknad&#一文带你深入了解Node.js(图文详解)9; }; const insertStr = &#一文带你深入了解Node.js(图文详解)9;insert into users set ?&#一文带你深入了解Node.js(图文详解)9;; db.query(insertStr, user, (err, results) => { if (err) return console.log(err.message); if (results.affectedRows == 一文带你深入了解Node.js(图文详解)) { console.log(&#一文带你深入了解Node.js(图文详解)9;插入数据成功&#一文带你深入了解Node.js(图文详解)9;); } }) //插入数据成功
6.一文带你深入了解Node.js(图文详解).4 更新
const user = { id: 一文带你深入了解Node.js(图文详解)0, username: &#一文带你深入了解Node.js(图文详解)9;super&#一文带你深入了解Node.js(图文详解)9;, password: &#一文带你深入了解Node.js(图文详解)9;一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)一文带你深入了解Node.js(图文详解)456&#一文带你深入了解Node.js(图文详解)9; }; const updateStr = &#一文带你深入了解Node.js(图文详解)9;update users set ? where id=?&#一文带你深入了解Node.js(图文详解)9;; db.query(updateStr, [user, user.id], (err, results) => { if (err) return console.log(err.message); if (results.affectedRows == 一文带你深入了解Node.js(图文详解)) { console.log(&#一文带你深入了解Node.js(图文详解)9;更新数据成功&#一文带你深入了解Node.js(图文详解)9;); } })
6.一文带你深入了解Node.js(图文详解).5 删除
(一文带你深入了解Node.js(图文详解)) 一般删除
const deleteStr = &#一文带你深入了解Node.js(图文详解)9;delete from users where id=?&#一文带你深入了解Node.js(图文详解)9;; db.query(deleteStr, 一文带你深入了解Node.js(图文详解)0, (err, results) => { if (err) return console.log(err.message); if (results.affectedRows == 一文带你深入了解Node.js(图文详解)) { console.log(&#一文带你深入了解Node.js(图文详解)9;删除成功&#一文带你深入了解Node.js(图文详解)9;); } })
(一文带你深入了解Node.js(图文详解)) 标记删除
const deleteStr = &#一文带你深入了解Node.js(图文详解)9;update users set status=一文带你深入了解Node.js(图文详解) where id=?&#一文带你深入了解Node.js(图文详解)9;; db.query(deleteStr, 一文带你深入了解Node.js(图文详解)0, (err, results) => { if (err) return console.log(err.message); if (results.affectedRows == 一文带你深入了解Node.js(图文详解)) { console.log(&#一文带你深入了解Node.js(图文详解)9;删除成功&#一文带你深入了解Node.js(图文详解)9;); } })
7.一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解) 基于服务端渲染的传统 Web 开发模式
概念:服务端在后台拼接html页面
,发送给客户端,不需要ajax
特点:
- 前端耗时少
- 有利于SEO
- 占用服务端资源
- 不利于前后端分离开发
7.一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解) 基于前后端分离的新型 Web 开发模式
概念:后端提供API
接口,前端通过ajax
调用接口
特点:
- 开发体验好
- 用户体验好
- 减轻服务器渲染压力
- 不利于SEO
不谈业务场景而盲目选择使用何种开发模式都是耍流氓
- 比如
企业级网站
,主要功能是展示而没有复杂的交互,并且需要良好的SEO
,则这时我们就需要使用服务器端渲染
- 而类似
后台管理项目
,交互性
比较强,不需要考虑SEO
,那么就可以使用前后端分离
的开发模式 - 另外,具体使用何种开发模式并不是绝对的,为了同时兼顾了首页的渲染速度和前后端分离的开发效率,一些网站采用了
首屏服务器端渲染 其他页面前后端分离
的开发模式
概念:通过不同的手段(验证码、密码、人脸、指纹...
),认证客户的身份
7.一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解) Cookie
Cookie:存储在浏览器不超过4KB
字符串,键值对
形式存储
- 自动发送
- 域名独立
- 过期时限
- 4KB限制
- 容易伪造,不建议存放
隐私数据
7.一文带你深入了解Node.js(图文详解).一文带你深入了解Node.js(图文详解) Session
核心:会员卡 pos机认证
npm install express-session
更多node相关知识,请访问:nodejs 教程!
以上是一文带你深入了解Node.js(图文详解)的详细内容。更多信息请关注PHP中文网其他相关文章!

JavaScript在Web开发中的主要用途包括客户端交互、表单验证和异步通信。1)通过DOM操作实现动态内容更新和用户交互;2)在用户提交数据前进行客户端验证,提高用户体验;3)通过AJAX技术实现与服务器的无刷新通信。

理解JavaScript引擎内部工作原理对开发者重要,因为它能帮助编写更高效的代码并理解性能瓶颈和优化策略。1)引擎的工作流程包括解析、编译和执行三个阶段;2)执行过程中,引擎会进行动态优化,如内联缓存和隐藏类;3)最佳实践包括避免全局变量、优化循环、使用const和let,以及避免过度使用闭包。

Python更适合初学者,学习曲线平缓,语法简洁;JavaScript适合前端开发,学习曲线较陡,语法灵活。1.Python语法直观,适用于数据科学和后端开发。2.JavaScript灵活,广泛用于前端和服务器端编程。

Python和JavaScript在社区、库和资源方面的对比各有优劣。1)Python社区友好,适合初学者,但前端开发资源不如JavaScript丰富。2)Python在数据科学和机器学习库方面强大,JavaScript则在前端开发库和框架上更胜一筹。3)两者的学习资源都丰富,但Python适合从官方文档开始,JavaScript则以MDNWebDocs为佳。选择应基于项目需求和个人兴趣。

从C/C 转向JavaScript需要适应动态类型、垃圾回收和异步编程等特点。1)C/C 是静态类型语言,需手动管理内存,而JavaScript是动态类型,垃圾回收自动处理。2)C/C 需编译成机器码,JavaScript则为解释型语言。3)JavaScript引入闭包、原型链和Promise等概念,增强了灵活性和异步编程能力。

不同JavaScript引擎在解析和执行JavaScript代码时,效果会有所不同,因为每个引擎的实现原理和优化策略各有差异。1.词法分析:将源码转换为词法单元。2.语法分析:生成抽象语法树。3.优化和编译:通过JIT编译器生成机器码。4.执行:运行机器码。V8引擎通过即时编译和隐藏类优化,SpiderMonkey使用类型推断系统,导致在相同代码上的性能表现不同。

JavaScript在现实世界中的应用包括服务器端编程、移动应用开发和物联网控制:1.通过Node.js实现服务器端编程,适用于高并发请求处理。2.通过ReactNative进行移动应用开发,支持跨平台部署。3.通过Johnny-Five库用于物联网设备控制,适用于硬件交互。

我使用您的日常技术工具构建了功能性的多租户SaaS应用程序(一个Edtech应用程序),您可以做同样的事情。 首先,什么是多租户SaaS应用程序? 多租户SaaS应用程序可让您从唱歌中为多个客户提供服务


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

记事本++7.3.1
好用且免费的代码编辑器