vue.js - 数据绑定

作者: ebfc7d0362e4 | 来源:发表于2017-05-28 01:14 被阅读329次

vue.js - 数据绑定

前言

感觉 vue 的很多方面的内容,都参考了 angular 的东西,数据绑定方面,更是赤裸裸的“抄袭”。对照来看,更有助于我们学习和理解框架本身透露出来的思想,而非框架本身。

一、单向绑定

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

<div id="app">
    <p>{{text}}</p>
</div>

<script>
    var app = new Vue({
        el: '#app',
        data: {
            text: 'text content'
        }
    });
</script>

但是,这种双大括号语法,只能用于 html 内部的字符串,不能用于绑定 html 的属性(如 title、disabled、checked 等),angular亦如是。

(二)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: 'title content'
        }
    });
</script>

某些框架如 Ember.js 支持在 html 属性上面使用双大括号语法,如 title={{title}},但是如果像上面,在 vue.js 的 html 属性上使用这种语法,框架本身就会报错,如下图所示:

err.png

上面的报错,除了提示不能使用双大括号语法以外,还告诉我们可以使用 v-bind 或者 shorthand,也就是 v-bind 的缩写 :。这一点上,vue 还是和 angular 的 ng-bind 非常相似。

二、 一次性绑定

<div id="app">
    <p v-once>{{once}}</p>
</div>

<script>
    var app = new Vue({
        el: '#app',
        data: {
            once: 'once content'
        }
    });

    app.once = 'changed content';
</script>

原本 angular 不支持一次性绑定的,而过分的使用数据绑定,将严重影响应用性能,angular 中 bindonce 这个第三方模块解决了这个问题。而 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 标签中原本的文本将被替换,angular 中也有类似的 ng-bind-html

四、双向绑定

<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>

跟 angular 一模一样,双向绑定依赖于 v-model 指令。修改 textarea 中的内容的时候, {{input}} 将让内容同步更新到对应的 div 元素中。


demo 地址

相关文章

  • Vue快速入门(二:数据绑定)《快乐Vue》

    数据绑定 数据绑定语法 主要介绍 Vue.js 的数据绑定语法.使用的是双大括号标签 {{}},为“Mustach...

  • Vue之表单双向数据绑定和组件

    三、表单双向数据绑定和组件 目录:双向数据绑定、组件 1.双向数据绑定 1)什么是双向数据绑定Vue.js是一个M...

  • 《Vue.js 实战》基础篇(上)

    本章内容:认识 Vue.js、数据绑定、计算属性、内置指令 一、初始 Vue.js 1.1 Vue.js 是什么 ...

  • Vue.js 双向数据绑定原理分析

    在使用Vue.js自定义组件时,很多时候,我们都期望数据是双向绑定的。 Vue.js实现双向数据绑定的两种方式 1...

  • vue.js - 数据绑定

    vue.js - 数据绑定 前言 感觉 vue 的很多方面的内容,都参考了 angular 的东西,数据绑定方面,...

  • Object.defineProperty实现视图数据绑定dem

    vue.js 最核心的功能有两个,一个是响应式数据绑定,二是组件系统。今天讲讲双向数据绑定的实现vue.js和av...

  • vuejs绑定列表

    上一篇文章,介绍了如何通过vue.js实现数据双向绑定,这篇文章将介绍如何通过其来绑定列表 如何在vue.js中将...

  • 原来vue的原理是这样的

    vue.js中有两个核心功能:响应式数据绑定,组件系统。主流的mvc框架都实现了单向数据绑定,而双向绑定无非是在单...

  • Vue.js项目刷新当前路由(页面)的方法与实践

    前言 越来越多的前端项目使用MVVM框架Vue.js进行架构开发,充分利用了Vue.js的数据驱动、双向数据绑定、...

  • vue.js

    Vue.js双向绑定的实现原理 Vue.js最核心的功能有两个,一是响应式的数据绑定系统,二是组件系统。本文仅探究...

网友评论

    本文标题:vue.js - 数据绑定

    本文链接:https://www.haomeiwen.com/subject/pvdcfxtx.html