data:image/s3,"s3://crabby-images/1526e/1526e2505b697d698390dd5db09ca76d9ba17b34" alt=""
MVVM模式
data:image/s3,"s3://crabby-images/f128e/f128eecdf6c1ccdc82ed20bbe724aac3e45fd4d3" alt="在这里插入图片描述" 下图不仅概括了MVVM模式(Model-View-ViewModel),还描述了在Vue.js中ViewModel是如何和View以及Model进行交互的。
ViewModel是Vue.js的核心,它是一个Vue实例。Vue实例是作用于某一个HTML元素上的,这个元素可以是HTML的body元素,也可以是指定了id的某个元素。
当创建了ViewModel后,双向绑定是如何达成的呢?
首先,我们将上图中的DOM Listeners和Data Bindings看作两个工具,它们是实现双向绑定的关键。 从View侧看,ViewModel中的DOM Listeners工具会帮我们监测页面上DOM元素的变化,如果有变化,则更改Model中的数据; 从Model侧看,当我们更新Model中的数据时,Data Bindings工具会帮我们更新页面中的DOM元素。
1.vue.js
<!--1.导入vue.js-->
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.min.js"></script>
2.绿色剪头为绑定(模块化),红色箭头方法将鼠标放在“测试1111”上,会显示hello vue
data:image/s3,"s3://crabby-images/2605d/2605df3a63ecb7c25ed1c4b09c1e78f6619928f7" alt="在这里插入图片描述"
3.判断
<h1 v-if="ok">yes</h1>
<h1 v-else>no</h1>
data:image/s3,"s3://crabby-images/de16e/de16e4508ebcb8ed2cdf49c7627a3df02d5239b4" alt="在这里插入图片描述"
<body>
<div id="app">
<h1 v-if="type==='a'">a</h1>
<h1 v-else-if="type==='b'">b</h1>
<h1 v-else>c</h1>
</div>
<!--1.导入vue.js-->
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.min.js"></script>
<script>
var vm = new Vue({
el:"#app",
data:{
type:'a'
}
});
</script>
</body>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
4.遍历数组
<div id="app">
<li v-for ="item in items">
{{item.message}}
</li>
</div>
<!--1.导入vue.js-->
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.min.js"></script>
<script>
var vm = new Vue({
el:"#app",
data:{
items:[
{message: 'xyj'},
{message: 'xyj2'}
]
}
});
</script>
data:image/s3,"s3://crabby-images/3dc55/3dc55e30f7ec42fc9c4a38b7c3d61509a83e49fc" alt=""
data:image/s3,"s3://crabby-images/25ce4/25ce470b97ee5acb52ad7cae7d0c9149ca12c30c" alt=""
data:image/s3,"s3://crabby-images/020d8/020d8406fbf8468246ff6c177e7e9a04fcb51ea1" alt=""
data:image/s3,"s3://crabby-images/01081/01081dae9f9ddf175bb8f0faba1b3778bdf44e17" alt=""
举报
data:image/s3,"s3://crabby-images/3388d/3388d305045129e298834bd6cabb1e140a854e1e" alt=""
|