Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue 也完全能够为复杂的单页应用提供驱动。
版本
官网教程:https://cn.vuejs.org/v2/guide/instance.html
特点
MVVM 是Model-View-ViewModel
的缩写,它是一种基于前端开发的架构模式,是一种事件驱动编程方式
Model
:vue对象的data属性里面的数据,这里的数据要显示到页面中View
:vue中数据要显示的HTML页面,在vue中,也称之为“视图模板” (HTML+CSS)ViewModel
:vue中编写代码时的vm对象,它是vue.js的核心,负责连接 View 和 Model数据的中转,保证视图和数据的一致性,所以前面代码中,data里面的数据被显示中p标签中就是vm对象自动完成的(双向数据绑定:JS中变量变了,HTML中数据也跟着改变)# 对于制作原型或学习,你可以这样使用最新版本: <script src="https://cdn.jsdelivr.net/npm/vue@2.6.14"></script> # 对于生产环境: <script src="https://cdn.jsdelivr.net/npm/vue@2.6.14"></script>
其实就是直接在浏览器中打开https://cdn.jsdelivr.net/npm/vue/dist/vue.js,然后复制下来,创建一个js文件再粘贴进去
<script src="js/vue.js"></script>
<html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.4.1/jquery.min.js"></script> <link href="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/css/bootstrap.min.css" rel="stylesheet"> <script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/js/bootstrap.min.js"></script> <script src="https://cdn.jsdelivr.net/npm/vue@2.6.14"></script> </head> <body> <h1>Vue</h1> <div id="app"> {{ word }} </div> </body> <script> let vm = new Vue({ el:'#app', data:{ word:'Hello Vue!' } }) </script> </html>
vm.word = 'Hello,HammerZe' // 修改js中变量的值 $('#app').text('饿死了') // 修改HTML的div中的值
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>插值</title> <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script> </head> <body> <div id="box"> <ul> <li>字符串:{{name}}</li> <li>数值:{{age}}</li> <li>数组:{{list1}}</li> <li>对象:{{obj1}}</li> <li>字符串:{{link1}}</li> <li>运算:{{10+20+30+40}}</li> <li>三目运算符:{{10>20?'是':'否'}}</li> </ul> </div> </body> <script> let vm = new Vue({ el: '#box', // 在box这个div中可以写 vue的语法 data: { name: 'Darker', // 字符串 age: 18, // 数值 list1: [1,2,3,4], // 数组 obj1: {name: 'Darker', age: 19}, // 对象 link1: '<a href="https://www.baidu.com">百度一下 你就知道</a>' } }) </script> </html>
指令 | 释义 |
---|---|
v-html | 让HTML渲染成页面 |
v-text | 标签内容显示js变量对应的值 |
v-show | 放1个布尔值:为真 标签就显示;为假 标签就不显示 |
v-if | 放1个布尔值:为真 标签就显示;为假 标签就不显示 |
v-show与 v-if的区别:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>v-html</title> <script src="https://cdn.jsdelivr.net/npm/vue@2.6.14"></script> </head> <body> <div id="box"> <ul> <li v-html="link1"></li> </ul> </div> </body> <script> let vm = new Vue({ el: '#box', // 在box这个div中可以写 vue的语法 data: { link1: '<a href="https://www.baidu.com">百度一下 你就知道</a>' } }) </script> </html>
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>v-text</title> <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script> </head> <body> <div id="box"> <ul> <li v-text="link1"></li> </ul> </div> </body> <script> let vm = new Vue({ el: '#box', // 在box这个div中可以写 vue的语法 data: { link1: '<a href="https://www.baidu.com">百度一下 你就知道</a>', } }) </script> </html>
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>v-show</title> <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script> </head> <body> <div id="box"> <h3>案例:控件通过按钮来控制显示和小事</h3> <button @click="handleClick()">点我</button> <br> <div v-show="isShow">isShow</div> </div> </body> <script> let vm = new Vue({ el: '#box', data: { isShow: true, }, methods: { handleClick(){ this.isShow = !this.isShow // this指的是当前的vue对象 }, } }) </script> </html>
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>v-if</title> <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script> </head> <body> <div id="box"> <h3>案例:控件通过按钮来控制显示和消失</h3> <button @click="handleClick()">点我</button> <br> <div v-if="isCreated">isCreated</div> </div> </body> <script> let vm = new Vue({ el: '#box', data: { isCreated:true }, methods: { handleClick(){ this.isCreated = !this.isCreated // this指的是当前的vue对象 }, } }) </script> </html>
指令 | 释义 |
---|---|
v-on | 触发事件(不推荐) |
@ | 触发事件(推荐) |
@[event] | 触发event事件(可以是其他任意事件) |
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>事件指令</title> <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script> </head> <body> <div id="box"> <button v-on:click="handleClick1">点我1</button> <!-- 下面这个用的多 --> <button @click="handleClick2">点我2</button> <!-- 如果不传参数,是没有区别的 --> <button @click="handleClick3()">点我3-1(带括号)</button> <!-- 如果要传参数 --> <button @click="handleClick3(1,22,333)">点我3-2(带括号+参数)</button> <!-- 传入事件 --> <button @click="handleClick4($event)">点我4(带事件参数)</button> </div> </body> <script> let vm = new Vue({ el: '#box', data: { }, methods: { handleClick1() { console.log('点我1') }, handleClick2() { console.log('点我2') }, handleClick3(a,b,c) { console.log(a,b,c) }, handleClick4(event) { console.log(event) }, } }) </script> </html>
指令 | 释义 |
---|---|
v-bind | 直接写js的变量或语法(不推荐) |
: | 直接写js的变量或语法(推荐) |
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>属性指令</title> <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script> <style> .red { color: rgba(255, 104, 104, 0.7); } .purple { color: rgba(104, 104, 255, 0.7); } </style> </head> <body> <div id="box"> <img v-bind:src="url" alt="" height="100"> <br> <button @click="handleClick">点我变色</button> <div :class="isActive?'red':'purple'"> <h1>我是一个div</h1> </div> </div> </body> <script> let vm = new Vue({ el: '#box', data: { url: 'https://ss0.bdstatic.com/70cFvHSh_Q1YnxGkpoWK1HF6hhy/it/u=205441424,1768829584&fm=26&gp=0.jpg', change: 'red', isActive: true }, methods: { handleClick() { this.isActive = !this.isActive }, } }) </script> </html>
【待续】