vue数据双向绑定——mustache语法

news/2024/7/10 0:45:35 标签: vue, mustache语法

mustache 模板,用于构造html页面内容。在实际工作中,当同一个模板中想要调用不同的函数来渲染画面,在已经自定义好了的前提下,可以在渲染页面时对传入的参数进行手动判断。

Mustache 的模板语法很简单,就那么几个:

  • {{data}}
  • {{#data}} {{/data}}
  • {{^data}} {{/data}}
  • {{.}}
  • {{>partials}}
  • {{{data}}}
  • {{!comments}}

先来一个简单demo,亲测无bug:

<!DOCTYPE html>
<html>
<head>
    <title>Event Delegation Example</title>
     <!-- CDN引用mustache.js引擎 -->
     <script type="text/javascript" src="https://cdn.bootcss.com/mustache.js/3.0.1/mustache.js"></script>
</head>
<body>
  <script type="text/javascript">
    var data = {
      "name": " xiaohua ",//name,msg,subject是键名
      "msg": {
        "sex": " female ", 
        "age": " 22 ", 
        "hobit": " reading "
      },
      "subject": ["Ch","En","Math","physics"] 
    }   
  
    var tpl = "<div>{{name}}</div>"; 
    var res = Mustache.render(tpl, data);
    document.write(res);
  </script>
</body>
</html>

1、{{data}}

{{}}就是 Mustache 的标示符,花括号里的 data 表示键名,这句的作用是直接输出与键名匹配的键值,例如:

var tpl = '{{name}}';
var res = Mustache.render(tpl, data);
document.write(res);

//输出:xiaohua

2、{{#data}} {{/data}}

#开始、以/结束表示区块,它会根据当前上下文中的键值来对区块进行一次或多次渲染,例如改写下 Demo 中的 tpl:

var tpl = '{{#msg}} <p>{{sex}},{{age}},{{hobit}}</p> {{/msg}}';
var res = Mustache.render(tpl, data);
document.write(res);

//输出:female, 22, reading

注意:如果{{#data}} {{/data}}中的 data 值为 null, undefined, false;则不渲染输出任何内容。

3、{{^data}} {{/data}}

该语法与{{#data}} {{/data}}类似,不同在于它是当 data值为 null, undefined, false 时才渲染输出该区块内容。

var tpl = '{{^nothing}} 没找到nothing键名就会渲染这段 {{/nothing}}';
var res = Mustache.render(tpl, data);
document.write(res);

//输出:没找到nothing键名就会渲染这段

4、{{.}}

{{.}}表示枚举,可以循环输出整个数组,例如:

var tpl = '{{#subject}} <p>{{.}}</p> {{/subject}}';
var res = Mustache.render(tpl, data);
document.write(res);

//输出: Ch En Math physics

5、{{>partials}}

>开始表示子模块,如{{> msg}};当结构比较复杂时,我们可以使用该语法将复杂的结构拆分成几个小的子模块,例如:

var tpl = "<h1>{{namme}}</h1> <ul>{{>msg}}</ul>";
var partials = {
  msg: "{{#msg}}<li>{{sex}}</li><li>{{age}}</li><li>{{hobit}}</li>{{/msg}}"
};
var res = Mustache.render(tpl, data, partials);
document.write(res);

//输出:
// female
// 22
// reading

6、{{{data}}}

{{data}}输出会将等特殊字符转译,如果想保持内容原样输出可以使用{{{}}},例如:

var tpl = '{{#msg}} <p>{{{age}}}</p> {{/msg}}'
var res = Mustache.render(tpl, data);
document.write(res);
console.log(typeof(data.msg.age));//控制台打印age类型为string

//输出:22

7、{{!comments}}

!表示注释,注释后不会渲染输出任何内容。

{{!这里是注释}}

//输出:

如果页面上的内容是从后台获取数据并渲染到页面上的,我们就可以使用mustache模板了。

值得注意的是,render的数据一定要与键名相符合。


http://www.niftyadmin.cn/n/1426132.html

相关文章

定义数组

String[] strnew String[size];

文字计数,刷新了有文字广告的页就计数

相关表cm_css(id b c font1 title) cm_txt( id title money url alt yds okok otype tfl display addtime)文字广告,标题title,文本alt,网址url username (id Username Psw txt_xs) 计数 txtad.jsp <% page language"java" import"java.util.*,java.m…

v-cloak解决Vue加载页面时出现类似{{data}}这样的mustache语法

直接贴代码 <style>[v-cloak] {display: none;} </style><div id"app" v-cloak>{{message}}</div><script>var app new Vue({el:#app,data:{message:这是一段文本}}) </script> 如上图是v-cloak放的位置 是不是每个需要渲染数…

sqlserver 复制表结构,复制表数据

sqlserver 复制表结构在企业管理器中,全选想要复制的表,右击所有任务/生成SQL脚本.保存为一个*.sql文件.再在查询分析器中打开.在菜单栏下面中间位置,选择一个数据库,然后把刚才保存的sql文件复制进去,点勾,再按F5执行.表结构复制成功. 复制表数据 使用SQL Server 2000自带的“…

v-if和v-show区别理解

Vue中对元素进行隐藏或显示&#xff0c;有两种常用方法&#xff0c;v-show和v-if&#xff0c;但这两种写法是有以下区别的 1、实现方法本质区别 vue-show本质就是标签display设置为none&#xff0c;控制隐藏vue-if是动态的向DOM树内添加或者删除DOM元素v-show 只是简单的css …

*同一机器上sqlserver 复制表结构及数据

一简单的复制 复制表1中id,r_p,r_p1,r_p2,r_p3,r_p4到表2的r_id,x_p,x_p1,x_p2,x_p3中&#xff0c;x_id为以固定值(1)。主要是方便从某表初始化某些值insert into 表2(x_id,r_id,x_p,x_p1,x_p2,x_p3)select 1,id,r_p,r_p1,r_p2,r_p3 from 表1 二所有表数据一起复制(一个数据…

新建网站,asp.net

visual studio 解决方案管理器, 解决方案,新建网站,asp.net

servlet彩色验证码

用image.jsp 的彩色验证出现" ... "的错误 使用servlet验证 pp.function.VerifyCodeServletpackage pp.function; import java.io.*; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import java.awt.Graph…