Vue快速入门(一)
2022/4/11 23:13:20
本文主要是介绍Vue快速入门(一),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
目录- Vue快速入门(一)
- 介绍
- Vue.js 是什么
- M-V-VM思想
- 安装
- CDN引入
- 下载到本地
- 快速使用
- 双向数据绑定测试
- 模板语法
- 插值语法
- 指令
- 文本指令
- v-html:让HTML渲染成页面
- v-text:标签内容显示js变量对应的值
- v-show:显示/隐藏内容
- v-if:显示/删除内容
- 事件指令
- v-on:click 可以缩写成@click
- 属性指令
- v-bind:class=’js变量’可以缩写成::class=’js变量’
- 文本指令
- 介绍
Vue快速入门(一)
介绍
Vue.js 是什么
Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue 也完全能够为复杂的单页应用提供驱动。
版本
- 主流:2.x
- 最新:3.x
官网教程:https://cn.vuejs.org/v2/guide/instance.html
特点
- 采用组件化模式,提高代码复用率、且让代码更好维护
- 声明式编码,让编码人员无需直接操作DOM,提高开发效率
- 使用虚拟DOM+优秀的Diff算法,尽量复用DOM节点
M-V-VM思想
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中数据也跟着改变)
安装
CDN引入
# 对于制作原型或学习,你可以这样使用最新版本: <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的区别:
- v-show:标签还在,只是不显示了(本质display: none)
- v-if:直接操作DOM,删除/插入 标签
v-html:让HTML渲染成页面
<!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>
v-text:标签内容显示js变量对应的值
<!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>
v-show:显示/隐藏内容
<!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>
v-if:显示/删除内容
<!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事件(可以是其他任意事件) |
v-on:click 可以缩写成@click
<!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的变量或语法(推荐) |
v-bind:class=’js变量’可以缩写成::class=’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>
【待续】
这篇关于Vue快速入门(一)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-27Vue2面试真题详解与实战教程
- 2024-12-27Vue3面试真题详解与实战攻略
- 2024-12-27JS大厂面试真题解析与实战指南
- 2024-12-27JS 大厂面试真题详解与实战指南
- 2024-12-27React 大厂面试真题详解及应对策略
- 2024-12-27Vue2 大厂面试真题详解及实战演练
- 2024-12-27Vue3 大厂面试真题详解及实战指南
- 2024-12-27Vue3大厂面试真题详解与实战攻略
- 2024-12-26React入门教程:从零开始搭建你的第一个React应用
- 2024-12-25Vue2入门教程:轻松掌握前端开发基础