[AaronYang]那天有个小孩跟我说Js-NodeJS[AY0]-EJS
按照自己的思路学习Node.Js 随心出发。EJS是Node.js中express框架中使用的一个模版引擎,当然还有Jade
我的学习就靠网上查资料,没有买书系统学,自己整理,如果有用了哪位大神的代码,还请原谅,表森气.奴婢知错了
标签:AaronYang 茗洋 Node.Js Javascript
本篇博客地址:http://www.cnblogs.com/AaronYang/p/4060189.html
开发准备(AaronYang原味)
1你需要一个Node.js开发工具

2基础回顾,Ejs,因为我是开发ASP.NET MVC的,所以更靠近微软的一边,更多的都会和.NET做对比

3GO GO GO!
1、缓存功能,能够缓存已经解析好的html模版;
2、<% code %>用于执行其中javascript代码;
3、<%= code %>会对code进行html转义;
4、<%- code %>将不会进行转义;
5、支持自定义标签,比如'<%'可以使用'{{','%>'用'}}'代替;
6、提供一些辅助函数,用于模版中使用
7、利用<%- include filename %>加载其他页面模版;
1.测试数组(写完只有一句尼玛,回到了jsp...的感觉)
/* GET home page. */
router.get('/', function(req, res) {
res.render('index', {
title: 'Express',
goods:['裤子','内衣','上衣','小三角']
});
});
我们在对应的views中的index.ejs网页中,代码如下:
<!DOCTYPE html>
<html>
<head>
<title><%= title %></title>
<link rel='stylesheet' href='/stylesheets/style.css'/>
<link rel="stylesheet" href="/stylesheets/cssreset.css"/>
<style>
body {
background-image: url('/images/1.jpg');
}
</style>
</head>
<body>
<h1><%= title %></h1> <p>Welcome to <%= title %></p>
<!--简单数组遍历-->
<!--<ul>-->
<!--<li>裤子</li>-->
<!--<li>裤子</li>-->
<!--<li>裤子</li>-->
<!--</ul>-->
<% for(var i = 0;i < goods.length;i++){ %>
<li>
<a href='http://<%= goods[i] %>'><%= goods[i] %></a>
</li>
<% } %>
</body>
</html>
我们直接可以使用goods对象了,我们通过<%%>这种方式来配合html方式遍历输出对象中的值
<%= %>是直接输出对象的值,你就理解<% js代码 %>中是js代码就OK啦

在jsp中是上面import后,输出对象的值,在.net的对比 razor中的@对象.属性 就行了
2.局部视图,类似.net mvc的PartialView,Ejs中也有类似,在早期使用partial('ejs文件',传给视图的对象值),现在2014年10月30日18:39:45已经淘汰了
推荐使用include,当然include是不用传参的,所以你在render页面传递过来的对象叫什么名字,就在分页面使用那个对象就行了
2.1 在index.js文件中,增加一个变量,键值对类型的productlists
Tip:这里额外讲个path.dirname的使用,需要require引入 path包才可以使用,这里返回最后一个/ 前面的内容
var path = require('path');
router.get('/', function(req, res) {
console.log(path.dirname('/pro/code/aaronyang'))
res.render('index', {
title: 'Express',
goods:['裤子','内衣','上衣','小三角'],
productlists:[
{
"name":"aaronyang裤子","price":"129元"
},{
"name":"aaronyang内衣","price":"199元"
},{
"name":"aaronyang外套","price":"1098元"
},{
"name":"aaronyang小三角","price":"99元"
}
]
});
});
在views文件夹中增加一个productItem.ejs文件,默认webstorm只有jade,但是你可以Edit File Template增加一个Ejs File,这个很简单,不讲了

代码如下:
<!--以下代码是aaronyang摸索出来的,博客来自:http://aaronyang.cnblogs.com-->
<% if (productlists.length) {
productlists.forEach(function(value,index){
%>
<div>
<span> <%= value.name%></span>:<span><%= value.price %></span>
</div>
<%})}%>
Aaronyang nodejs代码
这里可以直接使用productlists对象,集合可以使用forEach方法,然后配合<%%>的使用就可以了
这里forEach的index参数可以省略,就是个索引0,1,2,3...的东西
效果如下:

OK! 创建一个数据源productlists,然后一个模板页,使用了数据源的对象,然后页面中重复使用这段代码,OK,运行吧!让奴婢看下

