发布时间:2022-11-20 文章分类:WEB开发 投稿人:樱花 字号: 默认 | | 超大 打印

1.MVVM模型

⭐⭐

MVC和MVVM都是一种软件的体系结构

Vue的整个设计受到MVVM模型的影响

VueMVVM模型与data及methods属性超详细讲解

MVVM模型:

<div id="root">
<h1>school:{{name}}</h1>
<h1>address:{{address}}</h1>
<h1>test:{{1+1}}</h1>
</div>
<script type="text/javascript">
Vue.config.productionTip = false; //设置为 false 以阻止 vue 在启动时生成生产提示。
const vm = new Vue({
el: "#root",
data: {
name: "xiaozhao",
address: "henan",
a: 1,
},
});
console.log(vm);

2.data属性

⭐⭐

data属性是传入一个函数,并且该函数需要返回一个对象:

data中返回的对象会被Vue的响应式系统劫持,之后对该对象的修改或者访问都会在劫持中被处理:

data有2种写法

对象式

      data: {
name: "zj",
},

函数式

data function(){} data不能写箭头函数 this指向问题

      data() {
console.log("@@@", this); //此处的this是vue实例对象
return {
name: "zj",
};
},
<div id="app">
<h2>{{message}}</h2>
<button @click="changeMessage">改变message</button>
</div>
<script src="https://www.jb51.net/article/lib/vue.js"></script>
<script>
const app = Vue.createApp({
data: function () {
return { message: "Hello Data" };
},
//函数式
methods: {
changeMessage: function () {
this.message = "hello hhh";
},
},
});
app.mount("#app");

3.methods属性

✨✨

methods属性是一个对象,通常我们会在这个对象中定义很多的方法:

<script src="https://www.jb51.net/article/lib/vue.js"></script>
<script>
const app = Vue.createApp({
data: function () {
return {
counter: 0,
};
},
//methods:option api
methods: {
increment: function () {
this.counter++;
},
increment() {},
// methods中的函数不能写成箭头函数
increment: () => {
console.log(this);
},
},
});
app.mount("#app");

在方法中访问属性

在 methods 方法中访问 data 的数据,可以直接通过 this.属性名 的形式来访问。

到此这篇关于Vue MVVM模型与data及methods属性超详细讲解的文章就介绍到这了,更多相关Vue MVVM模型内容请搜索本站以前的文章或继续浏览下面的相关文章希望大家以后多多支持本站!