小试牛刀之Ejs模板引擎

与express一起使用的一些流行模板引擎是Pug,Mustache和EJS。Express应用程序默认使用Pug,但他也支持其他几个。

需要在应用中进行如下设置才能让Express渲染模板引擎:

  • view,放模板的文件目录,例如:app.set('views','./views)
  • view engine,要使用的模板引擎。例如,要使用pug模板引擎:app.set('view engine', 'pug')

在路由中渲染模板

在路由渲染模板并将渲染后的HTML字符串发送到客户端。

res.rander(view [, locals] [, callback])
  • view:一个字符串,view是渲染的模板文件的文件路径。
  • locals:一个对象,其属性定义视图的局部变量。
router.get("/", (req, res) => {
  // res.send({ list: ['aaa', 'bbb', 'ccc'] })
  res.render("list", { title: "新闻", list: ["aa", "bb", "cc"] })
})

ejs模板引擎的使用

安装ejs

npm i ejs
在express配置ejs模板引擎
使用ejs模板引擎

在入口文件中配置如下代码,配置Express使用ejs模板引擎

//配置模板引擎
app.set("views", path.join(__dirname, "./views")) //设置模板引擎的保存位置
app.set('view engine', 'ejs')

注意:

此时指定的模板目录为views,且模板文件的后缀名为.ejs

设置模板后缀为html

在app.js中添加如下代码,配置Express使用ejs模板引擎。并指定模板后缀名为html。

app.set('views',path.join(__dirname,'views')); //设置模板存储位置
app.set('view engine','html');
app.engine('html',require('ejs').renderFile); //使用ejs模板引擎解析html

注意:此时指定的模板目录为views,且模板文件的后缀名为.html

ejs模板语法
<%= %>   输出标签
<%- %>   输出html标签(html会被浏览器解析)
<%# %>   注释标签
<% %>    流程控制标签(写的是if,else,for)
<%- include("header.html",{user:user})%>  导入公共的模板内容

<body>
  <%- include("./haeder.html",{isShow:true})%>
    这是list页面
    <%=title%>
      <ul>
        <% for(var i=0;i<list.length;i++){ %>
          <li>
            <%=list[i]%>
          </li>
          <%} %>
      </ul>
      <h%- <h5>我是输出的html标签</h5>%>

        <%# <h3>注释标签,不会显示在页面结构中</h3>%>
          <%- include("./footer.html")%>
</body>

Snipaste_2022-06-27_16-51-25

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

抗争的小青年

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值