当然,include后面也可以跟路径,但是不要加引号,后缀名ejs可有可无
<% include productItem %>
附一份css重置html5样式css的文件,以后有用
/*
html5doctor.com Reset Stylesheet v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
margin:;
padding:;
border:;
outline:;
font-size:100%;
vertical-align:baseline;
background:transparent;
}
body {
line-height:;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
display:block;
}
nav ul {
list-style:none;
}
blockquote, q {
quotes:none;
}
blockquote:before, blockquote:after,
q:before, q:after {
content:'';
content:none;
}
a {
margin:;
padding:;
font-size:100%;
vertical-align:baseline;
background:transparent;
}
/* change colours to suit your needs */
ins {
background-color:#ff9;
color:#000;
text-decoration:none;
}
/* change colours to suit your needs */
mark {
background-color:#ff9;
color:#000;
font-style:italic;
font-weight:bold;
}
del {
text-decoration: line-through;
}
abbr[title], dfn[title] {
border-bottom:1px dotted;
cursor:help;
}
table {
border-collapse:collapse;
border-spacing:;
}
/* change border colour to suit your needs */
hr {
display:block;
height:1px;
border:;
border-top:1px solid #cccccc;
margin:1em 0;
padding:;
}
input, select {
vertical-align:middle;
}
aaronyang css重置
3. express4.x 的 include的版本layout方式
以前express3.x创建项目都有layout.ejs文件,然后render时候,可以指定layout参数,也就是相当于.net的母版页
好了,既然使用了express4.x,那么自己建立一个吧,我们写一个header.ejs和footer.ejs
header.ejs
<!DOCTYPE html>
<html>
<head>
<title><%= title %></title>
<link rel='stylesheet' href='/stylesheets/style.css'/>
<link rel="stylesheet" href="/stylesheets/cssreset.css"/>
<style>
body {
background-image: url('/images/1.jpg');
}
</style>
</head>
<body>
footer.ejs
</body>
</html>
然后我们修改index.ejs文件
<% include header%>
<h1><%= title %></h1>
<p>Welcome to <%= title %></p>
<!--简单数组遍历-->
<!--<ul>-->
<!--<li>裤子</li>-->
<!--<li>裤子</li>-->
<!--<li>裤子</li>-->
<!--</ul>-->
<% for(var i = 0;i < goods.length;i++){ %>
<li>
<a href='http://<%= goods[i] %>'><%= goods[i] %></a>
</li>
<% } %>
<hr/>
<% include productItem %>
<% include footer%>
效果还是一样的~
4. 使用Ejs自带的一些方法,增加一个对象testSelfMethod,用于测试,这里使用了Ejs的filter知识中的 upcase
res.render('index', {
title: 'Express',
goods:['裤子','内衣','上衣','小三角'],
productlists:[
{
"name":"aaronyang裤子","price":"129元"
},{
"name":"aaronyang内衣","price":"199元"
},{
"name":"aaronyang外套","price":"1098元"
},{
"name":"aaronyang小三角","price":"99元"
}
],
testSelfMethod:["Aaronyang1","Aaronyang2","Aaronyang3","Aaronyang4","hello aaronyang2014"]
});
使用<%=: %>
<hr/>
<%=: testSelfMethod[0] | upcase %>
这里网页输出的是 AARONYANG1

upcase方法就是转换成大写,更多的方法可以参考https://github.com/tj/ejs
<p><%=: testSelfMethod | last | capitalize %></p>
输出

