koa2使用ejs和nunjucks作为模板引擎的使用


Posted in Javascript onNovember 27, 2018

一、使用 ejs 作为模板引擎

koa2 如果使用 ejs、jade 这种作为模板引擎的话,直接使用 koa-views 进行模板加载即可。

比如使用 ejs :

安装:

yarn add koa-views ejs

使用:

在使用 render 的时候,需要进行异步文件模板读取,因此 ctx.render 需要使用 await

const app= require('koa')();
const koaViews= require('koa-views');
const path = require('path');

app.use(koaViews(path.join(__dirname, './view'), {
 extension: 'ejs'
}));

app.use( async ( ctx ) => {
 const title = "postbird";
 await ctx.render('index', {
 title
 });
});

app.listen(3000)

二、使用 nunjucks 作为模板引擎

我实在是讨厌 ejs 的模板引擎语法,觉得太弱也太麻烦,而且新版本中,去除了模板继承,很不方便。

我比较喜欢 nunjucks ,另外我发现了一个 aui-template 的模板引擎,语法使用起来很舒服,速度也很快,可以体验一下。

aui-template 文档地址:

http://aui.github.io/art-template/zh-cn/docs/

1、安装 koa-nunjucks-2

使用 nunjucks 作为模板引擎,不需要安装 koa-views。

并且可以借助别人封装好的中间件 koa-nunjucks-2 来实现,koa-nunjucks 这个名字已经被使用,但是作为很烂,也没维护。

有时间我会看看他的源码,怎么加载的 nunjucks

yarn add koa-nunjucks-2

2、使用 nunjucks

const koaNunjucks = require('koa-nunjucks-2');

app.use(koaNunjucks({
 ext: 'njk',
 path: path.join(__dirname, './views'),
 nunjucksConfig: {
 trimBlocks: true
 }
}));

3、渲染模板

同样,异步文件读取,需要使用 await 。

router.get('view', async (ctx) => {
 var food = {
 'ketchup': '5 tbsp',
 'mustard': '1 tbsp',
 'pickle': '0 tbsp'
 };
 await ctx.render('index',{title:'nunjucks',food});
});

4、模板语法

更多的语法可以看文档:

https://mozilla.github.io/nunjucks/cn/templating.html#for

<body>
 <h1>{{title}}</h1>
 <p>循环:</p>
 <ul>
 {% for key,value in food %}
  <li>{{key}} - {{value}}</li>
 {%endfor%}
 </ul>
</body>

三、效果

koa2使用ejs和nunjucks作为模板引擎的使用

四、问题

在使用 koa-nunjucks-2 的时候,发现一个问题:

app.use(nunjucks({})) 必须放在 app.use(router.routes()).use(router.allowedMethods()) 前面才能起作用,否则会报错 ctx.render() 不是一个 function。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JQuery获取元素文档大小、偏移和位置和滚动条位置的方法集合
Jan 12 Javascript
js取消单选按钮选中并判断对象是否为空
Nov 14 Javascript
JS中的异常处理方法分享
Dec 22 Javascript
浅析javascript中的DOM
Mar 01 Javascript
浅谈DOCTYPE对$(window).height()取值的影响
Jul 21 Javascript
微信小程序  生命周期详解
Oct 27 Javascript
VUE开发一个图片轮播的组件示例代码
Mar 06 Javascript
微信小程序实现登录页云层漂浮的动画效果
May 05 Javascript
详解webpack + react + react-router 如何实现懒加载
Nov 20 Javascript
Vue之mixin全局的用法详解
Aug 22 Javascript
JavaScript学习笔记之数组基本操作示例
Jan 09 Javascript
js定义类的方法示例【ES5与ES6】
Jul 30 Javascript
jQuery点击页面其他部分隐藏下拉菜单功能
Nov 27 #jQuery
js replace替换字符串同时替换多个方法
Nov 27 #Javascript
Vue中用props给data赋初始值遇到的问题解决
Nov 27 #Javascript
使用electron制作满屏心特效的示例代码
Nov 27 #Javascript
30分钟快速实现小程序语音识别功能
Nov 27 #Javascript
基于Koa2写个脚手架模拟接口服务的方法
Nov 27 #Javascript
Vue实现移动端左右滑动效果的方法
Nov 27 #Javascript
You might like
php实现ping
2006/10/09 PHP
PHP 学习路线与时间表
2010/02/21 PHP
PHP微信刮刮卡 附微信接口
2016/07/22 PHP
php组合排序简单实现方法
2016/10/15 PHP
phpMyAdmin无法登陆的解决方法
2017/04/27 PHP
PHP用户注册邮件激活账户的实现代码
2017/05/31 PHP
Thinkphp5行为使用方法汇总
2017/12/21 PHP
PHP排序算法之堆排序(Heap Sort)实例详解
2018/04/21 PHP
使用Git实现Laravel项目的自动化部署
2019/11/24 PHP
Javascript 汉字字节判断
2009/08/01 Javascript
javaScript 简单验证代码(用户名,密码,邮箱)
2009/09/28 Javascript
jquery显示隐藏input对象
2014/07/21 Javascript
使用js复制链接中的部分文字的方法
2015/07/30 Javascript
基于JavaScript实现添加到购物车效果附源码下载
2016/08/22 Javascript
JS动态加载脚本并执行回调操作
2016/08/24 Javascript
Angular企业级开发——MVC之控制器详解
2017/02/20 Javascript
浅析从vue源码看观察者模式
2018/01/29 Javascript
了解JavaScript中的选择器
2019/05/24 Javascript
[47:04]LGD vs infamous Supermajor小组赛D组 BO3 第二场 6.3
2018/06/04 DOTA
python打开url并按指定块读取网页内容的方法
2015/04/29 Python
使用python根据端口号关闭进程的方法
2018/11/06 Python
在vscode中配置python环境过程解析
2019/09/28 Python
俄罗斯药房连锁店:ASNA
2020/06/20 全球购物
网络、C以及其他硬件方面的面试题
2016/08/23 面试题
环境科学专业大学生自荐信格式
2013/09/21 职场文书
生物医学工程专业学生求职信范文分享
2013/12/14 职场文书
红领巾心向党广播稿
2014/01/19 职场文书
阳光体育活动实施方案
2014/05/25 职场文书
医学求职信
2014/05/28 职场文书
班子四风对照检查材料
2014/08/21 职场文书
2014年学习委员工作总结
2014/11/14 职场文书
2014年汽车销售工作总结
2014/12/01 职场文书
金砖之国观后感
2015/06/11 职场文书
销区经理年终述职报告模板
2019/11/28 职场文书
MySQL创建索引需要了解的
2021/04/08 MySQL
深入理解CSS 中 transform matrix矩阵变换问题
2021/08/30 HTML / CSS