前端框架--vue.js数据绑定

   vue.js数据绑定有  单向、双向和一次性绑定

  一、单向绑定

      (一)Mustache 语法,双大括号 {{}}(html 内字符串绑定)

<div id="app">
  <p>{{text}}</p>
</div>
 
<script>
  var app = new Vue({
    el: '#app',
    data: {
      text: 'hello world!'
    }
  });
</script>
这种双大括号语法,只能用于 html 内部的字符串,不能用于绑定 html 的属性(如 title、disabled、checked 等)

(二)v-bind 指令(html 属性绑定)

<div id="app">
  <p title={{title}}></p>   //会报错
  <p v-bind:title="title">title属性绑定,html属性不能使用双大括号形式绑定,只能使用v-bind指令</p>
  <p :title="title">“:” 是 “v-bind” 的快捷方式</p>
</div>
 
<script>
  var app = new Vue({
    el: '#app',
    data: {
      title: 'hello'
    }
  });
</script>
除了提示不能使用双大括号语法以外,还告诉我们可以使用 v-bind 或者 shorthand,也就是 v-bind 的缩写 :。

一次性绑定

<div id="app">
  <p v-once>{{once}}</p>
</div>
 
<script>
  var app = new Vue({
    el: '#app',
    data: {
      once: 'hello'
    }
  });
 
  app.once = 'changed content';
</script>
而过分的使用数据绑定,将严重影响应用性能, vue 通过 v-once 实现了框架本身对一次性绑定的原生支持。
## 不进行 html 转义
<div id="app">
  <p v-html="html">不转义的绑定(直接输出 html)</p>
</div>
 
<script>
  var app = new Vue({
    el: '#app',
    data: {
      html: '<div>div element</div>'
    }
  });
</script>
出于安全考虑,默认的数据绑定,会进行转义操作,屏蔽掉 html 标签。使用 v-html 指令,可以实现对文本内容不转义输出。这里的输出会替换掉目标标签的 innerHTML 代码中 p 标签中原本的文本将被替换

双向绑定

<div id="app">
  <div>{{input}}</div>
  <textarea v-model="input"></textarea>
</div>
<script>
  var app = new Vue({
    el: '#app',
    data: {
      input: 'two-way-binding'
    }
  });
</script>
双向绑定依赖于 v-model 指令。修改 textarea 中的内容的时候, {{input}} 将让内容同步更新到对应的 div 元素中,数据双向绑定。


总结:

单项绑定: 双大括号 {{}}

一次性绑定: v-once  , v-html

双向绑定:v-model



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值