Vue3 学习笔记,快速初始化Vue项目及 data 函数用法学习(二)
ztj100 2024-12-31 15:58 11 浏览 0 评论
推荐阅读
Vue3 学习笔记,Vue 简介及如何引入 Vue3 框架(一)
快速初始化Vue项目
在学习之前,我们先通过引入JS文件的方式快速初始化一个 Vue 项目,首先我们先打开 VsCode 编辑器,具体步骤如下:
一、新建一个文件夹
二、新建index.html、style.css 和 index.js 文件
三、新建个lib目录,把下载好的 vue.global.js 文件放在这个目录下(下载地址:https://unpkg.com/vue@3.2.45/dist/vue.global.js)
完成后的目录结构如下:
--- index.html
--- index.js
--- lib
---vue.global.js
--- style.css
四、然后回到 index.html 做一些代码编写工作:
- 通过一个 !(感叹号)快速初始化一个 h5 页面代码
- 然后再 head 标签和 title 标签之间,引入 lib/vue.global.js 文件。
- 在 js 文件的下方引入 style.css 文件
- 在 body 中定义一个 id = app 的 div 容器
- 在body标签结束之前引入 index.js 文件
<!DOCTYPE html>
<html lang="zh-cn">
<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>Vue项目初始化</title>
<script src="/lib/vue.global.js"></script>
<link rel="stylesheet" href="style.css" />
</head>
<body>
<div id="app"></div>
<script src="index.js"></script>
</body>
</html>
五、接下来回到 index.js 文件初始化 vue 实例,挂载到 id 等于 app 的实例中,代码如下
const app = Vue.createApp();
app.mount("#app");
到这里一个简单的 Vue3 项目就创建完了,接下来我们进入 data() 函数的学习。
如何理解 data() 数据状态函数
在 Vue.js 中,data 函数用于定义组件实例的状态。组件实例中定义的数据可以在模板中使用,也可以在组件的 JavaScript 逻辑中使用。
下面是一个例子,该组件有一个名为 message 的 data 属性:
<template>
<div>
{{ message }}
</div>
</template>
<script>
export default {
data() {
return {
message: '你好,前端达人!'
}
}
}
</script>
在上面的例子中,data 函数返回了一个对象,该对象中有一个名为 message 的属性。在模板中,可以使用 {{ message }} 来显示这个属性的值。
注意,data 属性必须是函数,这是固定用法。如果 data 属性是一个普通对象,那么所有组件实例将共享同一个数据对象,在多个组件实例中使用同一个 data 对象将会导致问题。
另外,组件实例中定义的数据属性是响应式的,这意味着如果数据属性的值改变,那么对应的模板中的内容也将自动更新(响应式机制,稍后会介绍)。
通过data函数返回的对象,组件内部都能使用 this 访问到,如:
<template>
<button @click="changeData">Change Data</button>
</template>
<script>
export default {
data() {
return {
message: 'Hello, Vue!'
}
},
methods:{
changeData(){
this.message = "new data";
}
}
}
</script>
在 Vue.js 中,data 函数用于定义组件实例的状态,返回的对象中的属性可以是任意类型的值,包括:
- 基本类型: 例如数字、字符串、布尔值等
- 数组: 例如 array
- 对象:例如 Object
- 甚至是函数
例如
data() {
return {
message: 'Hello, Vue!',
count: 0,
todos: [],
user: {
name: 'John Doe',
age: 30
},
print: function(){
console.log("data function")
}
}
},
在上面的例子中, 定义了message,count,todos,user,print五个数据,分别是字符串,数字,数组,对象,函数。
Vue3 中你可以用 setup() 函数定义数据状态
在 Vue 3 中,可以使用 setup() 函数来定义组件的逻辑和状态。在 setup() 函数中,可以使用 reactive() 函数来创建一个响应式对象,它可以用来存储组件的状态。下面是一个示例:
<!DOCTYPE html>
<html>
<head>
<title>Vue 3 数据状态示例</title>
</head>
<body>
<div id="app">
{{ message }}
</div>
<script src="https://cdn.jsdelivr.net/npm/vue@3"></script>
<script>
const app = Vue.createApp({
setup() {
const state = Vue.reactive({
message: 'Hello Vue 3'
});
return {
...state
}
}
});
app.mount('#app')
</script>
</body>
</html>
HTML属性绑定 Data 中的值
当你想要绑定一个链接的 href 属性到 Vue 实例中的数据时,你可以这样做:
<a v-bind:href="url">Link</a>
这里的 v-bind:href 指令绑定了 Vue 实例中的 url 数据到链接的 href 属性上。当 url 数据更新时,链接的 href 也会更新。
同样也可以使用缩写:
<a :href="url">Link</a>
需要注意的是,当你绑定一个数据到 href 时,确保你绑定的是完整的URL,不然可能会被浏览器理解成相对路径。
基于 data 数据状态进行列表展示
在 Vue 中展示列表数据可以使用 v-for 指令。v-for 指令用于遍历数组中的数据并将其渲染到页面上。
假设你有一个名为 items 的数组,其中包含了要展示在页面上的数据,那么你可以在模板中使用 v-for 指令来遍历 items 数组并将每一项数据渲染到页面上。
例如:
<template>
<ul>
<li v-for="item in items" :key="item.id">{{ item.name }}</li>
</ul>
</template>
<script>
export default {
data() {
return {
items: [
{ id: 1, name: 'Item 1' },
{ id: 2, name: 'Item 2' },
{ id: 3, name: 'Item 3' },
],
};
},
};
</script>
当你使用 v-for 指令来遍历数组中的数据时,你需要在指令中指定两个值:
- 第一个值是当前遍历到的数组元素,在上面的例子中是 item。
- 第二个值是数组本身,在上面的例子中是 items。
在指令中你可以使用这两个值来定义要渲染在页面上的元素。在上面的例子中,我们使用了一个 li 标签来渲染每一项数据,并在里面使用了一个插值表达式来展示每一项的 name。
在遍历数组时,为了避免vue重复渲染,你需要给每一个元素赋予一个唯一标识符。可以使用 v-bind 指令和 key 特性来为每一项绑定一个唯一的标识符,比如上面的例子中用了每一项的 id 来标识。
整体来说,使用 v-for 指令可以让你很容易地在 Vue 中遍历数组并将数据渲染到页面上。
在真实项目中还会经常使用 computed 和 methods 来获取数据进行展示, 也可以使用vuex进行状态管理。(在稍后的文章里会详细介绍)
基于条件展示 Data 数据
在 Vue 中一共有 4 种方式可以基于条件展示 Data 中的数据。
一、使用 v-if 指令。
v-if 指令用于根据条件判断是否渲染元素。当条件为 true 时,元素会被渲染,否则元素不会被渲染。
<template>
<div>
<p v-if="showData">{{ data }}</p>
</div>
</template>
<script>
export default {
data() {
return {
data: 'This is my data',
showData: true,
};
},
};
</script>
二、使用 v-show 指令。
v-show 指令与 v-if 指令类似,也用于根据条件判断是否渲染元素。唯一的区别是,v-show 指令会始终渲染元素,只是在条件为 false 时将元素隐藏。
<template>
<div>
<p v-show="showData">{{ data }}</p>
</div>
</template>
<script>
export default {
data() {
return {
data: 'This is my data',
showData: true,
};
},
};
</script>
三、使用三元运算符。
三元运算符可以在模板中直接使用条件判断并返回对应的值,从而达到条件展示数据的目的.
<template>
<div>
<p>{{showData ? data : "loading"}}</p>
</div>
</template>
<script>
export default {
data() {
return {
data: 'This is my data',
showData: true,
};
},
};
</script>
四、使用计算属性 computed.
可以在 computed 里面进行条件判断,并返回对应的数据。
<template>
<div>
<p>{{computedData}}</p>
</div>
</template>
<script>
export default {
data() {
return {
data: 'This is my data',
showData: true,
};
},
computed: {
computedData() {
return this.showData ? this.data : "loading"
}
}
};
</script>
这四种方法都可以在 Vue 中基于条件展示数据。
你可以根据自己的需求来选择使用哪一种方法。
v-if指令和v-show的区别在于,v-if会在第一次加载的时候,真正的去除不需要的元素,而v-show只是用CSS来控制元素的显示和隐藏。所以v-if会在第一次加载时对性能有影响,而v-show在第一次加载时不会对性能产生影响。
计算属性 computed 可以在数据发生改变时自动更新,性能会比在模板中使用三元运算符和方法好。
结束语
今天的文章就介绍到这里,感谢你的阅读,下一篇文章我将会继续介绍事件、computed 计算属性相关内容。
相关推荐
- 从IDEA开始,迈进GO语言之门(idea got)
-
前言笔者在学习GO语言编程的时候,GO语言在国内还没有像JAVA/Php/Python那样普及,绕了不少的弯路,要开始入门学习一门编程语言,最好就先从选择一个好的编程语言的开发环境开始,有了这个开发环...
- 基于SpringBoot+MyBatis的私人影院java网上购票jsp源代码Mysql
-
本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目介绍基于SpringBoot...
- 基于springboot的个人服装管理系统java网上商城jsp源代码mysql
-
本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目介绍基于springboot...
- 基于springboot的美食网站Java食品销售jsp源代码Mysql
-
本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目介绍基于springboot...
- 贸易管理进销存springboot云管货管账分析java jsp源代码mysql
-
本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目描述贸易管理进销存spring...
- SpringBoot+VUE员工信息管理系统Java人员管理jsp源代码Mysql
-
本项目为前几天收费帮学妹做的一个项目,JavaEEJSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。一、项目介绍SpringBoot+V...
- 目前见过最牛的一个SpringBoot商城项目(附源码)还有人没用过吗
-
帮粉丝找了一个基于SpringBoot的天猫商城项目,快速部署运行,所用技术:MySQL,Druid,Log4j2,Maven,Echarts,Bootstrap...免费给大家分享出来前台演示...
- SpringBoot+Mysql实现的手机商城附带源码演示导入视频
-
今天为大家带来的是基于SpringBoot+JPA+Thymeleaf框架的手机商城管理系统,商城系统分为前台和后台、前台用的是Bootstrap框架后台用的是SpringBoot+JPA都是现在主...
- 全网首发!马士兵内部共享—1658页《Java面试突击核心讲》
-
又是一年一度的“金九银十”秋招大热门,为助力广大程序员朋友“面试造火箭”,小编今天给大家分享的便是这份马士兵内部的面试神技——1658页《Java面试突击核心讲》!...
- SpringBoot数据库操作的应用(springboot与数据库交互)
-
1.JDBC+HikariDataSource...
- SpringBoot 整合 Flink 实时同步 MySQL
-
1、需求在Flink发布SpringBoot打包的jar包能够实时同步MySQL表,做到原表进行新增、修改、删除的时候目标表都能对应同步。...
- SpringBoot + Mybatis + Shiro + mysql + redis智能平台源码分享
-
后端技术栈基于SpringBoot+Mybatis+Shiro+mysql+redis构建的智慧云智能教育平台基于数据驱动视图的理念封装element-ui,即使没有vue的使...
- Springboot+Mysql舞蹈课程在线预约系统源码附带视频运行教程
-
今天发布的是由【猿来入此】的优秀学员独立做的一个基于springboot脚手架的Springboot+Mysql舞蹈课程在线预约系统,系统项目源代码在【猿来入此】获取!https://www.yuan...
- SpringBoot+Mysql在线众筹系统源码+讲解视频+开发文档(参考论文
-
今天发布的是由【猿来入此】的优秀学员独立做的一个基于springboot脚手架的在线众筹管理系统,主要实现了普通用户在线参与众筹基本操作流程的全部功能,系统分普通用户、超级管理员等角色,除基础脚手架外...
- Docker一键部署 SpringBoot 应用的方法,贼快贼好用
-
这两天发现个Gradle插件,支持一键打包、推送Docker镜像。今天我们来讲讲这个插件,希望对大家有所帮助!GradleDockerPlugin简介...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- 从IDEA开始,迈进GO语言之门(idea got)
- 基于SpringBoot+MyBatis的私人影院java网上购票jsp源代码Mysql
- 基于springboot的个人服装管理系统java网上商城jsp源代码mysql
- 基于springboot的美食网站Java食品销售jsp源代码Mysql
- 贸易管理进销存springboot云管货管账分析java jsp源代码mysql
- SpringBoot+VUE员工信息管理系统Java人员管理jsp源代码Mysql
- 目前见过最牛的一个SpringBoot商城项目(附源码)还有人没用过吗
- SpringBoot+Mysql实现的手机商城附带源码演示导入视频
- 全网首发!马士兵内部共享—1658页《Java面试突击核心讲》
- SpringBoot数据库操作的应用(springboot与数据库交互)
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- node卸载 (33)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- exceptionininitializererror (33)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)