基本

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")
}

Web开发框架『express』的基本使用 —— { }的更多相关文章

  1. Ubuntu下搭建NodeJS+Express WEB开发框架

    Ubuntu下搭建NodeJS+Express WEB开发框架 2012-12-27 15:06 作者: NodeJSNet 来源: 本站 浏览: 2,966 次阅读 我要评论暂无评论 字号: 大 中 ...

  2. 转:基于node的web开发框架Express入门

    JavaScript 标准参考教程(alpha) 草稿二:Node.js Express框架 GitHub TOP Express框架 来自<JavaScript 标准参考教程(alpha)&g ...

  3. node.js上除了Express还有哪些好用的web开发框架

    老司机都有体会, 开发本身没有多难, 最纠结其实是最初的技术和框架选型, 本没有绝对的好坏之分, 可一旦选择了不适合于自己业务场景的框架, 将来木已成舟后开发和维护成本都很高, 等发现不合适的时候更换 ...

  4. 『005』Web集群

    『006』索引-The Web cluster 准备更新中

  5. 基于 Node.js 平台,快速、开放、极简的 web 开发框架。

    资料地址:http://www.expressjs.com.cn/ Express 基于 Node.js 平台,快速.开放.极简的 web 开发框架. $ npm install express -- ...

  6. Node.js 入门手册:那些最流行的 Web 开发框架

    这篇文章与大家分享最流行的 Node.js Web 开发框架.Node 是一个服务器端 JavaScript 解释器,它将改变服务器应该如何工作的概念.它的目标是帮助程序员构建高度可伸缩的应用程序,编 ...

  7. 『TensorFlow』分布式训练_其三_多机分布式

    本节中的代码大量使用『TensorFlow』分布式训练_其一_逻辑梳理中介绍的概念,是成熟的多机分布式训练样例 一.基本概念 Cluster.Job.task概念:三者可以简单的看成是层次关系,tas ...

  8. 『TensorFlow』分布式训练_其二_单机多GPU并行&GPU模式设定

    建议比对『MXNet』第七弹_多GPU并行程序设计 一.tensorflow GPU设置 GPU指定占用 gpu_options = tf.GPUOptions(per_process_gpu_mem ...

  9. WEB开发框架性能排行与趋势分析

    WEB开发框架性能基准测试解读与趋势分析 TechEmpower的<Web Framework Benchmarks>性能基准测试,是关注Web开发框架发展的重要途径.但是内容数据众多,每 ...

随机推荐

  1. 简述基于CPU的机器码运行过程

    引言:会写日志的人不一定是优秀的人,但优秀的人往往是会写日志的 这里涉及五个部分,胡歌,林拜,贾以枚,罗伊人,冯眷眷-林拜老婆 依次对应CPU里的控制器, CPU里的寄存器,存储器,输入电路,输出电路 ...

  2. 2022省选前联考 AVL树/平衡树

    题目描述 pks 得到了一棵 \(N\) 个节点,权值为 \(1\sim N\) 的 \(AVL\) 树,他觉得这棵树太大了,于是他想要删掉一些节点使得最后剩下的树恰好有 \(K\) 个节点.如果 p ...

  3. LMC7660即-5V产生电路

    LMC7660为小功率极性反转电源转换器,通过LMC7660电路产生-5V电压,其芯片管脚定义如下表所示. LMC7660负电压产生电路如下图所示. 其中6脚当供电电压大于等于5V时该脚必须悬空,当供 ...

  4. 1 什么是Zookeeper 能干什么

    1 Zookeeper 概述 美团,饿了么,淘宝,58 同城等等应用都是 zookeeper 的现实生活版 博主我开了个饭店,如何才能让大家都能吃到我们的饭菜?需要入驻美团,这样大家就可以在美团 ap ...

  5. 【Python爬虫技巧】快速格式化请求头Request Headers

    你好,我是 @马哥python说 . 我们在写爬虫时,经常遇到这种问题,从目标网站把请求头复制下来,粘贴到爬虫代码里,需要一点一点修改格式,因为复制的是字符串string格式,请求头需要用字典dict ...

  6. CSDN 原力(声望,影响力) -- 设计草案

    目标 CSDN 希望成为开发者学习,成长和成就的平台.我们已经有很多功能来支持开发者的职业成长了, 如何衡量成就呢?我们希望用 原力 (以前也叫 影响力,声望) 来体现用户的成就, 并希望用原力来帮助 ...

  7. 配置Webpack Dev Server 实战操作方法步骤

    本文摘要:配置 Webpack Dev Server 可以解决本地开发前端应用时,手动执行 webpack 命令或 yarn build 命令,再去浏览器中访问 dist/index.html 的麻烦 ...

  8. 在centos7.6上部署前后端分离项目Nginx反向代理vue.js2.6+Tornado5.1.1,使用supervisor统一管理服务

    原文转载自「刘悦的技术博客」https://v3u.cn/a_id_102 这一次使用vue.js+tornado的组合来部署前后端分离的web项目,vue.js不用说了,前端当红炸子鸡,泛用性非常广 ...

  9. 完成 DolphinScheduler 新手任务赢好礼活动 | 倒计时3 天

    想轻松参与 DolphinScheduler 项目贡献吗? 想获得 500 元京东购物卡吗? 参与活动,有机会得更多活动奖励! 活动截止至6月30日 了解更多详情: 在你参与 DolphinSched ...

  10. luoguP4556 [Vani有约会]雨天的尾巴 /【模板】线段树合并 (线段树-权值-动态开点,树链剖分)

    中学毕业了,十七号就要前往武汉报道.中学的终点是武汉大学,人生的终点却不是,最初的热情依然失却,我还是回来看看这分类排版皆惨淡的博客吧,只是是用来保存代码也好.想要换一个新博客,带着之前的经验能把它整 ...