zoukankan      html  css  js  c++  java
  • 模板语法

    Vue.js使用基于HTML的模板语法(因此能被遵循规范的浏览器和HTML解析器解析),可以声明式地将DOM绑定至底层Vue实例的数据.

    在底层实现上,Vue将模板编译成虚拟DOM渲染函数,结合系统函数,Vue可以计算出最少需要重新渲染多少组件,并把DOM操作次数减到最少.

    ps. 熟悉虚拟DOM或偏爱JS,可以不用模板,直接写渲染(render)函数,使用JSX.

    1. 插值

    1.1 文本

    Mustache语法(双大括号)的文本插值:

    // Mustache标签会被替换为对应数据对象上msg属性的值,无论何时,属性改变,插值都会更新.
    <span>Message: {{ msg }}</span>
    

    v-once指令执行一次性地插值,数据改变时,插值不会更新

    <span v-once>这个将不会改变:{{ msg }}</span>
    

    1.2 原始HTML

    双大括号会将数据解析成普通文本,而非HTML代码

    // span的内容会被替换成属性值rawHtml,直接作为HTML(会忽略解析属性值中的数据绑定)
    <span v-html="rawHtml"></span>
    

    ps. 不能使用v-html来复合局部模板,Vue不是基于字符串的模板引擎;反之对于用户界面(UI),组件更适合作为可重用、可组合的基本单位.

    注:绝不要对用户提供的内容使用插值(动态渲染的任意HTML容易导致XSS攻击)

    1.3 特性

    Mustache语法不能作用在HTML特性上,可以用v-bind指令

    <div v-bind:id="dynamicId"></div>
    
    // 布尔特性(只要存在就意味着值为true)
    // 如果isButtonDisabled的值是null、undefined或false,则disabledb特性甚至不会被包含在渲染出来的button元素中.
    <button v-bind:disabled="isButtonDisabled">Button</button>
    

    1.4 使用JS表达式

    // 这些表达式会在所属Vue实例的数据作用域下作为JS被解析,每个绑定都只能包含单个表达式
    {{ number + 1 }}
    {{ ok ? 'YES' : 'NO' }}
    {{ message.split('').reverse().join('') }}
    
    <div v-bind:id="'list' + id"></div>
    
    // 这是语句,不是表达式
    {{ var a = 1 }}
    
    // 流控制也不会生效,请使用三元表达式
    {{ if (ok) { return message } }}
    

    ps. 模板表达式都被放在沙盒中,只能访问全局变量的一个白名单,如Math、Date.不应该在模板表达式中访问用户定义的全局变量.

    2. 指令

    指令(Directives)是带有v-前缀的特殊特性,它的值预期是单个JS表达式(v-for除外).职责是当表达式的值改变时,将其产生的连带影响,响应式地作用于DOM.

    // v-if指令根据表达式seen值的真假来插入/移除p元素
    <p v-if="seen">看见我了</p>
    

    2.1 参数

    一些指令能够接受一个"参数",在指令之后以冒号表示.

    // 这里的href参数告知v-bind指令将该元素的href特性与表达式url的值绑定.
    <a v-bind:href="url">...</a>
    
    // v-on指令用于监听DOM事件,参数是监听的事件名.
    <a v-on:click="doSomething">...</a>
    

    2.2 动态参数

    这里的attributeName会被作为一个JS表达式进行动态求值,求得的值将会作为最终的参数使用.

    // 例如attributeName值为"href",则该绑定等价于v-bind:href
    <a v-bind:[attributeName]="url">...</a>
    

    同样地,也可以使用动态参数为一个动态的事件名绑定处理函数.

    // 当eventName的值为"focus"时,v-on:[eventName]等价于v-on:focus.
    <a v-on:[eventName]="doSomething">...</a>
    

    ps. 对动态参数的值的约束

    动态参数预期会求出一个字符串,异常情况下值为null,这个特殊的null值可以显性地用于移除绑定.任何其他非字符串类型的值都会触发警告.

    ps. 对动态参数表达式的约束

    某些字符(空格/引号)放在HTML特性名里是无效的,会触发编译警告.

    // 可以使用没有空格/引号的表达式,或用计算属性替代这种复杂表达式
    <a v-bind:['foo' + bar]="value">...</a>
    

    在DOM中使用模板(直接在一个HTML文件里撰写模板)需要回避大写键名,浏览器会把特性名全部强制转为小写.

    // 在DOM中使用模板时这段代码会被转换为v-bind:[someattr]
    <a v-bind:[someAttr]="value">...</a>
    

    2.3 修饰符

    修饰符(modifier)是以半角句号.指明的特殊后缀,用来指出一个指令应该以特殊方式绑定.

    // .prevent修饰符告诉v-on指令对于触发的事件调用event.preventDefault().
    <form v-on:submit.prevent="onSubmit">...</form>
    

    3. 缩写

    v-前缀作为一种视觉提示,用来识别模板中Vue特定的特性.使用vue.js为标签添加动态行为时,v-很有帮助.

    然而使用频繁的指令就会很繁琐,且在构建由vue管理所有模板的单页面应用程序(SPA),v-就没那么有必要了.因此,Vue为v-bind和v-on两个常用的指令提供了特定简写.

    3.1 v-bind 缩写

    // 完整语法
    <a v-bind:href="url">...</a>
    // 缩写
    <a :href="url">...<a/>
    

    3.2 v-on 缩写

    // 完整语法
    <a v-on:click="doSomething">...</a>
    // 缩写
    <a @click="doSomething">...</a>
    
  • 相关阅读:
    poj 2417 Discrete Logging
    洛谷 P2886 [USACO07NOV]牛继电器Cow Relays
    bzoj 3232 圈地游戏——0/1分数规划(或网络流)
    bzoj 4753 [Jsoi2016]最佳团体——0/1分数规划
    bzoj 5281 [Usaco2018 Open]Talent Show——0/1分数规划
    CF 949D Curfew——贪心(思路!!!)
    bzoj 3872 [Poi2014]Ant colony——二分答案
    bzoj 1731 [Usaco2005 dec]Layout 排队布局——差分约束
    洛谷 1344 [USACO4.4]追查坏牛奶Pollutant Control——最大流
    洛谷 1262 间谍网络——缩点+拓扑
  • 原文地址:https://www.cnblogs.com/LittlePANDA-ZSJ/p/11242554.html
Copyright © 2011-2022 走看看