从testSelfMethod对象中,最后一个值,将字符串 转换成 首字母为大写的字符串,本来hello 变成了Hello
下面我也列出来了几个,看名字大致也知道几个怎么用了
first 返回数组的第一个元素
last 返回数组的最后一个元素
capitalize 返回首字母大写的字符串
downcase 返回字符串的小写
upcase 返回字符串的大写
sort 排序
sort_by:'prop' 照指定的prop属性进行升序排序
size 返回长度,即length属性,不一定非是数组才行
length
plus:n 加上n,将转化为Number进行运算
minus:n 减去n,将转化为Number进行运算
times:n 乘以n,将转化为Number进行运算
divided_by:n 除以n,将转化为Number进行运算
join:'val' 将数组用'val'最为分隔符,进行合并成一个字符串
truncate:n 截取前n个字符,超过长度时,将返回一个副本
truncate_words:n 取得字符串中的前n个word,word以空格进行分割
replace:pattern,substitution 字符串替换,substitution不提供将删除匹配的子串
prepend:val 如果操作数为数组,则进行合并;为字符串则添加val在前面
append:val 如果操作数为数组,则进行合并;为字符串则添加val在后面
map:'prop' 返回对象数组中属性为prop的值组成的数组
reverse 翻转数组或字符串
get:'prop' 取得属性为'prop'的值
Tip:
在Ejs中,可以通过以下方式拓展一个 filter,在node.js中我还不知道怎么加上
ejs.filters.last = function(obj) {
return obj[obj.length - 1];
};
OK!
结尾话(AaronYang Ending)
[AaronYang]那天有个小孩跟我说Js-NodeJS[AY0]-EJS的更多相关文章
- [AaronYang]那天有个小孩跟我说Js正则
按照自己的思路学习Node.Js 随心出发.突破正则冷门知识点,巧妙复习正则常用知识点 标签:AaronYang 茗洋 Node.Js 正则 Javascript 本篇博客地址:http://ww ...
- 那天有个小孩教我WCF[一][2/3]
接着上次的继续讲吧 我们开始吧 9.创建数据库 use master go --创建库 if exists(select * from sysdatabases where name='NewsDB' ...
- 那天有个小孩教我WCF[一][1/3]
那天有个小孩教我WCF[一][1/3] 既然是小孩系列,当然要有一点基础才能快速掌握,归纳,总结的一个系列,哈哈 前言: 第一篇嘛,不细讲,步步教你创建一个简单SOA案例,对WCF有个基本的认识,我不 ...
- (转)那天有个小孩教我WCF[一][1/3]
原文地址:http://www.cnblogs.com/AaronYang/p/2950931.html 既然是小孩系列,当然要有一点基础才能快速掌握,归纳,总结的一个系列,哈哈 前言: 第一篇嘛,不 ...
- 那天有个小孩跟我说LINQ(五)转载
2 LINQ TO SQL(代码下载) 我们以一个简单的销售的业务数据库为例子 表结构很简单:Users(购买者(用户)表),Products(产品信息表),Sales(销 ...
- 那天有个小孩跟我说LINQ(三)转载
1 LINQ TO Objects续2(代码下载) 新建项目 linq_Ch3控制台程序 1.1 操作字符串 ①查找字符串中包含的大写字母,字符串是由多个char类型组 ...
- 那天有个小孩跟我说LINQ(八)学会Func
文章已经迁移到:http://www.ayjs.net/2013/08/68/ 文章已经迁移到:http://www.ayjs.net/2013/08/68/ 文章已经迁移到:http://www.a ...
- 那天有个小孩跟我说LINQ(七)转载
1 LINQ TO XML(代码下载) 准备:新建项目 linq_Ch7控制台程序,新建一个XML文件夹,我们就轻松地学习一下吧 XDocument ...
- 那天有个小孩跟我说LINQ(六)转载
2 LINQ TO SQL完结(代码下载) 我们还是接着上次那个简单的销售的业务数据库为例子,打开上次那个例子linq_Ch5 2.1 当数据库中的表建立了主外键 ①根据主键获取子表信息 ...
随机推荐
- BZOJ2325 [ZJOI2011]道馆之战 树链剖分 线段树
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ2325 题意概括 给你一棵N个点的树,树上的每个节点有A,B两块区域,且每种区域有两种状态:可以走的 ...
- BZOJ5074 小B的数字 BZOJ2017年10月月赛 其他
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ5074 题意概括 题解 作为蒟蒻的我第一个就选择了过的人最多的D题. 不仔细看好吓人. 然而并不难. ...
- 6-2 S树 uva712
这题关键是 反转 查询是固定按照x1x2x3来的 那么先收集前面的顺序 然后在数组里面直接调用即可 比如前面的树是 x3 x1 x2 就把这个当作数组下标 最左边的树是 1<&l ...
- Nightmare HDU1072
非常标准的BFS 第一次写错了很多 1.到达4时设置为墙就好了 避免了死循环 2.不用开d数组 在结构体里面就行了 3.结构体初始化函数的写法: Node(int x=0,int y=0,int ...
- 070 关于HBase的概述
1.hbase的特点 ->数据存储量可以达到亿级别数据维持在秒级 ->按列存储的数据库 ->能够存储上百万列 ->hbase的底层存储依赖于HDFS ->如何扩展hbas ...
- hdu 1394 (线段树求逆序数)
<题目链接> 题意描述: 给你一个有0--n-1数字组成的序列,然后进行这样的操作,每次将最前面一个元素放到最后面去会得到一个序列,那么这样就形成了n个序列,那么每个序列都有一个逆序数,找 ...
- hdu 1166 敌兵布阵【线段树】(求给定区间和)
题目链接:https://vjudge.net/contest/182746#problem/B 敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) ...
- HTTP协议学习笔记(三)
HTTP协议学习笔记(三) 1.状态码告知从服务器端返回的请求结果 状态码的职责是当客户端向服务端向服务端发送请求时,描述返回的请求结果.借助状态码,用户可以知道服务端是正常处理了请求,还是出现了错误 ...
- 算法进阶面试题02——BFPRT算法、找出最大/小的K个数、双向队列、生成窗口最大值数组、最大值减最小值小于或等于num的子数组数量、介绍单调栈结构(找出临近的最大数)
第二课主要介绍第一课余下的BFPRT算法和第二课部分内容 1.BFPRT算法详解与应用 找到第K小或者第K大的数. 普通做法:先通过堆排序然后取,是n*logn的代价. // O(N*logK) pu ...
- 10,EasyNetQ-发布确认
默认的AMQP发布不是事务性的,并且不能保证您的消息实际上会到达代理. AMQP指定了一个事务性发布,但是对于RabbitMQ来说,它非常慢,我们还没有通过EasyNetQ API支持. 对于高性能保 ...