Web开发框架『express』的基本使用 —— { }
2024-10-19 12:43:46
基本
res.send([body]) 和 res.end([data] [, encoding]) 的区别
1、参数的区别:
res.send([body]): body这个参数可以是【Buffer对象】、字符串、对象、数组
res.end([data] [, encoding]): data这个参数可以是【Buffer对象】、字符串
2、响应报文头的区别:
res.send()hui自动发送更多的响应报文头,其中包括Content-Type,不会发生乱码问题
app.get()、app.all()、app.use() 的区别
// 含义:请求方法是get,请求路径pathname必须严格等于/submit
app.get('/submit',function(req,res){
res.send('submit');
})
// 含义:请求方法可以是任何一个,请求路径pathname必须严格等于/submit
app.all('/submit',function(req,res){
res.send('submit');
})
// 含义:请求方法可以是任何一个,请求路径pathname的第一部分等于/submit
app.use('/submit',function(req,res){
res.send('submit');
})
通过 req.params 获取路由中的参数
app.get('/news/:year/:month/:day',function(req,res){
res.send(req.params);
})
请求地址:http://localhost:8000/news/2020/12/30
响应参数:{"year": "2020","month": "12","day": "30"}
模拟 Apache 实现静态资源托管服务
// 含义:1、路径第一部分等于 /
// 2、如果请求的是index.html,就用请求的index.html与public拼接,返回找到的静态资源文件
app.use('/',express.static(path.join(__dirname,'public')))
// 含义:1、路径第一部分等于 /www
// 2、如果请求的是index.html,就用请求的index.html与public拼接,返回找到的静态资源文件
app.use('/www',express.static(path.join(__dirname,'public')))
实践
创建 package.json 文件
npm init -y
安装 express 模块
npm i express --save
封装 app.js 模块
// app.js 模块负责:启动服务
// 1、加载 express 模块
var express = require("express")
// 加载 config.js 模块
var config = require("./config.js")
// 加载路由模块
var router = require("./router.js")
// 2、创建 app 对象
var app = express()
// 3、注册路由
// 设置 app 与 router 相关联
app.use('/',router)
// 4、启动服务
app.listen(config.port,function(){
console.log('http://localhost:' + config.port);
})
封装 config.js 模块
module.exports = {
port: '9000'
}
封装 router.js 模块
// 主要负责路由判断
// 1、创建 router 对象(router 既是一个对象,也是一个函数)
var express = require("express")
var router = express.Router()
// 加载业务模块
var handler = require("./handler.js")
// 2、通过 router 对象挂载路由
// 挂载路由的时候,内部会以【键值对】的形式创建一个【路由表】
// 键:请求路径,值:请求时要执行的函数
router.get('/',handler.index)
router.get('/index',handler.index)
router.get('/submit',handler.submit)
// 3、返回 router
module.exports = router
封装 handler.js 模块
// 业务模块
module.exports.index = function(req,res){
res.send("index page")
}
module.exports.submit = function(req,res){
res.send("submit page")
}
最新文章
- ASP.net 使用ConfigurationManager获取连接字符串
- 【前端】移动端Web开发学习笔记【2】 &; flex布局
- python函数(五)
- 配置tomcat的虚拟路径
- 手写DataSet,DataTable
- 老鼠跑猫叫主人惊醒c++观察者模式实现
- hdu oj Period (kmp的应用)
- iOS控件——UIView与UIImageView播放动画的实现方法
- MFC内部结构剖析
- poj_1743_Musical Theme(后缀数组)
- 安装WIA组件
- 在对话框中利用CToolBar类添加工具条的方法
- js前端对后台数据的获取,如果是汉字则需要添上引号
- Android网络通信(8):WiFi Direct
- 第一个openGL程序
- tomcat+nginx+redis集群搭建并解决session共享问题。
- Inno Setup Winfrom 打包工具
- Java使用Apache POI进行Excel导入和导出
- 【Redis】- 延时任务
- json-lib反序列化抽象属性及对象