• EJS学习(二)之语法规则上


    标签含义

    • <% %> :'脚本' 标签,用于流程控制,无输出即直接使用JavaScript语言。

    • <%= %>:转义输出数据到模板(输出是转义 HTML 标签)即在后端定义的变量,可以再前端显示输出

    • <%- %>:非转义输出数据到模板

    • <%# %>:注释标签,不执行、不输出内容

    • <%% %>: 输出字符串 '<%'

    • %>: 一般结束标签

    • -%> :删除紧随其后的换行符

    • <%_ 删除其前面的空格符

    • _%> 将结束标签后面的空格符删除

    ⚠️ 空格不是必须的

    用法

    var template = ejs.compile(str, options);
    template(data);
    // => 输出绘制后的 HTML 字符串
    
    ejs.render(str, data, options);
    // => 输出绘制后的 HTML 字符串
    
    ejs.renderFile(filename, data, options, function(err, str){
        // str => 输出绘制后的 HTML 字符串
    });

    options参数

    • cache 是否缓存解析后的模版,需要filename作为key;

    • filename 模版文件名被 cache 参数用做键值,同时也用于 include 语句

    • context 函数执行时的上下文环境

    • compileDebug 标识是否是编译debug,为true则会生成解析过程中的跟踪信息,用于调试;当为 false 时不编译调试语句

    • client 标识是否用于浏览器客户端运行,为true则返回解析后的可以单独运行的Function函数

    • open 代码开头标记,默认为'<%';

    • close 代码结束标记,默认为'%>';

    • delimiter 放在角括号中的字符,用于标记标签的开与闭,也就是自定义模版标签

    • debug 标识是否是debeg状态,debug为true则会输出生成的Function内容

    • _with 是否使用 with() {} 结构。如果为 false,所有局部数据将存储在 locals 对象上。

    • localsName 如果不使用 with ,localsName 将作为存储局部变量的对象的名称。默认名称是 locals

    • rmWhitespace 删除所有可安全删除的空白字符,包括开始与结尾处的空格。对于所有标签来说,它提供了一个更安全版本的 -%> (在一行的中间并不会剔除标签后面的换行符)。

    • escape 为 <%= 结构设置对应的转义(escape)函数。它被用于输出结果以及在生成的客户端函数中通过 .toString() 输出。(默认转义 XML)。

    自定义分隔符

    可针对单个模板或全局使用自定义分隔符:

    情况一:使用ejs.render()

    var ejs = require('ejs'),
        users = ['geddy', 'neil', 'alex'];
    
    // 单个模板文件
    ejs.render('<?= users.join(" | "); ?>', {users: users},
        {delimiter: '?'});
    // => 'geddy | neil | alex'
    
    // 全局
    ejs.delimiter = '$';
    ejs.render('<$= users.join(" | "); $>', {users: users});
    // => 'geddy | neil | alex'

    情况二:使用ejs.renderFiler()

    
    
    // 单个模板文件
    // 11.ejs内容:
    <? for(var i=0; i<num; i++ ) { -?>
          <h2><?= user.name ?></h2>
          <h2><?= user.age ?></h2>
    <? } -?>
       
    // 11.js内容:
    var ejs = require('ejs');
    
    ejs.renderFile('./work/lesson14/view/11.ejs',{
        user:{
            name:"wangkun",
            age:22,
        },
        num:2
    },{rmWhitespace:true,delimiter: '?'},(err,data)=>{
        if(err) {
            console.error(err);
        }else {
            console.log(data);
        }
    });
    
    // 输出:
    <body>
    <h2>wangkun</h2>
    <h2>22</h2>
    <h2>wangkun</h2>
    <h2>22</h2>
    </body>


    // 全局

    // 12.ejs内容:
      <$ for(var i=0; i<num; i++ ) { -$>
        <h2><$= user.name $></h2>
        <h2><$= user.age $></h2>
      <$ } -$>
    // 12.js内容:
      const ejs = require('ejs');

      ejs.delimiter = '$';

      ejs.renderFile('./work/lesson14/view/12.ejs',{
        user:{
          name:"wangkun",
          age:22,
        },
        num:2
      },{rmWhitespace:true},(err,data)=>{
        if(err) {
          console.error(err);
        }else {
          console.log(data);
        }
      });
     
      // 输出:
      
      <h2>wangkun</h2>
      <h2>22</h2>
      <h2>wangkun</h2>
      <h2>22</h2>
     

     

  • 相关阅读:
    System.Runtime.InteropServices.COMException (0x800706BA) 解决方法
    Win7 不能安装 msi 解决办法
    note 1 对象和数据类型
    note 0 Python介绍及Python IDE环境安装 Spyder with Anaconda
    无法获得锁 /var/lib/dpkg/lock
    keil5 MDK 链接报错 Error: L6410W 解决
    手动卸载CAD 删除残留文件 清理遗留的文件
    keil5 MDK warning:registered ARM compiler version not found in path
    干掉hao123劫持浏览器主页
    Win7 无法访问Installer服务
  • 原文地址:https://www.cnblogs.com/kunmomo/p/11465612.html
Copyright © 2020-2023  润新知