vue特点
- 组件化:用户界面分解为可重用的组件,这些组件可以使开发的页面更加模块化和可维护=
- 双向数据绑定:vue提供了一种轻松绑定数据和DOM元素之间的机制,意味着数据发送变化时,视图会自动更新,反之亦然
- 虚拟DOM:vue使用虚拟DOM来最小化实际DOM更新的次数,从而提高性能
认知
在前端开发中,如果你要使用Vue框架你也需要进行框架的引入相关Vue依赖,在前端用于管理依赖的工具并没有像后端一样采用Maven来进行管理,而是引入了一个新的工具 --- 脚手架(也可以将脚手架直观地理解为maven)
因此,为了快速构建Vue项目,我们可以选择脚手架工具Vue CLI来创建vue项目。如果不想这么麻烦,还可以采用如下的方式来快速使用Vue:
使用CDN引入 在HTML文件中添加以下配置
//使用CDN引入 在HTML文件中添加以下配置
<!-- 开发版本,包含带有警告的调试模式 -->
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
本地加载引入
//本地加载引入
将vue.js下载到本地,然后通过<script>引入
vue的基础使用
如下代码展示了开发者该如何快速构建一个vue项目
<!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>index</title>
</head><body><div id="app"><!-- 表达式 --><h1>{{message}}</h1></div><!-- 开发环境版本,包含了有帮助的命令行警告 --><script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script><script>// 创建Vue的实例new Vue({// 绑定id为app的元素el: "#app",// 数据data: {message: "hello Vue!"}})</script>
</body></html>//运行上述代码,就能在页面上打印出Hello Vue
//上述代码做的工作1.通过new关键字构建一个vue实例对象。这点就像Java中new构建一个实例没太大区别。
2.在构建vue实例对象时,可以传入一个对象信息。具体来看,其为el字段指定一个名为#app的属性。同时为data字段又配置的了一个对象信息。事实上,在Vue中el和data是两个重要的选项,其主要用于定义Vue实例的根元素和数据。其中,
1.el选项:用于指定Vue实例关联的DOM元素。它定义了Vue实例在哪个DOM元素上渲染和控制。值通常为一个CSS选择器
2.data选项:主要用于定义Vue实例的数据。而数据属性可以是任何JavaScript数据类型,例如字符串、数字、对象、数组等。
不难发现,通过构建一个vue实例对象,然后对该实例配置el,data两个字段指定vue实例作用对象,以及存储的数据信息,然后再页面中使用{{}}语法即可获取到data字段中配置的内容。
数据操作
在vue中与数据操作的操作息息相关的大致有计算属性、侦听器、方法三种常见手段
计算属性
Vue允许开发者定义计算属性,这些属性根据其他数据属性的值进行计算。而计算属性会缓存计算结果,只有在依赖的数据属性发生变化时才会重新计算
<!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>index</title>
</head><body><div id="app"> <input type="text" v-model="radius"><p>圆的面积:{{ circleArea }}</p></div><!-- 开发环境版本,包含了有帮助的命令行警告 --><script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script><script>new Vue({el:"#app",data: {radius: 5},computed: {circleArea: function() {return Math.PI * Math.pow(this.radius, 2);}}});</script>
</body></html>
监听属性(watch)
除了计算属性外,也可以使用 watch 选项来监听数据属性的变化,然后执行自定义的操作。上述逻辑改为侦听器则逻辑如下
<!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>index</title>
</head><body><div id="app"> <input type="text" v-model="radius"><p>圆的面积:{{ circleArea }}</p></div><!-- 开发环境版本,包含了有帮助的命令行警告 --><script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script><script>new Vue({el:"#app",data: {radius: 0,circleArea:0},watch: {radius:function(newValue,oldVule){console.log(newValue)this.circleArea = Math.PI * Math.pow(newValue, 2);}}});</script>
</body></html>
指定操作
v-model
用于实现双向数据绑定,通常用于表单元素,使输入框的值与数据属性保持同步
<input v-model="message">
v-for
用于循环渲染列表中的元素,通常与v-bind:key一起使用
<ul><li v-for="item in items" :key="item.id">{{ item.name }}</li>
</ul>
v-if、v-else、v-else-if
用于条件渲染,根据条件决定是否渲染或显示DOM元素
<p v-if="isTrue">This is true</p>
<p v-else>This is false</p>
v-show
用于根据条件切换元素的可见性,与v-if不同,仅使用CSS样式控制显示/隐藏,不会添加/删除元素
<p v-show="isVisible">This may be hidden</p>
v-bind(缩写为:)
用于绑定HTML属性的值到Vue实例的数据属性,以实现动态属性绑定
<a :href="url">Visit Vue.js</a>
v-on(缩写为@)
用于监听DOM事件,当事件触发时执行Vue实例的方法
<button @click="doSomething">Click me</button>
v-once
用于标记元素和其子元素只渲染一次,后续的数据变化不会影响它们
<p v-once>{{ message }}</p>