express开发(一)简介与搭建
ccwgpt 2025-04-27 12:50 6 浏览 0 评论
上周末去了趟上海书城,不愧是上海数得上号的书城,流行的科技书应有尽有,话不多说直接上图。
最经典的C语言O(∩_∩)O
最流行的java(づ ̄ 3 ̄)づ
超酷的R语言/(ㄒoㄒ)/~~
然而,身为一个坚定的前端JSer,我还是选择了Node与javascript
上图!
Node赛高!Express赛高!
下面让题主来以一个长者的身份讲讲对express的简单理解,看完后你们还会知道怎样搭建一个属于自己的简单的express服务端。(此中有膜意,欲辩已忘言。)
Express简介
Express网站(http://expressjs.com/)上是这样介绍Express的:"Fast, unopinionated, minimalist web framework for Node.js"。翻译过来就是:“精简的、灵活的Node.js Web程序框架,为构建单页、多页及混合的Web程序提供了一系列健壮的功能特性。”(没错,翻译过来就是这么长)
Express的缔造者TJ·Holowaychuk说Express是在Sinatra的启发下创建的,后者是一个基于Ruby的框架。Express借鉴一个Ruby上的框架并不奇怪:Ruby致力于让Web开发变得更快、更高效、更可维护,并衍生了大量的Web开发方式。
Express还与Node的一个插件--connect有紧密的联系,然而在Express4.0中,connect插件被去掉了,只剩下了static中间件。
搭建一个简单的项目
下面我们要建一个简单的基于express4.0的小项目,会实现一些基础的功能:
定制404、500页面
使用express中的res.send、res.set、res.status替换Node中自带的res.end、res.writeHead
了解express中的路由
首先用npm安装express,在你的文件夹下,如test中运行
npm init
初始化之后,运行
npm install -S express
这样npm会将express下载道node_modules中,并更新你的package.json文件,将express写入你的依赖中。
接下来创建一个mydemo.js文件,作为我们项目的入口。
(Node与Express开发的作者Ethan Brown任务,项目的入口文件命名不应该是千篇一律的index.js或者app.js,应该基于你的项目名来命名。npm init默认的使用index.js,如果你使用了别的文件来做主文件,记得修改package.json中的main属性。)
在其中输入如下代码:
var express = require('express');
var app = express();
app.set('port', process.env.PORT || 3000);
//定制404页面
app.use(function(req, res){
res.type('text/plain');
res.status('404');
res.send('404 - Not Found');
});
app.use(function(req,res){
console.err(err.stack);
res.type('text/plain');
res.status('500');
res.send('500 - Server Error');
});
app.listen(app.get('port'), function(){
console.log('Express is started on http://localhost:' + app.get('port') + ';press Ctrl + C to terminate.');
});
然后在命令行输入
node mydemo.js
访问http://localhost:3000/你会看到它返回了一个404页面,因为你还没设置“/”路径。
现在我们的项目结构如下。
现在,我们给首页和关于页面加上路由。在404处理器之前加上两个新路由。
'use strict';
app.get('/', function(req, res){
res.type('text/plain');
res.send('mydemo home page');
});
app.get('/about', function(req, res){
res.type('text/plain');
res.send('about page');
})
//定制404页面
app.use(function(req, res){
res.type('text/plain');
res.status('404');
res.send('404 - Not Found');
});
Express官方文档中有这样一个命令——app.VERB。这里的app.VERB并不是一个具体的方法,而是自带HTTP的动词(最常见的是get和post)。这种方法有两个参数:一个路径和一个函数。
之后再次运行程序,就可以看到我们的首页和about页面了。
现在我们对程序做一些小小的改动,是的路由跟项目入口文件分离开来,这在大型项目中是必要的过程,因为路由一旦过多再跟启动文件混合在一起就不易维护,所以要将他们分离开来。
创建一个新的文件夹routes,在其中创建文件main.js
输入如下代码:
'use strict';
var router = require('express').Router();
router.get('/', function(req, res){
res.type('text/plain');
res.send('mydemo home page');
});
router.get('/about', function(req, res){
res.type('text/plain');
res.send('about page');
})
module.exports = router;
这里使用了express的router方法,是express推荐的router中间件,使用也很简单,跟之前用app实例直接操作路由没太大的区别。之后我们将mydemo.js修改如下:
'use strict';
var express = require('express');
var app = express();
var main = require('./routes/main');
app.set('port', process.env.PORT || 3000);
app.use('/', main);
//定制404页面
app.use(function(req, res){
res.type('text/plain');
res.status('404');
res.send('404 - Not Found');
});
app.use(function(req,res){
console.err(err.stack);
res.type('text/plain');
res.status('500');
res.send('500 - Server Error');
});
app.listen(app.get('port'), function(){
console.log('Express is started on http://localhost:' + app.get('port') + ';press Ctrl + C to terminate.');
});
我们用var main = require('./routes/main');引入创建的route文件,再用app.use('/',main)使用。运行后会发现,效果跟之前是一样的。当然你也可以设置app.use('/tset', main)。这样你要访问localhost:3000/test和localhost:3000/test/about才能看到你设置的两个路由。
现在我们的项目结构如下:
小结
我们用express搭建了一个简单的项目,使用了router中间件,app.get,app.set方法。
之后我们会讲exprss中的视图和布局,并使用handlebars来作为我们的前端模板。
大家可以访问我的github。
https://github.com/ZZR-china/node_express
做了些微小的工作,谢谢大家。
欢迎订阅和点赞收藏哦O(∩_∩)O。
相关推荐
- NestJS入门教程系列一
-
介绍Nest(NestJS)是用于构建高效,可扩展的Node.js服务器端应用程序的框架。它使用渐进式JavaScript,内置并完全支持TypeScript(但开发人员仍然能够使用JavaScrip...
- 【推荐】一个网盘资源搜索与转存工具,支持移动端与PC端!
-
如果您对源码&技术感兴趣,请点赞+收藏+转发+关注,大家的支持是我分享最大的动力!!!项目介绍CloudSaver是一个基于Vue3和Express的网盘资源搜索与转存开源实用工具。它支持...
- Appium原理精讲
-
目前使用Appium新版本和旧版本的企业数目都很多,而两个版本的安装过程和api的使用又有较大的区别。但是无论表面上的东东如何变化,内部原理都是一样的。在这里我给大家介绍一下appium的核心,增进大...
- Kubernetes最小部署单元Pod
-
一、Kubernetes与Pod简介在当今云计算和容器化技术盛行的时代,Kubernetes已然成为容器编排领域的中流砥柱。它是一个开源的容器编排平台,由Google基于其内部使用的Bo...
- 最常用的四种跨域解决方案
-
前置知识什么是跨域?浏览器发送的请求地址(URL)与所在页面的地址不同(端口/协议/域名其一不同)。简言之,浏览器发出的请求url,与其所在页面的url不一样。此时,同源策略会让浏览器拒收服务器...
- Bolt.New —— 全栈AI Web自动编程
-
Bolt.New是由StackBlitz公司推出的,全栈AI工具,代码编辑、运行、部署,通通一站式搞定。它使用WebContainers技术,无需任何本地安装或配置,在浏览器中,就可以运行完整的No...
- Nodejs Express新手教程&高手进阶
-
NodejsExpress新手教程&高手进阶Express是一个NodeJS平台的框架,主要用于构于Web服务器项目。本文将通过示例介绍适合新手入门的Express基础使用,以及高手进阶知识,如:c...
- Express.js 创建Node.js Web应用
-
Express.js是一个基于Node.js的Web应用框架,框架的设计目的是构建应用的架构和简化应用的开发。框架会解决一些通用的问题,在Express.js中,Express框架会处理如:中间件、代...
- JavaScript 的 Express.js 功能及应用场景详解
-
Express.js是一个基于Node.js的轻量级Web应用框架,主要用于快速构建服务器端应用和API。它的核心功能包括以下关键点:1.路由管理URL路径与HTTP方法映射:通过...
- nodejs的express4文件下载
-
在nodejs的express框架中,下载变得非常简单,就一个方法,res.download()首先express命令行生成项目基本框架:不会的看这里:http://blog.csdn.net/zz...
- Express 系列:快速生成一个项目
-
系列预告本系列将以一个项目入手结合相关技术细节来带领大家一起学习Express这个基于Node.js的后端框架。本文首先将介绍:如何快速的生成一个具有一定结构的Express项目。Express项目结...
- nodejs的express自动生成项目框架
-
nodejs版本为:4.X,express版本为4.X1.全局安装2个模块express、express-generator在命令行输入:npminstall-gexpressnpminsta...
- express开发(一)简介与搭建
-
上周末去了趟上海书城,不愧是上海数得上号的书城,流行的科技书应有尽有,话不多说直接上图。最经典的C语言O(∩_∩)O最流行的java(づ ̄3 ̄)づ超酷的R语言/(ㄒoㄒ)/~~然而,身为一个坚定的前...
- Vue+Echarts可视化大屏系统后端框架搭建(附代码)
-
各位同学,大家好。上节课,前面我们讲解了Vue+Echarts前端部分的设计方法。这节课程,我们开始讲解使用Express进行后端设计的方法。01项目相关理论介绍什么是expressExpress是...
- Shopify电商API接口开发
-
Shopify电商API接口开发上线流程主要包括以下步骤。北京木奇移动技术有限公司,专业的软件外包开发公司,欢迎洽谈合作。前期准备-注册Shopify账号:在Shopify官网注册,用于后续开发测试...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- MVC框架 (46)
- spring框架 (46)
- 框架图 (58)
- bootstrap框架 (43)
- flask框架 (53)
- quartz框架 (51)
- abp框架 (47)
- jpa框架 (47)
- laravel框架 (46)
- express框架 (43)
- scrapy框架 (52)
- beego框架 (42)
- java框架spring (43)
- grpc框架 (55)
- 前端框架bootstrap (42)
- orm框架有哪些 (43)
- ppt框架 (48)
- 内联框架 (52)
- winform框架 (46)
- gui框架 (44)
- cad怎么画框架 (58)
- ps怎么画框架 (47)
- ssm框架实现登录注册 (49)
- oracle字符串长度 (48)
- oracle提交事务 (47)