赞
踩
参考谷粒商城
在 MVVM 之前,开发人员从后端获取需要的数据模型,然后要通过DOM操作Model 渲染到 View 中。而后当用户操作视图,我们还需要通过 DOM 获取 View 中的数据,然后同步到Model 中。
而 MVVM 中的 VM 要做的事情就是把 DOM 操作完全封装起来,开发人员不用再关心Model
和 View 之间是如何互相影响的:
把开发人员从繁琐的 DOM 操作中解放出来,把关注点放在如何操作Model 上。
Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue 也完全能够为复杂的单页应用提供驱动。
官网
参考
Git 地址
尤雨溪,Vue.js 创作者,Vue Technology 创始人,致力于 Vue 的研究开发。
官网文档提供了 3 中安装方式:
在 hello.html 中,我们编写一段简单的代码。
h2 中要输出一句话:xx 非常帅
。前面的xx
是要渲染的数据。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<div id="app">
<h2>{{name}},非常帅!!!</h2>
</div>
</body>
</html>
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <div id="app"> <h2>{{name}},非常帅!!!</h2> </div> <script src="./node_modules/vue/dist/vue.js"></script> <script> let vm = new Vue({ el: "#app", data: { name: "张三" } }) </script> </body> </html>
h2
元素中,我们通过{{name}}的方式,来渲染刚刚定义的name 属性。打开页面查看效果:
更神奇的在于,当你修改 name 属性时,页面会跟着变化:
我们对刚才的案例进行简单修改:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <div id="app"> <input type="text" v-model="num"> <h2>{{name}},非常帅!!!有{{num}}个人为他点赞</h2> </div> <script src="./node_modules/vue/dist/vue.js"></script> <script> // 创建 vue 实例 let vm = new Vue({ el: "#app", // el 即 element,该 vue 实例要渲染的页面元素 data: { // 渲染页面需要的数据 name: "张三", num: 5 } }) </script> </body> </html>
双向绑定:
效果:我们修改表单项,num 会发生变化。我们修改 num,表单项也会发生变化。为了实时观察到这个变化,我们将 num 输出到页面。
我们不需要关注他们为什么会建立起来关联,以及页面如何变化,我们只需要做好数据和视图的关联即可(MVVM)
给页面添加两个按钮:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <div id="app"> <input type="text" v-model="num"> <button v-on:click="num++">关注</button> <button v-on:click="cancle">取消</button> <h2>{{name}},非常帅!!!有{{num}}个人为他点赞</h2> </div> <script src="./node_modules/vue/dist/vue.js"></script> <script> // 创建 vue 实例 let vm = new Vue({ el: "#app", // el 即 element,该 vue 实例要渲染的页面元素 data: { // 渲染页面需要的数据 name: "张三", num: 5 }, methods:{ cancle(){ this.num--; } } }) </script> </body> </html>
v-on
指令绑定点击事件,而不是普通的onclick
,然后直接操作num1)、使用 Vue 实例管理 DOM
2)、DOM 与数据/事件等进行相关绑定
3)、我们只需要关注数据,事件等处理,无需关心视图如何进行修改\
每个 Vue 应用都是通过用 Vue 函数创建一个新的 Vue 实例开始的:
let app = new Vue({
});
在构造函数中传入一个对象,并且在对象中声明各种 Vue 需要的数据和方法,包括:
等等
接下来我们一 一介绍。
每个 Vue 实例都需要关联一段 Html 模板,Vue 会基于此模板进行视图渲染。我们可以通过 el 属性来指定。
例如一段 html 模板:
<div id="app">
</div>
然后创建 Vue 实例,关联这个 div
let vm = new Vue({
el: "#app"
})
这样,Vue 就可以基于 id 为app
的 div 元素作为模板进行渲染了。在这个div 范围以外的部分是无法使用 vue 特性的。
当 Vue 实例被创建时,它会尝试获取在 data 中定义的所有属性,用于视图的渲染,并且监视 data 中的属性变化,当 data 发生改变,所有相关的视图都将重新渲染,这就是“响应式“系统。
html:
<div id="app">
<input type="text" v-model="name" />
</div>
JS:
let vm = new Vue({
el: "#app",
data: {
name: "刘德华"
}
})
input
的值Vue 实例中除了可以定义 data 属性,也可以定义方法,并且在 Vue 实例的作用范围内使用。
Html:
<div id="app">
{{num}}
<button v-on:click="add">加</button>
</div>
JS:
let vm = new Vue({
el: "#app",
data: {
num: 0
},
methods: {
add: function () {
// this 代表的当前 vue 实例
this.num++;
}
}
})
什么是指令?
v-
前缀的特殊特性。例如我们在入门案例中的 v-on,代表绑定事件。
格式:{{表达式}}
说明:
使用{{}}方式在网速较慢时会出现问题。在数据未加载完成时,页面会显示出原始的{{}}
,加载完毕后才显示正确数据,我们称为插值闪烁。
我们将网速调慢一些,然后刷新页面,试试看刚才的案例:
可以使用 v-tex
t 和 v-html
指令来替代{{}}
说明:
示例:
<div id="app">
v-text:<span v-text="hello"></span> <br />
v-html:<span v-html="hello"></span>
</div>
<script src="./node_modules/vue/dist/vue.js"></script>
<script>
let vm = new Vue({
el: "#app",
data: {
hello: "<h1>大家好</h1>"
}
})
</script>
效果:
并且不会出现插值闪烁,当没有数据时,会显示空白或者默认数据。
html 属性不能使用双大括号形式绑定,我们使用 v-bind 指令给 HTML 标签属性绑定值;而且在将 v-bind
用于 class
和 style
时,Vue.js 做了专门的增强。
<div id="app" class="static" v-bind:class="{ active: isActive, 'text-danger': hasError }">
</div>
<script>
let vm = new Vue({
el: "#app",
data: {
isActive: true,
hasError: false
}
})
</script>
v-bind:style
的对象语法十分直观,看着非常像 CSS,但其实是一个JavaScript 对象。style属性名可以用驼峰式 (camelCase) 或短横线分隔 (kebab-case,这种方式记得用单引号括起来) 来命名。
例如:font-size–>fontSize
<div id="app" class="static" v-bind:class="{ active: isActive, 'text-danger': hasError }"
v-bind:style="{ color: activeColor, fontSize: fontSize + 'px' }">
</div>
<script>
let vm = new Vue({
el: "#app",
data: {
isActive: true,
hasError: false,
activeColor: 'red',
fontSize: 30
}
})
</script>
<div id="app" class="static" v-bind:class="{ active: isActive, 'text-danger': hasError }"
v-bind:style="{ color: activeColor, fontSize: fontSize + 'px' }" v-bind:user="userName">
</div>
<script>
let vm = new Vue({
el: "#app",
data: {
isActive: true,
hasError: false,
activeColor: 'red',
fontSize: 30,
userName: 'zhangsan'
}
})
</script>
<div id="app" class="static" :class="{ active: isActive, 'text-danger': hasError }"
:style="{ color: activeColor, fontSize: fontSize + 'px' }" :user="userName">
</div>
<script>
let vm = new Vue({
el: "#app",
data: {
isActive: true,
hasError: false,
activeColor: 'red',
fontSize: 30,
userName: 'zhangsan'
}
})
</script>
刚才的 v-text、v-html、v-bind 可以看做是单向绑定,数据影响了视图渲染,但是反过来就不行。接下来学习的 v-model 是双向绑定,视图(View)和模型(Model)之间会互相影响。既然是双向绑定,一定是在视图中可以修改数据,这样就限定了视图的元素类型。目前v-model 的可使用元素有:
基本上除了最后一项,其它都是表单的输入项。
示例:
<div id="app"> <input type="checkbox" v-model="language" value="Java" />Java<br /><input type="checkbox" v-model="language" value="PHP" />PHP<br /> <input type="checkbox" v-model="language" value="Swift" />Swift<br /> <h1> 你选择了:{{language.join(',')}} </h1> </div> <script src="../node_modules/vue/dist/vue.js"></script> <script type="text/javascript"> let vm = new Vue({ el: "#app", data: { language: [] } }) </script>
CheckBox
对应一个 model 时,model 的类型是一个数组,单个checkbox 值默认是boolean 类型text
和textarea
默认对应的 model 是字符串select
单选对应字符串,多选对应也是数组v-on 指令用于给页面元素绑定事件。
语法: v-on:事件名="js 片段或函数名"
示例:
<div id="app"> <!--事件中直接写 js 片段--> <button v-on:click="num++">点赞</button> <!--事件指定一个回调函数,必须是 Vue 实例中定义的函数--> <button v-on:click="decrement">取消</button> <h1>有{{num}}个赞</h1> </div> <script type="text/javascript"> let vm = new Vue({ el: "#app", data: { num: 100 }, methods: { decrement() { this.num--; //要使用 data 中的属性,必须this.属性名} } } }) </script>
另外,事件绑定可以简写,例如v-on:click='add'
可以简写为@click='add'
在事件处理程序中调用 event.preventDefault()
或 event.stopPropagation()
是非常常见的需求。尽管我们可以在方法中轻松实现这点,但更好的方式是:方法只有纯粹的数据逻辑,而不是去处理 DOM 事件细节。
为了解决这个问题,Vue.js 为 v-on
提供了事件修饰符。修饰符是由点开头的指令后缀来表示的。
.stop
:阻止事件冒泡到父元素.prevent
:阻止默认事件发生.capture
:使用事件捕获模式.self
:只有元素自身触发事件才执行。(冒泡或捕获的都不执行).once
:只执行一次<div id="app"> <!--事件中直接写 js 片段--> <button v-on:click="num++">点赞</button> <!--事件指定一个回调函数,必须是 Vue 实例中定义的函数--> <button v-on:click="decrement">取消</button> <h1>有{{num}}个赞</h1> <div style="border: 1px solid red;padding: 20px;" @click="hello"> 大div <div style="border: 1px solid blue;padding: 20px;" @click.stop="hello"> 小div <br> <a href="http://www.baidu.com" @click.prvent>去百度</a> </div> </div> </div> <script type="text/javascript"> let vm = new Vue({ el: "#app", data: { num: 100 }, methods: { decrement() { this.num--; //要使用 data 中的属性,必须this.属性名} }, hello(){ alert("点击了!") } } }) </script>
效果:点击小div,大div不会有点击事件,点击超链接,不会跳转,只会出现小div的点击事件
在监听键盘事件时,我们经常需要检查常见的键值。Vue 允许为 v-on
在监听键盘事件时添加按键修饰符:
<!-- 只有在 `keyCode` 是 13 时调用 `vm.submit()` -->
<input v-on:keyup.13="submit">
记住所有的 keyCode
比较困难,所以 Vue 为最常用的按键提供了别名:
<!-- 同上 -->
<input v-on:keyup.enter="submit">
<!-- 缩写语法 -->
<input @keyup.enter="submit">
全部的按键别名:
.enter
.tab
.delete
(捕获“删除”和“退格”键).esc
.space
.up
.down
.left
.right
可以用如下修饰符来实现仅在按下相应按键时才触发鼠标或键盘事件的监听器。
.ctrl
.alt
.shift
<!-- Alt + C -->
<input @keyup.alt.67="clear">
<!-- Ctrl + Click -->
<div @click.ctrl="doSomething">Do something</div>
遍历数据渲染页面是非常常用的需求,Vue 中通过 v-for 指令来实现。
语法:v-for="item in items"
<div id="app"> <ul> <li v-for="user in users"> {{user.name}} - {{user.gender}} - {{user.age}} </li> </ul> </div> <script src="../node_modules/vue/dist/vue.js"></script> <script type="text/javascript"> let app = new Vue({ el: "#app", data: { users: [ { name: '柳岩', gender: '女', age: 21 }, { name: '张三', gender: '男', age: 18 }, { name: '范冰冰', gender: '女', age: 24 }, { name: '刘亦菲', gender: '女', age: 18 }, { name: '古力娜扎', gender: '女', age: 25 } ] }, }) </script>
在遍历的过程中,如果我们需要知道数组角标,可以指定第二个参数:语法:v-for="(item,index) in items"
<div id="app">
<ul>
<li v-for="(user, index) in users">
{{index + 1}}. {{user.name}} - {{user.gender}} - {{user.age}}</li>
</ul>
</div>
v-for 除了可以迭代数组,也可以迭代对象。语法基本类似
语法:
v-for="value in object"
v-for="(value,key) in object"
v-for="(value,key,index) in object"
<div id="app"> <ul> <li v-for="(user, index) in users"> {{index + 1}}. {{user.name}} - {{user.gender}} - {{user.age}}</li> </ul> <ul> <li v-for="(value, key, index) in user"> {{index + 1}}. {{key}} - {{value}} </li> </ul> </div> <script type="text/javascript"> let app = new Vue({ el: "#app", data: { users: [ { name: '柳岩', gender: '女', age: 21 }, { name: '张三', gender: '男', age: 18 }, { name: '范冰冰', gender: '女', age: 24 }, { name: '刘亦菲', gender: '女', age: 18 }, { name: '古力娜扎', gender: '女', age: 25 } ], user: { name: '张三', gender: '男', age: 18 } }, }) </script>
用来标识每一个元素的唯一特征,这样 Vue 可以使用“就地复用”策略有效的提高渲染的效率。
<ul>
<li v-for="(user, index) in users" :key="index">
{{index + 1}}. {{user.name}} - {{user.gender}} - {{user.age}}</li>
</ul>
<ul>
<li v-for="(value, key, index) in user" :key="user.name">
{{index + 1}}. {{key}} - {{value}}
</li>
</ul>
如果 items 是数组,可以使用 index 作为每个元素的唯一标识
如果 items 是对象数组,可以使用 item.id 作为每个元素的唯一标识
v-if,顾名思义,条件判断。当得到结果为 true 时,所在的元素才会被渲染
。
v-show,当得到结果为 true 时,所在的元素才会被显示
。
语法:v-if="布尔表达式", v-show="布尔表达式"
<div id="app"> <button v-on:click="show = !show">点我呀</button> <br> <h1 v-if="show"> 看到我啦?! </h1> <h1 v-show="show"> 看到我啦?!show </h1> </div> <script type="text/javascript"> let app = new Vue({ el: "#app", data: { show: true } }) </script>
当 v-if 和 v-for 出现在一起时,v-for 优先级更高。也就是说,会先遍历,再判断条件。
修改 v-for 中的案例,添加 v-if:
<ul>
<li v-for="(user, index) in users" :key="index" v-if="user.gender=='女'">
{{index + 1}}. {{user.name}} - {{user.gender}} - {{user.age}}</li>
</ul>
只显示女性
v-else 元素必须紧跟在带 v-if
或者 v-else-if
的元素的后面,否则它将不会被识别。
<div id="app"> <button v-on:click="random=Math.random()">点我呀</button><span>{{random}}</span> <h1 v-if="random >= 0.75"> 看到我啦?!v-if >= 0.75 </h1> <h1 v-else-if="random > 0.5"> 看到我啦?!v-else-if > 0.5 </h1> <h1 v-else-if="random > 0.25"> 看到我啦?!v-else-if > 0.25 </h1> <h1 v-else> 看到我啦?!v-else </h1> </div> <script type="text/javascript"> let app = new Vue({ el: "#app", data: { random: 1 } }) </script>
某些结果是基于之前数据实时计算出来的,我们可以利用计算属性。来完成
<div id="app"> <ul> <li>西游记:价格{{xyjPrice}},数量: <input type="number" v-model="xyjNum"> </li> <li>水浒传:价格{{shzPrice}},数量: <input type="number" v-model="shzNum"> </li> <li>总价:{{totalPrice}}</li> </ul> </div> <script> let vm = new Vue({ el: "#app", data: { xyjNum: 1, shzNum: 1, xyjPrice: 30, shzPrice: 10 }, computed: { totalPrice() { return this.xyjNum * this.xyjPrice + this.shzNum * this.shzPrice } } }) </script>
效果:只要依赖的属性发生变化,就会重新计算(动态计算)这个属性
watch 可以让我们监控一个值的变化。从而做出相应的反应。
<div id="app"> <ul> <li>西游记:价格{{xyjPrice}},数量: <input type="number" v-model="xyjNum"> </li> <li>水浒传:价格{{shzPrice}},数量: <input type="number" v-model="shzNum"> </li> <li>总价:{{totalPrice}}</li> {{ msg }} </ul> </div> <script> let vm = new Vue({ el: "#app", data: { xyjNum: 1, shzNum: 1, xyjPrice: 30, shzPrice: 10, msg: "" }, computed: { totalPrice() { return this.xyjNum * this.xyjPrice + this.shzNum * this.shzPrice } }, watch: { xyjNum(newVal, oldVal) { if (newVal >= 3) { this.msg = "西游记没有更多库存了" this.xyjNum = 3 } else { this.msg = "" } } } }) </script>
效果:西游记数量不能超过3
过滤器不改变真正的data
,而只是改变渲染的结果,并返回过滤后的版本。在很多不同的情况下,过滤器都是有用的,比如尽可能保持 API 响应的干净,并在前端处理数据的格式。
示例:展示用户列表性别显示男女
<div id="app"> <table> <tr v-for="user in userList"> <td>{{user.id}}</td> <td>{{user.name}}</td> <!-- 使用代码块实现,有代码侵入 --> <td>{{user.gender===1? "男":"女"}}</td> </tr> </table> </div> </body> <script> let app = new Vue({ el: "#app", data: { userList: [ { id: 1, name: 'jacky', gender: 1 }, { id: 2, name: 'peter', gender: 0 } ] } }); </script>
注册在当前 vue 实例中,只有当前实例能用
<div id="app"> <table> <tr v-for="user in userList"> <td>{{user.id}}</td> <td>{{user.name}}</td> <!-- 使用代码块实现,有代码侵入 --> <td>{{user.gender===1? "男":"女"}}</td> <!-- | 管道符号:表示使用后面的过滤器处理前面的数据 --> <td>{{user.gender | genderFilter}}</td> </tr> </table> </div> </body> <script> let app = new Vue({ el: "#app", data: { userList: [ { id: 1, name: 'jacky', gender: 1 }, { id: 2, name: 'peter', gender: 0 } ] }, // filters 定义局部过滤器,只可以在当前 vue 实例中使用 filters: { genderFilter(gender) { return gender === 1 ? '男~' : '女~' } } }); </script>
// 在创建 Vue 实例之前全局定义过滤器:
Vue.filter('capitalize', function (value) {
return value.charAt(0).toUpperCase() + value.slice(1)
})
<!-- 任何 vue 实例都可以使用: -->
<td>{{user.name | capitalize }} </td>
在大型应用开发的时候,页面可以划分成很多部分。往往不同的页面,也会有相同的部分。例如可能会有相同的头部导航。
但是如果每个页面都独自开发,这无疑增加了我们开发的成本。所以我们会把页面的不同部分拆分成独立的组件,然后在不同页面就可以共享这些组件,避免重复开发。
在 vue 里,所有的 vue 实例都是组件
我们通过 Vue 的 component 方法来定义一个全局组件。
<div id="app"> <!--使用定义好的全局组件--> <counter></counter> </div> <script type="text/javascript"> // 定义全局组件,两个参数:1,组件名称。2,组件参数 Vue.component("counter", { template: '<button v-on:click="count++">你点了我 {{ count }} 次,我记住了.</button>', data() { return { count: 0 } } }) let app = new Vue({ el: "#app" }) </script>
定义好的组件,可以任意复用多次:
<div id="app">
<!--使用定义好的全局组件-->
<counter></counter>
<counter></counter>
<counter></counter>
<counter></counter>
</div>
组件的 data 属性必须是函数!
一个组件的 data 选项必须是一个函数,因此每个实例可以维护一份被返回对象的独立的拷贝;
一旦全局注册,就意味着即便以后你不再使用这个组件,它依然会随着Vue 的加载而加载。因此,对于一些并不频繁使用的组件,我们会采用局部注册。
我们先在外部定义一个对象,结构与创建组件时传递的第二个参数一致:
// 定义局部组件
const counter = {
template: '<button v-on:click="count++">你点了我 {{ count }} 次,我记住了.</button>',
data() {
return {
count: 0
}
}
};
let app = new Vue({
el: "#app",
components:{
counter:counter // 将定义的对象注册为组件
}
})
简写:
let app = new Vue({
el: "#app",
components:{
counter // 将定义的对象注册为组件
}
})
每个 Vue 实例在被创建时都要经过一系列的初始化过程 :创建实例,装载模板,渲染模板等等。Vue 为生命周期中的每个状态都设置了钩子函数(监听函数)。每当Vue 实例处于不同的生命周期时,对应的函数就会被触发调用。
生命周期:你不需要立马弄明白所有的东西。
如果使用构造生成文件(例如构造单文件组件),模板编译将提前执行
<div id="app"> <span id="num">{{num}}</span> <button v-on:click="num++">赞!</button> <h2> {{name}},非常帅!!!有{{num}}个人点赞。 </h2> </div> <script> let app = new Vue({ el: "#app", data: { name: "张三", num: 100 }, methods: { show() { return this.name; }, add() { this.num++; } }, beforeCreate() { console.log("=========beforeCreate============="); console.log("数据模型未加载:" + this.name, this.num); console.log("方法未加载:" + this.show()); console.log("html 模板未加载:" + document.getElementById("num")); }, created: function () { console.log("=========created============="); console.log("数据模型已加载:" + this.name, this.num); console.log("方法已加载:" + this.show()); console.log("html 模板已加载:" + document.getElementById("num")); console.log("html 模板未渲染:" + document.getElementById("num").innerText); }, beforeMount() { console.log("=========beforeMount============="); console.log("html 模板未渲染:" + document.getElementById("num").innerText); }, mounted() { console.log("=========mounted============="); console.log("html 模板已渲染:" + document.getElementById("num").innerText); }, beforeUpdate() { console.log("=========beforeUpdate============="); console.log("数据模型已更新:" + this.num); console.log("html 模板未更新: " + document.getElementById("num").innerText); }, updated() { console.log("=========updated============="); console.log("数据模型已更新:" + this.num); console.log("html 模板已更新: " + document.getElementById("num").innerText); } }); </script>
<div id=”app”>
元素。使用了 router,导入了 App 组件。并且使用<App/>
标签引用了这个组件<router-view>
,所以显示了图片。但是由于<router-view>
代表路由的视图,默认是访问/#/路径(router 路径默认使用HASH 模式)。在 router 中配置的/是显示 HelloWorld 组件。<router-linkto="/foo">Go to Foo</router-link>
标签Vue 单文件组件模板有三个部分;
<template> <h1>你好,hello,{{ name }}</h1> </template> <script> export default { data() { return { name: "张三", }; }, }; </script> <style> h1, h2 { font-weight: normal; color: red; } </style>
文件–>首选项–>用户代码片段–>点击新建代码片段–取名 vue.json 确定
{ "生成 vue 模板": { "prefix": "vue", "body": [ "<template>", "<div></div>", "</template>", "", "<script>", "//这里可以导入其他文件(比如:组件,工具 js,第三方插件js,json文件,图片文件等等)", "//例如:import 《组件名称》 from '《组件路径》';", "", "export default {", "//import 引入的组件需要注入到对象中才能使用", "components: {},", "props: {},", "data() {", "//这里存放数据", "return {", "", "};", "},", "//计算属性 类似于 data 概念", "computed: {},", "//监控 data 中的数据变化", "watch: {},", "//方法集合", "methods: {", "", "},", "//生命周期 - 创建完成(可以访问当前 this 实例)", "created() {", "", "},", "//生命周期 - 挂载完成(可以访问 DOM 元素)", "mounted() {", "", "},", "beforeCreate() {}, //生命周期 - 创建之前", "beforeMount() {}, //生命周期 - 挂载之前", "beforeUpdate() {}, //生命周期 - 更新之前", "updated() {}, //生命周期 - 更新之后", "beforeDestroy() {}, //生命周期 - 销毁之前", "destroyed() {}, //生命周期 - 销毁完成", "activated() {}, //如果页面有 keep-alive 缓存功能,这个函数会触发", "}", "</script>", "<style lang='scss' scoped>", "//@import url($3); 引入公共 css 类", "$4", "</style>" ], "description": "生成 vue 模板" } }
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。