模板引擎
模板引擎是第三方模块。
让开发者以更加友好的方式拼接字符串,使项目代码更加清晰、更加易于维护。
art-template模板引擎
在命令行工具中使用 npm install art-template 命令进行下载
使用const template = require(‘art-template’)引入模板引擎
告诉模板引擎要拼接的数据和模板在哪 const html = template(‘模板路径’, 数据);
使用模板语法告诉模板引擎,模板与数据应该如何进行拼接
const template = require('art-template');
const path = require('path');
//一般模板文件都放在views里面
const views = path.join(__dirname, 'views', '01.art');
//第一个参数是模板的路径最好写绝对路径 要求.art
//第二个参数是要在模板中显示的数据
const html = template(views, {
name: '张三',
age: 20,
content: '<h1>我是标题</h1>' //如果内容带标签 使用模板标准写法默认不对标签进行解析 如果确认标签是安全的可以使用原文输出语法{{@}}
});
//返回的是拼接好的字符串
console.log(html);
模板引擎语法
art-template同时支持两种模板语法:标准语法和原始语法。
标准语法可以让模板更容易读写,原始语法具有强大的逻辑处理能力。
标准语法: {{ 数据 }}
原始语法:<%=数据 %>
<!-- 标准语法 -->
<p>{{ name }}</p>
<p>{{ 1 + 1 }}</p>
<p>{{ 1 + 1 == 2 ? '相等' : '不相等' }}</p>
<p>{{ content }}</p>
<!-- 如果内容带标签 要进行原文输出 -->
<p>{{@ content }}</p>
<!-- 原始语法 -->
<p><%= name %></p>
<p><%= 1 + 2%></p>
<p><%= 1 + 1 == 2 ? '相等' : '不相等' %></p>
<p><%= content%></p>
<!-- 如果内容带标签 要进行原文输出 -->
<p><%- content%></p>
输出
标准语法:{{ 数据 }}
原始语法:<%=数据 %>
原文输出
如果数据中携带HTML标签,默认模板引擎不会解析标签,会将其转义后输出。
标准语法:{{@ 数据 }}
原始语法:<%-数据 %>
条件判断
循环
标准语法:{{each 数据}} {{/each}}
原始语法:<% for() { %> <% } %>
子模版
使用子模板可以将网站公共区块(头部、底部)抽离到单独的文件中。
标准语法:{{include ‘模板’}}
原始语法:<%include(‘模板’) %>
模板继承
使用模板继承可以将网站HTML骨架抽离到单独的文件中,其他页面模板可以继承骨架文件。
示例:
模板配置
向模板中导入变量 template.defaults.imports.变量名 = 变量值; 可以用于导入其他模块的方法供.art使用
设置模板根目录 template.defaults.root = 模板目录 减少拼接的时候书写量
设置模板默认后缀 template.defaults.extname = ‘.art’