nodejs框架express准备登录
目录:
- 安装模板
- 静态资源
- 添加视图
- 渲染视图
- url重定向
模板引擎
从本节课程开始我们要使用express框架实现一个简单的用户登陆功能,让我们先准备一下相关资源。
在nodejs中使用express框架,它默认的是ejs和jade渲染模板,今天我们就以ejs模板为例,讲述模板渲染网页模板的基础功能。
1. ejs模板安装方法
npm install ejs
2. 目录下安装好了之后,如何调用呢,如下所示:
//指定渲染模板文件的后缀名为ejs
app.set('view engine', 'ejs');
3. 默认ejs模板只支持渲染以ejs为扩展名的文件,可能在使用的时候会觉得它的代码书写方式很不爽还是想用html的形式去书写,该怎么办呢,这时就得去修改模板引擎了,也就会用到express的engine函数。
4. engine注册模板引擎的函数,处理指定的后缀名文件。
// 修改模板文件的后缀名为html
app.set( 'view engine', 'html' );
// 运行ejs模块
app.engine( '.html', require( 'ejs' ).__express );//两个下划线
"__express",ejs模块的一个公共属性,表示要渲染的文件扩展名。
静态资源
由于环境的限制,这里我们就不使用静态资源了,但是实际开发中我们肯定会用到,具体使用规则已在下面列出,可参考。
如果要在网页中加载静态文件(css、js、img),就需要另外指定一个存放静态文件的目录,当浏览器发出非HTML文件请求时,服务器端就会到这个目录下去寻找相关文件。
1. 项目目录下添加一个存放静态文件的目录为public。
2. 在public目录下在添加三个存放js、css、img的目录,相应取名为javascripts、stylesheets、images。
3. 然后就可以把相关文件放到相应的目录下了。
4. 比如,浏览器发出如下的样式表请求:
<link href="/stylesheets/bootstrap.min.css" rel="stylesheet" media="screen">
服务器端就到public/stylesheets/目录中寻找bootstrap.min.css文件。
有了静态目录文件,我们还得在启动文件里告诉它这个静态文件路径,需要指定一下,如下所示:
app.use(express.static(require('path').join(__dirname, 'public')));
PS:express.static —— 指定静态文件的查找目录。
使用use函数调用中间件指定express静态访问目录,'public'就是我们我们新建的用来存放静态文件的总目录。
添加视图
好,下面我们就来添加网页模板了,项目中我们会新建一个目录用来单独存放模板文件,这里我们就统一放到根路径上了。
下面开始新建index.html、login.html、home.html三个页面。
1. index.html页面参考内容如下:
<div style="height:400px;width:550px;margin:50px auto;margin-left:auto;border:solid 1px;background: rgb(246, 246, 253);">
<div style="margin-left: 35px;">
<h1>首页</h1>
<form action="#" role="form" style="margin-top: 90px;margin-left: 60px;">
<h1>欢迎进入首页!</h1>
<div style="margin-top: 145px;">
<input type="button" value="登 陆">
</div>
</form>
</div>
</div>
2. login.html页面参考内容如下:
...
<title>用户登录</title>
<meta charset="utf-8">
<script src="http://code.jquery.com/jquery-2.1.1.min.js"></script>
... <div style="height:300px;width:350px;margin:100px auto;margin-left:auto;border:solid 1px;background: rgb(246, 246, 253);">
<div style="width:200px;margin:auto;margin-top:50px;">
<h1>用户登录</h1>
<form action="#" role="form" method="post">
<input id="username" type="text" name="username" style="margin: 20px 0px;">
<input id="password" type="password" name="password">
<div style="margin-top:30px;margin-left:125px;">
<input type="button" value="登 陆">
</div>
</form>
</div>
</div>
3. home.html页面参考内容如下:
<div style="height:400px;width:550px;margin:50px auto;margin-left:auto;border:solid 1px;background: rgb(246, 246, 253);">
<div style="margin-left: 45px;">
<h1>主页</h1>
<form action="#" role="form" style="margin-top: 90px;">
<h1>登陆成功!</h1>
<div style="margin-top: 145px;">
<input type="button" value="退 出">
</div>
</form>
</div>
</div>
访问视图
我们要如何对网页模板进行访问呢,这就要用到res对象的render函数了。
1. render函数,对网页模板进行渲染。
2. 格式:res.render(view, [locals], callback);
3. 参数view就是模板的文件名callback用来处理返回的渲染后的字符串,options、callback可省略,在渲染模板时[locals](JSON格式)可为其模板传入变量值,在模板中就可以调用所传变量了,在后面我们会讲述具体使用方法,也可先自行使用看其效果。
4. 比如渲染我们刚刚添加的index.html页面,我们就可以在app.js中写入如下内容:
var express = require('express');
var app = express();
var path = require('path');
app.set('views', __dirname);
app.set( 'view engine', 'html' );
app.engine( '.html', require( 'ejs' ).__express );
app.get('/', function(req, res) {
res.render('index');
});
app.listen(80);
4. 和静态文件一样,我们也要设置views存放的目录,如下:
// 设定views变量,意为视图存放的目录
app.set('views', __dirname);
有了网页模板和指定目录,下面就可以访问它们了。
redirect基本用法
redirect方法允许网址的重定向,跳转到指定的url并且可以指定status,默认为302方式。
格式:res.redirect([status], url);
例1:使用一个完整的url跳转到一个完全不同的域名。
res.redirect("http://www.hub wiz.com");
例2:跳转指定页面,比如登陆页,如下:
res.redirect("login");
nodejs框架express准备登录的更多相关文章
- nodejs框架express实现登录
目录: 访问视图 Post请求 Post请求 - body(1) Post请求 - body(2) Post登陆1 Post登陆2 页面访问控制1 页面访问控制2 访问视图 前面我们已经添加了视图模板 ...
- NodeJS 框架 Express 从 3.0升级至4.0的新特性
NodeJS 框架 Express 从 3.0升级至4.0的新特性 [原文地址:√https://scotch.io/bar-talk/expressjs-4-0-new-features-and-u ...
- [转] NodeJS框架express的途径映射(路由)功能及控制
NodeJS框架express的路径映射(路由)功能及控制 我们知道Express是一个基于NodeJS的非常优秀的服务端开发框架,本篇CSSer将提供express框架的route和route co ...
- 知名nodeJS框架Express作者宣布弃nodeJS投Go
知名 nodeJS 框架 Express 的作者 TJ Holowaychuk 在 Twitter 发推并链接了自己的一篇文章,宣布弃 nodeJS 投 Go. 他给出的理由是:Go 语言和 Rust ...
- nodejs框架express快速开始
认识express 创建应用 get请求 简述中间件 all方法 use方法1 use方法2 回调函数 获取主机.路径名 Get请求 - query Get请求 - param Get请求 - par ...
- NodeJS框架express的路径映射(路由)功能及控制
我 们知道Express是一个基于NodeJS的非常优秀的服务端开发框架,本篇CSSer将提供express框架的route和route control章节,route实现了客户端请求的URL的路径映 ...
- CentOS安装运行NodeJS框架Express
安装依赖包 yum -y install gcc make gcc-c++ openssl-devel wget 下载/解压NodeJs wget http://nodejs.org/dist/v0. ...
- (转)windows下安装nodejs及框架express
转自:http://jingyan.baidu.com/article/456c463b60fb380a583144a9.html windows下安装nodejs及框架express nodejs从 ...
- nodejs的Express框架源码分析、工作流程分析
nodejs的Express框架源码分析.工作流程分析 1.Express的编写流程 2.Express关键api的使用及其作用分析 app.use(middleware); connect pack ...
随机推荐
- OSG-OSGEarth
OSG-OSGEarth 初次使用Cmake——以OsgEarth工程创建为例 转:http://www.cnblogs.com/Realh/archive/2012/02/08/2342507.ht ...
- Emmet:HTML/CSS代码快速编写神器
本文来源:http://www.iteye.com/news/27580 ,还可参考:http://www.w3cplus.com/tools/emmet-cheat-sheet.html Em ...
- mysql主从复制过滤
主从复制过滤: 配置文件中的[mysqld]块中: master:(考虑到即时点还原一般不在主过滤) binlog_do_db= #数据库白名单 binlog_ignore_db= #数据库白名单 s ...
- c# 函数练习
1.out的使用 2.100以内与7无关的数(个位数是7,十位数是7,7的倍数) 每日一句:不求与人相比,但求超越自己,要哭就哭出激动的泪水,要笑就笑出成长的性格!
- 第 6 章 贴近servlet
服务器在获得请求的时候会先根据jsp页面生成一个java文件,然后使用jdk的编译器将此文件编译,最后运行得到的class文件处理用户的请求返回响应.如果再有请求访问这jsp页面,服务器会先检查jsp ...
- Jquery中animate可以操作css样式属性总结
可以用 animate() 方法来操作所有 CSS 属性吗? 是的,几乎可以!不过,需要记住一件重要的事情:当使用 animate()时, 必须使用 Camel 标记法书写所有的属性名,比如,必须使用 ...
- android之消息机制(二)
消息通道:Looper 首先编写main.xml文件 代码如下: <LinearLayout xmlns:android="http://schemas.android.com/apk ...
- 手动给控制器添加xib
UIViewController绑定xib界面可视化,有两种方式: 1.第一种(自动化),在创建控制器时,勾选xib选项. 2.第二种手动创建一个Xib,然后再手动绑定到对应的控制器上
- IOS第18天(2,CALayer自定义图层)
- (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typica ...
- Codeforces Round #350 (Div. 2) D2 二分
五一期间和然然打的团队赛..那时候用然然的号打一场掉一场...七出四..D1是个数据规模较小的题 写了一个暴力过了 面对数据如此大的D2无可奈何 现在回来看 一下子就知道解法了 二分就可以 二分能做多 ...