模板引擎artTemplate简单语法

模板引擎

模板引擎是第三方模块。
让开发者以更加友好的方式拼接字符串,使项目代码更加清晰、更加易于维护。
在这里插入图片描述

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’

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值