将js进行到底:node学习6
开始真正的node web开发——express框架
为何说现在才是web开发的真正开始呢?
首先任何企业都不会用原生的http协议API去开发一个完整的网站,除非她们先开发一个框架出来,其次我们之前的所谓http,connect都只是打开了一个http服务器而已,顶多只能算个工具集(中间件),最后使用像express这样的框架使我们把精力集中到功能业务上来了!
生产力因此而得以体现!
引入express
上一章,即便我们已经可以使用connect处理用户各种请求了,但依然需要我们人为的去关注路由,文件判断,并且connect,serve-static只是起到了纯中间作用,且拼拼凑凑组合出一个看上去还不错的网站,这些并没有直接加强HTTP这个API。
可以发现我们依然在使用 require("http").createServer()"
来创建http服务
package.json
{
"name":"test-express",
"version":"0.0.1",
"description":"an express example",
"dependencies":{
"express":"latest",
"jade":"latest"
}
}
npm install
Express是直接在http上加强的,封装了http API,我们不必再为http API缺少操心了
Express创建HTTP服务器
var express = require("express");
var app = express();
app.get('/',function(req,res){
res.send("hello world");
});
app.listen(3000);
可以看到express模块暴露的express方法本身,返回一个对象,其get方法已经解决了路径处理的问题。这是一个非常简单的示例页面,已经让我感受到了他将会使得web开发变得十分简单。
Express托管静态文件
使用express框架express.static来对上一回中的serve-static托管静态文件做修改,必须说明的是:express.static 是 Express 内置的唯一一个中间件。是基于 serve-static 开发的,负责托管 Express 应用内的静态资源。(官网说明)
新建一个public目录专门存放静态文件:css,js,images等资源文件都可以
app.use(express.static('public'));
只需要一行代码,测试效果
Express视图业务分离——模板渲染引擎Jade
在刚开始开发web那会,我一直无法理解php的smarty是什么,在开发了javaee之后,慢慢熟悉了一个名词“模板引擎”,由于php本身可以内嵌html所以,很容易让初学者忽视了这个模板引擎的概念,后来,开发java之时,我们需要将前端(html)后端(java)进行分离的时候,就需要接触到模板引擎了,主要作用:
在纯html文件中输入规定格式的变量或者逻辑语言,在经过http发送给客户端浏览器前将其中的变量标记替换为对应的值,并且将逻辑语言编程,最终生成纯html文件流发送给客户端。
通俗言之:模板引擎像一个加工模具,将非纯html(带模板代码)装入,生成新的,完善的纯html代码,这样我们不需要在html中直接嵌入后端语句来动态修改页面,这实现了逻辑和视图的分离(模板引擎是动态网站的核心内容之一)
举个栗子,使用Jade模板引擎!(需要外部模块,前面package.json中已经加入了)
首先模板存放位置,新建:views目录->新建index.jade文件
前端index.jade
doctype
html
head
title= pageTitle
script(type='text/javascript').
function showCityEx(city)
{
return city + " & " + city;
}
body
h1 #{h1}
table(border=1)
tr
th hello
th world,citys.count=#{cscores.length + 3}
th count
for city,index in citys
tr
td= index
td welcome to #{city}(#{city.substr(0,4)})
td= cscores[index]
div over!
后端:index.js
var express = require("express");
var app = express();
var city_names = [
'wuhan',
'tianjin',
'beijing',
'shanghai'
];
var city_scores = [
'60',
'62',
'80',
'70'
];
app.use(express.static('public'));
app.set("view engine","jade");
app.set("views",__dirname+"/views");
app.get('/',function(req,res){
res.render("index",{citys:city_names,cscores:city_scores});
});
app.listen(3000);
解释
学习express先不理会那些jade模板代码,如需了解,参考Jade官网API:http://jade-lang.com/
重心放在nodejs代码上,app.get方法并没有改变,参数URL绑定了参数回调函数。
res调用了render,是模板引擎渲染方法,表示向客户端输出一个渲染后的html
- 配置一:使用app.set可以配置express,将view engine设置为jade
- 配置二:将模板存放位置配置为:views目录,我们将jade文件放在里面,以后自动读取
- render参数一:文件名,不带后缀
- render参数二:jade模板中需要替换掉的变量
- render还有一个参数是回调函数,处理生成的html,可以这样写:
res.render("index",function(err,html){
//继续处理html,比如打印到控制台console.log(html);
});
模板引擎的基本使用套路无非就是:设置模板类型,设置模板目录,render出来!
Jade模板语言本身值得我们单独拿出来学习!
Express request与response
整个HTTP开发都围绕着request(用户请求)和response(响应请求)在做开发。
express为我们封装了http的req与res对象,方便开发。
记录一些常见的对象方法:
Request
如果直接打印req对象你会看到一堆乱七八糟东西,没啥意思。
打印如下这些东西研究一下:
params对象
app.get('/user/:name',function(req,res){
console.log(req.params.name);
})
地址栏输入:http://localhost:3000/user/devil
终端显示:
query对象
app.get('/user',function(req,res){
console.log(req.query.name);
});
地址栏输入:http://localhost:3000/user?name=devil
终端显示:同上!
Response
download()
app.get('/getimg',function(req,res){
res.download(__dirname+"/public/images/xq.jpg");
});
用于下载文件,使用后强制用户下载该文件
json()和jsonp()
app.get('/json',function(req,res){
res.json({name:"devil",sex:"男",body:"strong"});
});
强制将js对象转换为json数据格式发送给客户端,后者则支持jsonp,效果一样。
redirect()
app.get('/baidu',function(req,res){
res.redirect('http://www.baidu.com');
});
重定向到其他页面
send()
app.get('/send',function(req,res){
res.send({some:'json'});
});
send是express非常常用的方法,功能巨多,优点是可自动转化格式,输入数字发送状态码,输入字符串返回客户端字符串,输入js对象返回json对象,他能对参数数据类型做很好的判断,要优于上述json()方法。
sendFile()
app.get('/send',function(req,res){
res.sendFile("E:\\视频\\电影\\v字仇杀队.mp4");
});
这个就有意思了,是发送文件,但并不会使得用户下载,应该是以二进制流的方式发送文件,理论上还需要浏览器支持,测试后效果:
如果是图片文件,则显示图片。
将js进行到底:node学习6的更多相关文章
- 【特别推荐】Node.js 入门教程和学习资源汇总
这篇文章与大家分享一批很有用的 Node.js 入门教程和学习资源.Node 是一个服务器端的 JavaScript 解释器,它将改变服务器应该如何工作的概念.它的目标是帮助程序员构建高度可伸缩的应用 ...
- Node.js 入门教程和学习资源汇总
这篇文章与大家分享一批很有用的 Node.js 入门教程和学习资源.Node 是一个服务器端的 JavaScript 解释器,它将改变服务器应该如何工作的概念.它的目标是帮助程序员构建高度可伸缩的应用 ...
- Node.js环境搭建和学习(windwos环境)
Node.js环境搭建和学习 一.环境搭建 1.下载安装文件 下载地址http://nodejs-org.qiniudn.com/下载Node.js环境安装包,根据操作系统下载对应的安装包 下载地址 ...
- node 学习笔记 - Modules 模块加载系统 (1)
本文同步自我的个人博客:http://www.52cik.com/2015/12/11/learn-node-modules-path.html 用了这么久的 require,但却没有系统的学习过 n ...
- [学姿势]实验室搬砖+node学习
这周开始进行收尾工作,我当然没有进行核心技术的开发,主要负责的是对web端进行展示上的修修补补,主要包括添加VLC播放器.rtsp视频流以及一些js细节. 1.VLC 全称为Video Lan Cli ...
- 2015第40周二Node学习
node历史 今天看cnode开源项目用了io.js,在查这个项目时发现这篇文章node历史,node.js和io.js关系谈到Node.js的由来,不可避免要聊到它的创始人Ryan Dahl.在20 ...
- 2015第40周一Node学习
node学习尝试 早上看了张丹大牛博客文章nodeJS学习路线图和node从零入门系列,感觉获益匪浅,尝试了里面几项内容,对node有了更深入的认识. npm npm是一个node包管理和分发工具,已 ...
- Node学习——开篇
前言:自从下决心转学前端以来,我的专业课java基本荒废了,所以对于后台开发的逻辑也已基本忘干净了.但是作为一名准前端程序猿,我认为还是有必要了解后端开发的,虽不必深入学习,但是能够了解项目从前端到后 ...
- node 学习资料
Node 学习资料: 资料名称 网址 Node.js 中文API文档 http://nodejs.cn/api/ Node 菜鸟教程 http://www.runoob.com/nodejs/node ...
- Node学习HTTP模块(HTTP 服务器与客户端)
Node学习HTTP模块(HTTP 服务器与客户端) Node.js 标准库提供了 http 模块,其中封装了一个高效的 HTTP 服务器和一个简易的HTTP 客户端.http.Server 是一个基 ...
随机推荐
- winEdt打开tex文件报错解决方法
写论文真的是不断遇到各种困难啊,这个Latex软件就很多,好不容易中个A1区的文章,期刊说更新了新的模板就下载了,忽然发现打开有reading error,看不到一点内容,神奇的是竟然可以运行.这样的 ...
- ⼩程序中⽀持es7的async语法
⼩程序中⽀持es7的async语法 es7的 async 号称是解决回调的最终⽅案 在⼩程序的开发⼯具中,勾选 es6转es5语法 下载 facebook 的 regenerator 库中的 rege ...
- 嵌入式c语言编码规范
学习嵌入式的同学应该首先掌握嵌入式编码规范,这样才能更好的嵌入式系统. 下面就从这几个方面讲解一下嵌入式c编码规范. 注释风格.排版风格.头文件风格.变量定义.宏定义.函数 1 注释风格 1.1 注 ...
- G. Petya and Graph(经典项目与项目消耗问题)(网络流)
题:https://codeforces.com/contest/1082/problem/G 题意:给定有边权和点权的图,问你选一些边,然sum边-sum点最大(点权被多次用为公共点只会减一次) 分 ...
- Debian8.8为普通用户添加sudo权限
1.进入root用户,su root 输入密码,我们首先修改 /etc/sudoers 文件的属性为可写权限# chmod +w /etc/sudoers2.编辑 vim /etc/sudoers,添 ...
- 直播弹幕抓取逆向分析流程总结 websocket,flash
前端无秘密 直播的逆向抓取说到底是前端的调试和逆向技术,加上部分的dpa(深入包分析,个人能力尚作不到深入,只能作简单分析)难度较低 目前互联网直播弹幕主要是两种技术实现. 1websocket消息通 ...
- crontab不执行service命令
我这里的需求是每30分钟重启一次 写成下面的格式就可以正确执行了,后面执行的命令写绝对路径 */30 * * * * /usr/bin/supervisorctl restart all
- learning Perl:91行有啥用? 88 print "\n----------------------------------_matching_multiple-line_text--------------------------\n"; 91 my $lines = join '', <FILE>;
89 open FILE, "< file_4_ex_ch7.txt" 90 or die "cannot open file: $!"; ...
- D. Fish eating fruit
题:https://nanti.jisuanke.com/t/41403 题意:求任意俩点之间距离之和模3后的三个结果的总数(原距离之和) 第一种做法: 树形dp #include<bits/s ...
- VMware 安装 Centos7 后,没有ipv4的地址,或者地址显示127.0.0.1
问题描述:VMware 安装 Centos7 后,没有ipv4的地址,或者地址显示127.0.0.1 安装环境:VMware版本:VMware-workstation-full-14.0.0.2405 ...