当前位置:首页 > 科技  > 软件

Vue3 学习笔记,快速初始化 Vue 项目及 Data 函数用法学习

来源: 责编: 时间:2023-11-30 09:29:35 346观看
导读快速初始化Vue项目在学习之前,我们先通过引入JS文件的方式快速初始化一个 Vue 项目,首先我们先打开 VsCode 编辑器,具体步骤如下:新建一个文件夹。新建index.html、style.css 和 index.js 文件。新建个lib目录,把下载好的

hEX28资讯网——每日最新资讯28at.com

快速初始化Vue项目

在学习之前,我们先通过引入JS文件的方式快速初始化一个 Vue 项目,首先我们先打开 VsCode 编辑器,具体步骤如下:hEX28资讯网——每日最新资讯28at.com

新建一个文件夹。hEX28资讯网——每日最新资讯28at.com

新建index.html、style.css 和 index.js 文件。hEX28资讯网——每日最新资讯28at.com

新建个lib目录,把下载好的 vue.global.js 文件放在这个目录下(下载地址:https://unpkg.com/vue@3.2.45/dist/vue.global.js)。hEX28资讯网——每日最新资讯28at.com

完成后的目录结构如下:hEX28资讯网——每日最新资讯28at.com

--- index.html--- index.js--- lib     ---vue.global.js--- style.css

然后回到 index.html 做一些代码编写工作:hEX28资讯网——每日最新资讯28at.com

  • 通过一个 !(感叹号)快速初始化一个 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 的实例中,代码如下:hEX28资讯网——每日最新资讯28at.com

const app = Vue.createApp();app.mount("#app");

到这里一个简单的 Vue3 项目就创建完了,接下来我们进入 data() 函数的学习。hEX28资讯网——每日最新资讯28at.com

如何理解 data() 数据状态函数

在 Vue.js 中,data 函数用于定义组件实例的状态。组件实例中定义的数据可以在模板中使用,也可以在组件的 JavaScript 逻辑中使用。hEX28资讯网——每日最新资讯28at.com

下面是一个例子,该组件有一个名为 message 的 data 属性:hEX28资讯网——每日最新资讯28at.com

<template>  <div>    {{ message }}  </div></template><script>export default {  data() {    return {      message: '你好,前端达人!'    }  }}</script>

在上面的例子中,data 函数返回了一个对象,该对象中有一个名为 message 的属性。在模板中,可以使用 {{ message }} 来显示这个属性的值。hEX28资讯网——每日最新资讯28at.com

注意,data 属性必须是函数,这是固定用法。如果 data 属性是一个普通对象,那么所有组件实例将共享同一个数据对象,在多个组件实例中使用同一个 data 对象将会导致问题。hEX28资讯网——每日最新资讯28at.com

另外,组件实例中定义的数据属性是响应式的,这意味着如果数据属性的值改变,那么对应的模板中的内容也将自动更新(响应式机制,稍后会介绍)。hEX28资讯网——每日最新资讯28at.com

通过data函数返回的对象,组件内部都能使用 this 访问到,如:hEX28资讯网——每日最新资讯28at.com

<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 函数用于定义组件实例的状态,返回的对象中的属性可以是任意类型的值,包括:hEX28资讯网——每日最新资讯28at.com

  • 基本类型: 例如数字、字符串、布尔值等。
  • 数组: 例如 array。
  • 对象:例如 Object。
  • 甚至是函数。

例如:hEX28资讯网——每日最新资讯28at.com

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五个数据,分别是字符串,数字,数组,对象,函数。hEX28资讯网——每日最新资讯28at.com

Vue3 中你可以用 setup() 函数定义数据状态

在 Vue 3 中,可以使用 setup() 函数来定义组件的逻辑和状态。在 setup() 函数中,可以使用 reactive() 函数来创建一个响应式对象,它可以用来存储组件的状态。下面是一个示例:hEX28资讯网——每日最新资讯28at.com

<!DOCTYPE html><html>  <head>    <title>Vue 3 数据状态示例</title>  </head>  <body>    <div id="app">      {{ message }}    </div>    <script src="https://cdn.jsdelivr/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 实例中的数据时,你可以这样做:hEX28资讯网——每日最新资讯28at.com

<a v-bind:href="url">Link</a>

这里的 v-bind:href 指令绑定了 Vue 实例中的 url 数据到链接的 href 属性上。当 url 数据更新时,链接的 href 也会更新。hEX28资讯网——每日最新资讯28at.com

同样也可以使用缩写:hEX28资讯网——每日最新资讯28at.com

<a :href="url">Link</a>

需要注意的是,当你绑定一个数据到 href 时,确保你绑定的是完整的URL,不然可能会被浏览器理解成相对路径。hEX28资讯网——每日最新资讯28at.com

基于 data 数据状态进行列表展示

在 Vue 中展示列表数据可以使用 v-for 指令。v-for 指令用于遍历数组中的数据并将其渲染到页面上。hEX28资讯网——每日最新资讯28at.com

假设你有一个名为 items 的数组,其中包含了要展示在页面上的数据,那么你可以在模板中使用 v-for 指令来遍历 items 数组并将每一项数据渲染到页面上。hEX28资讯网——每日最新资讯28at.com

例如:hEX28资讯网——每日最新资讯28at.com

<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 指令来遍历数组中的数据时,你需要在指令中指定两个值:hEX28资讯网——每日最新资讯28at.com

  • 第一个值是当前遍历到的数组元素,在上面的例子中是 item。
  • 第二个值是数组本身,在上面的例子中是 items。

在指令中你可以使用这两个值来定义要渲染在页面上的元素。在上面的例子中,我们使用了一个 li 标签来渲染每一项数据,并在里面使用了一个插值表达式来展示每一项的 name。hEX28资讯网——每日最新资讯28at.com

在遍历数组时,为了避免vue重复渲染,你需要给每一个元素赋予一个唯一标识符。可以使用 v-bind 指令和 key 特性来为每一项绑定一个唯一的标识符,比如上面的例子中用了每一项的 id 来标识。hEX28资讯网——每日最新资讯28at.com

整体来说,使用 v-for 指令可以让你很容易地在 Vue 中遍历数组并将数据渲染到页面上。hEX28资讯网——每日最新资讯28at.com

在真实项目中还会经常使用 computed 和 methods 来获取数据进行展示, 也可以使用vuex进行状态管理。(在稍后的文章里会详细介绍)hEX28资讯网——每日最新资讯28at.com

基于条件展示 Data 数据

在 Vue 中一共有 4 种方式可以基于条件展示 Data 中的数据。hEX28资讯网——每日最新资讯28at.com

使用 v-if 指令

v-if 指令用于根据条件判断是否渲染元素。当条件为 true 时,元素会被渲染,否则元素不会被渲染。hEX28资讯网——每日最新资讯28at.com

<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 时将元素隐藏。hEX28资讯网——每日最新资讯28at.com

<template>  <div>    <p v-show="showData">{{ data }}</p>  </div></template><script>export default {  data() {    return {      data: 'This is my data',      showData: true,    };  },};</script>

使用三元运算符

三元运算符可以在模板中直接使用条件判断并返回对应的值,从而达到条件展示数据的目的.hEX28资讯网——每日最新资讯28at.com

<template>  <div>    <p>{{showData ? data : "loading"}}</p>  </div></template><script>export default {  data() {    return {      data: 'This is my data',      showData: true,    };  },};</script>

使用计算属性 computed

可以在 computed 里面进行条件判断,并返回对应的数据。hEX28资讯网——每日最新资讯28at.com

<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 中基于条件展示数据。hEX28资讯网——每日最新资讯28at.com

你可以根据自己的需求来选择使用哪一种方法。hEX28资讯网——每日最新资讯28at.com

v-if指令和v-show的区别在于,v-if会在第一次加载的时候,真正的去除不需要的元素,而v-show只是用CSS来控制元素的显示和隐藏。所以v-if会在第一次加载时对性能有影响,而v-show在第一次加载时不会对性能产生影响。hEX28资讯网——每日最新资讯28at.com

计算属性 computed 可以在数据发生改变时自动更新,性能会比在模板中使用三元运算符和方法好。hEX28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-35317-0.htmlVue3 学习笔记,快速初始化 Vue 项目及 Data 函数用法学习

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 深入探讨React中的useMemo:原理解析与最佳实践

下一篇: 原来New关键字创建对象的背后还隐藏了这么多秘密,看完这篇文章我顿悟了

标签:
  • 热门焦点
  • K60 Pro官方停产 第三方瞬间涨价

    虽然没有官方宣布,但Redmi的一些高管也已经透露了,Redmi K60 Pro已经停产且不会补货,这一切都是为了即将到来的K60 Ultra铺路,属于厂家的正常操作。但有意思的是该机在停产之后
  • 小米官宣:2023年上半年出货量中国第一!

    今日早间,小米电视官方微博带来消息,称2023年小米电视上半年出货量达到了中国第一,同时还表示小米电视的巨屏风暴即将开始。“公布一个好消息2023年#小米电视上半年出货量中国
  • Rust中的高吞吐量流处理

    作者 | Noz编译 | 王瑞平本篇文章主要介绍了Rust中流处理的概念、方法和优化。作者不仅介绍了流处理的基本概念以及Rust中常用的流处理库,还使用这些库实现了一个流处理程序
  • Temu起诉SHEIN,跨境电商战事升级

    来源 | 伯虎财经(bohuFN)作者 | 陈平安日前据外媒报道,拼多多旗下跨境电商平台Temu正对竞争对手SHEIN提起新诉讼,诉状称Shein&ldquo;利用市场支配力量强迫服装厂商与之签订独家
  • 一条抖音4亿人围观 ! 这家MCN比无忧传媒还野

    作者:Hiu 来源:互联网品牌官01 擦边少女空降热搜,幕后推手曝光被网友誉为&ldquo;纯欲天花板&rdquo;的女网红井川里予,近期因为一组哥特风照片登上热搜,引发了一场互联网世界关于
  • OPPO K11样张首曝:千元机影像“卷”得真不错!

    一直以来,OPPO K系列机型都保持着较为均衡的产品体验,历来都是2K价位的明星机型,去年推出的OPPO K10和OPPO K10 Pro两款机型凭借各自的出色配置,堪称有
  • 联想小新Pad Pro 12.6将要推出,搭载高通骁龙 870 处理器

    联想小新Pad Pro 12.6将于秋季新品会上推出,官方按照惯例直接在发布会前给出了机型的所有参数。联想小新 Pad Pro 12.6 将搭载高通骁龙 870 处理器,重量为 5
  • DRAM存储器10月价格下跌,NAND闪存本月价格与上月持平

    10月30日,据韩国媒体消息,自今年年初以来一直在上涨的 DRAM 存储器的交易价格仅在本月就下跌了近 10%,此次是全年首次降价,而NAND 闪存本月价格与上月持平。市
  • AI艺术欣赏体验会在上海梅赛德斯奔驰中心音乐俱乐部上演

    光影交错的镜像世界,虚实幻化的视觉奇观,虚拟偶像与真人共同主持,这些场景都出现在2019世界人工智能大会的舞台上。8月29日至31日,“AI艺术欣赏体验会”在上海
Top