13.node中的模板引擎

模板引擎最早诞生于服务器领域,后来才发展到了前端。

在node中使用art-template

1.安装 npm install art-template

2.在需要使用的文件模块中加载 art-template

    使用require加载,参数中的 art-template 就是下载的包的名字。即 install 的名字是什么,则 require 中就是什么

3.查文档,使用模板引擎API ---下载模板的那个地址

 var template = require('art-template')
 template('script 标签 id',{对象})  //对象 对 标签中读到的字符串作解析替换
 template.render('hello {{ name }}', {
          name: 'Jack'
 })  // 对象中的 name 被替换到 标签中的 name
 console.log(ret)

(01) 

  var template = require('art-template')
  var tpl = `
<html>
<body>
           大家好,我叫: {{ name}}
        我今年 {{ age }} 岁了
        我来自 {{ province }}
        我喜欢:{{ each hobbies }} {{ $value }} {{/each}}
       </body>
</html>
`
 var ret = template.render( tpl , {
   name : 'jack' ,
              age : 18 ,
              province : '北京市' ,
              hobbies:[
                  '写代码' ,
                  '打游戏' ,
                  '唱歌跳舞' 
              ]
})
 console.log(ret)

(02)
  新建一个HTML文件,将(01)中反引号内的内容粘贴过去
 js 文件中: 

 var template = require('art-template')
 fs.readFile('./tpl.html' , function(err,data){
     if(err){
        return console.log('读取文件失败')
      }
  // 默认读取到的 data 数据是二进制数据。而模板引擎的render方法需要接收的是字符串。
 var ret = template.render( data.toString(), {
             name : 'jack' ,
              age : 18 ,
              province : '北京市' ,
              hobbies:[
                  '写代码' ,
                  '打游戏' ,
                  '唱歌跳舞' 
              ]
})
 console.log(ret)
})
  

(02.1)HTML 文件内容修改<!DOCTYPE html> 

<html>
<head>
   <meta charset="UTF-8">
   <title>{{ title }} </title>
 <body>
           大家好,我叫: {{ name}}
        我今年 {{ age }} 岁了
        我来自 {{ province }}
        我喜欢:{{ each hobbies }} {{ $value }} {{/each}}
        <script>
           var foo = ' {{ title }} '  // 模板引擎不关心内容,只看自己认识的标记符符号。所以此处 title 也会被替换。
        </script>
   </body>
</html>

与浏览器中的模板引擎不同的是:

浏览器中的模板引擎:浏览器把模板字符串存储到<script>标签中

node中的模板引擎:node把模板字符串存储到文件中。因为node中没有<script>标签

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值