03-Vue数据单向传递和双向传递

2020-04-17  本文已影响0人  仰望_IT

数据单向传递

1. MVVM设计模式

在MVVM设计模式中由3个部分组成
M : Model 数据模型(保存数据, 处理数据业务逻辑)
V : View 视图(展示数据, 与用户交互)
VM: View Model 数据模型和视图的桥梁(M是中国人, V是美国人, VM就是翻译)

MVVM设计模式最大的特点就是支持数据的双向传递
数据可以从 M -> VM -> V
也可以从 V -> VM -> M

2. Vue中MVVM的划分

Vue其实是基于MVVM设计模式的
View:被控制的区域
View Model:Vue实例对象
Model:实例对象中的data

3. Vue中数据的单向传递

我们把"数据"交给"Vue实例对象", "Vue实例对象"将数据交给"界面"
Model -> View Model -> View

<!--这里就是MVVM中的View-->
<div id="app">
    <p>{{ message  }}</p>
</div>
<script>
    // 这里就是MVVM中的View Model
    let vue = new Vue({
        el: '#app',
        // 这里就是MVVM中的Model
        data: {
            message : "Vue单向传递"
        }
    });
</script>

数据双向绑定

默认情况下Vue只支持数据单向传递 M -> VM -> V
但是由于Vue是基于MVVM设计模式的, 所以也提供了双向传递的能力,在<input>、<textarea> 及 <select>元素上可以用 v-model 指令创建双向数据绑定, 也只有这三个元素可以实现双向绑定
例如:

<div id="app">
    <input type="text" v-model="message">
</div>

<script>
    let vue = new Vue({
        el: '#app',
        data: {
            message: "Vue双向传递"
        }
    });
</script>

v-model 会忽略所有表单元素的 valuecheckedselected 特性的初始值
而总是将 Vue 实例的数据作为数据来源。要在JavaScript 在组件的 data 选项中声明初始值。

上一篇 下一篇

猜你喜欢

热点阅读