nunjucks

Nunjucks模板

它是一款JavaScript 模板引擎,可以动态生成页面,相当于界面跟数据是分离的,MV模式.

这是一个模板渲染,以下在egg-js项目下进行.

  1. 首先引入该插件.
npm i egg-view-nunjucks --save
  1. 启动插件 config\plugin.js
module.exports = {
  // had enabled by egg
  // static: {
  //   enable: true,
  // }
  nunjucks: {
    enable: true,
    package: 'egg-view-nunjucks',
  },
};
  1. 配置渲染引擎,config\config.default.js
  config.view = {
    mapping: {
      '.nj': 'nunjucks',
    },
  };

这样在渲染时,.nj后缀文件会使用nunjucks引擎进行渲染.

  1. 先建立好一个页面框架,layout.html.
<!DOCTYPE html>
<html lang="en">

  <head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
  </head>

  <body>
    <div>
      {% block content %}{% endblock %}
    </div>
  </body>

</html>

其中{% block content %}{% endblock %}是我们要填充的内容。

  1. 新建一个 code.nj,继承于上一个模板.
{% extends 'layout.html' %}
{% block content %}
Hey!
<br/>
<br/>
A sign in attempt requires further verification because we did not recognize our device.
To complete the sign in,enter the verification code on the unrecognized device.
<br/>
<br/>
Verification code: <font color='#42a5f5'>{{code}}</font>
{% endblock %}
  1. controller,这样渲染.
'use strict';

const Controller = require('egg').Controller;

class HomeController extends Controller {
  async index() {
    const { ctx } = this;
    await ctx.render('code.nj', { code: 123456 });
  }
}

module.exports = HomeController;

默认会从app/view/目录下搜索模板文件.

最后效果:
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值