vue3.2 基础及常用方法

news2025/1/24 1:36:52

Vue3.2(21年8月10日)相比于Vue3新增了语法糖,减少了代码冗余

Vue3相比于Vue2,在虚拟DOM,编译, 数据代理,打包构建封面进行了优化

Vue3使用组合式API, 适合大型项目, 去除了this

vue2的 beforeCreatecreated 被新增的setup生命周期替代

vue3 使用插件: volar
配置用户代码片段可以快速输入vue3 模板
在这里插入图片描述

1. css支持v-bind 指令:

<template>
  <div class="box">{{color}}</div>
</template>

<script setup>
  import {ref} from 'vue'
  let color = ref('red')
</script>

<style scoped>
.box {
  width: 100px;
  height: 50px;
  background-color: v-bind(color);
}
</style>

2. setup语法糖

vue3.0的变量需要return出来才可以在template中使用, 写法冗余

vue3.2 在script标签中添加setup解决问题
组件只需要引入,不需要注册,属性方法不需要返回,不需要写setup函数,不需要写export default

3. data定义

3.1 直接定义无响应式

let name = ‘zhangsan’

3.2 ref定义基本数据类型

在script标签内,需要用 name.value 修改和获取值

可以接受基本类型、也可以是复杂类型(比如对象,数组)。建议处理基本类型数据。

基本类型的数据:响应式依然是靠Object.defineProperty()的get与set完成的。

<template>
  <div>{{name}}</div>
  <button @click="setName">set</button>
</template>

<script setup>
  import {ref} from 'vue'
  let name = ref('zhangsan')
  const setName = () => {
    name.value = 'lisi'
  }

</script>
<style scoped>
</style>

3.3 reactive 定义引用数据类型

reactive支持引用类型, 直接 变量.属性 使用和修改

<template>
  <div>{{user.name}}</div>
  <div>{{user.money}}</div>
  <button @click="setItem">set</button>
</template>

<script setup>
  import {reactive} from 'vue'
  let user = reactive({
    name: 'zhangsan',
    money: 1000
  })
  const setItem = () => {
    user.money = 1500
    user.gupiao = 100
  }

</script>
<style scoped>
</style>

4. methods方法定义

在template中 :

<button @click='addMoney'>加钱</button>

在script中:

const money = ref(1000)
const addMoney = () => {
  money.value ++
}

5. computed计算属性

获得一个新的属性

<template>
  <div>{{nameString}}</div>
  <div>{{user.money}}</div>
  <button @click="setItem">set</button>
</template>

<script setup>
  import {reactive, computed} from 'vue'
  let user = reactive({
    name: 'zhangsan',
    money: 1000
  })
  const nameString = computed(() => {
    return '我的名字是' + user.name
  })

</script>
<style scoped>
</style>

6 watch使用:

监听响应式数据的变化

watch(数据源, 执行函数, [配置参数])
// 配置的参数:立即执行, 深度监听
{immediate: true, deep: true}

6.1 监听基本数据类型 单一数据源

<script setup>
import {ref, watch} from 'vue'
 let name = ref('zhnagsan')
 //直接监听属性
watch(name,(newVal,oldVal)=>{
    console.log('变量发生了改变...',newVal, oldVal);
})

6.2 监听引用数据类型 单一数据源

<template>
  <div>{{user.name}}</div>
  <div>{{user.money}}</div>
  <button @click="setItem">set</button>
</template>

<script setup>
  import {reactive, watch} from 'vue'
  let user = reactive({
    name: 'zhangsan',
    money: 1000
  })
  // 监听方法返回的属性
  watch(() => user.money, (newVal, oldVal) => {
    console.log('user money 变了: ', newVal, oldVal)
  })
  const setItem = () => {
    user.money = 1500
  }
</script>

6.2 监听引用数据类型 多数据源[深度监听]

<template>
  <div>{{user.name}}</div>
  <div>{{user.money}}</div>
  <div>{{user.hobby.study}}</div>
  <button @click="setItem">set</button>
</template>

<script setup>
  import {reactive, watch} from 'vue'
  let user = reactive({
    name: 'zhangsan',
    money: 1000,
    hobby: {
      study: '语文'
    }
  })
  // 深度监听 {deep:true}
  watch(() => user.hobby.study, (newVal, oldVal) => {
    console.log('user money 变了: ', newVal, oldVal)
  }, {deep:true})

  const setItem = () => {
    user.hobby.study = '数学'
  }
</script>

7. 生命周期

在这里插入图片描述

import { onMounted } from 'vue'
onMounted(() => {
  console.log(document.querySelector('.box')) // 可以获取DOM
})

7.1 ref获取元素


<template>
  <div ref="box">
    <button>Hehe</button>
  </div>
</template>
 
<script setup>
  import { ref, onMounted } from "vue";
  const box = ref(null);
  onMounted(() => {
    console.log(box.value);
  });

8 组件使用

  • 创建 components/Son.vue
  • 在App.vue 中导入子组件
  • Vue3.2 在导入子组件时,自动注册该组件
  • 组件名格式: 大驼峰写法

子组件Son.vue

<template>
  <div>Son compoment</div>
</template>

<script setup>
</script>

父组件


<template>
  <Son/>
</template>

<script setup>
import Son from './components/Son.vue'
</script>


全局组件:
main.js

 app.component('ComponentB', ComponentB)
<ComponentA/>

9.组件通信

9.1 父传子 defineProps

子组件Son.vue

<template>
  <div>Son compoment</div>
  <div>{{name}}</div>
  <div>{{like}}</div>
</template>

<script setup>
const props = defineProps({
  name: {
    type: String,
    default: ""
  },
  like: {
    type: Array,
    default: () => []
  }
})
</script>

父组件


<template>
  <Son name="小灰灰" :like="like"/>
</template>

<script setup>
import Son from './components/Son.vue'
let like = ["红太狼", "灰太狼"]
</script>

9.2 子传父 defineEmits

子组件

<template>
  <button @click="sendData">传递数据</button>
</template>

<script setup>
// 自定义事件
const emit = defineEmits(['send'])
// 事件执行函数
const sendData = () => {
  emit('send', '子组件的数据')
}
</script>

父组件


<template>
  <Son @send="getData"/>
</template>

<script setup>
import Son from './components/Son.vue'

const getData = (data) => {
  console.log('父组件获取到: ', data)
}
</script>

  1. 条件渲染
<template>
  <div v-if="type === 'A'">
    A
  </div>
  <div v-else-if="type === 'B'">
    B
  </div>
  <div v-else>
    Not A/B
  </div>
</template>

<script setup>
let type = 'B'
</script>

  1. 列表渲染
<template>
  <li v-for="item in items">
    {{ item.message }}
  </li>
</template>

<script setup>
import {ref} from 'vue'
let items = ref([
  {message: 'm1'},
  {message: 'm2'},
  {message: 'm3'}
])

setTimeout(() => {
  items.value.push({message: 'm4'})},
  2000)
</script>

  1. 事件处理
<button @click="say">Say bye</button>
// 传递参数
<button @click="say('bye')">Say bye</button>

事件修饰符:

.stop .prevent .self .capture .once .passive

<!-- 单击事件将停止传递 -->
<a @click.stop="doThis"></a>
  1. 表单输入绑定(用于、、)
<input v-model="text">

<input type="radio" v-model="pick" :value="first" />
<input type="radio" v-model="pick" :value="second" />
  1. 插槽slot
    实现 可以用在不同的地方渲染各异的内容,但同时还保证都具有相同的样式。

使用

<FancyButton>
  Click me! <!-- 插槽内容 -->
</FancyButton>

组件:

<button class="fancy-btn">
  <slot></slot> <!-- 插槽出口 -->
</button>

元素是插槽, 父元素插槽内容将在slot处渲染
渲染之后的DOM:

<button class="fancy-btn">Click me!</button>

另一中js的方式理解:将内容传递给子元素, 子元素包裹时候生成DOM,返回给父元素

// 父元素传入插槽内容
FancyButton('Click me!')

// FancyButton 在自己的模板中渲染插槽内容
function FancyButton(slotContent) {
  return `<button class="fancy-btn">
      ${slotContent}
    </button>`
}

子组件

<template>
  <li v-for="item in items">
    <slot></slot>
  </li>

  <button class="fancy-btn">
    <slot></slot> <!-- 插槽出口 -->
  </button>
</template>

<script setup>
import {ref} from 'vue'
let items = ref([
  {message: 'm1'},
  {message: 'm2'},
  {message: 'm3'}
])

</script>

父组件

  <Son>
    ABC
  </Son>
  1. Teleport: 组件传送到DOM节点
    <Teleport> 是一个内置组件,它可以将一个组件内部的一部分模板“传送”到父组件的外的其他 DOM 结构外层的位置去。

如下传送到了body元素上


<template>
  <div>
    <button @click="open = true">Open Modal</button>

    <Teleport to="body">
      <div v-if="open" class="modal">
        <p>Hello from the modal!</p>
        <button @click="open = false">Close</button>
      </div>
    </Teleport>
  </div>
</template>

<script setup>
import { ref } from 'vue'
const open = ref(false)

</script>
<style scoped>
.modal {
  position: fixed;
  z-index: 999;
  top: 20%;
  left: 50%;
  width: 300px;
  margin-left: -150px;
  border: 2px red solid;
}
</style>

// 传送到id为teleport-target的DOM元素上:

  <Teleport to="#teleport-target"> </Teleport>

  1. 模板引用
    通过ref获取DOM元素
<template>
  <div ref="divRef">divRef</div>
</template>

<script>
  import { onMounted, ref } from 'vue'
  const divRef = ref(null)
  onMounted(() => { // 挂载后才可以获取DOM元素
    console.log('[long] divRef: ', divRef.value)
  })
</script>
  1. 条件渲染
    17.1 条件渲染 v-if
<div v-if="type==='A'">A</div>
<div v-else-if="type==='B'">B</div>
<div v-else>C</div>

多元素条件渲染:使用<template>包装器元素

<template v-if="ok">
  <p>P1</p>
  <p>P2</p>
</template>

17.2 条件渲染 v-show
v-if 不保留DOM元素,切换开销更高
v-show 保留DOM元素,设置display属性,不支持template包装器元素,初始渲染开销高

17.3 不推荐使用v-ifv-for同时使用, 同时使用时v-if首先执行

  1. 列表渲染v-for
const items = ref([{ message: 'F1' },{ message: 'F2' }])

<li v-for="(item, index ) in items">
 {{ item.message }} - {{ index }}
</li>

item 是迭代项别名

使用template渲染多个元素

<ul>
  <template v-for="item in items">
    <li>{{ item.msg }}</li>
    <li class="divider" role="presentation"></li>
  </template>
</ul>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/408023.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

js中常遇到 切割截取字符串的几种方法

切割截取字符串的几种方法 1、 split() 方法用于把一个 字符串 分割成 字符串数组 &#xff1b; stringObject.split(str,length)var str "123,456,789"; console.log(str.split()); // ["1", "2", "3", ",", "4&qu…

【PC端聊天功能模板】vue-elementul简单实现电脑端客服聊天功能,pc端聊天系统静态页面布局,配套websocket方案和心跳重连机制【详细注释,拿来即用】

前言 这里是给大家写了一个简单的模板来使用&#xff0c;可以直接复制了调调就能用。因为这个聊天也是很容易出现的功能&#xff0c;所以我写一个模板静态页面放在这&#xff0c;以后需要这个功能的时候可以不用布局了&#xff0c;直接复制改改。 我的代码里面有详细的注释&…

小马带你认识前端开发神器WebStorm(WebStorm及Git的相关配置与使用)

先说一下个人感觉吧&#xff0c;小马之前也是一直在用 Visual Studio Code 来进行开发&#xff0c;但随着开发需求增加&#xff0c;VS 所需要的插件越来越多&#xff08;用过 vs code 的同学都知道&#xff0c;它虽可以进行各种开发语言的编写&#xff0c;但是需要相应的插件支…

ECharts设置x轴刻度间隔的两种方法

ECharts设置x轴刻度文字间隔的两种方法 背景 最近在写一个echarts数据看板&#xff0c;要在一个页面中展示多张图表&#xff0c;所以留给每张图表的尺寸就很小。这也就使得图表x轴的刻度文字全部挤到一起了&#xff0c;废话不多说&#xff0c;直接上图看效果。 右边的图标就…

11.定时任务定时线程池详解

3.1 新增定时任务池 11.定时任务&定时线程池详解 ​ 当我们不用任务框架时&#xff0c;我们想自己写一个定时任务时&#xff0c;我们能想起那个工具类呢&#xff1f;Timer &#xff1f;还有吗&#xff1f;不知道了&#xff0c;下面我们要讲下ScheduledThreadPoolExecutor…

Vue图片路径问题(动态引入:绝对路径、相对路径),require动态路径问题

Vue图片路径问题&#xff08;动/静态引入&#xff1a;绝对路径、相对路径&#xff09; DEMO实例&#xff08;可快速解决问题&#xff09;: 注意&#xff1a;绝对路径方式导入的图片需要存储在 publiic 文件夹下 静态导入相对路径&#xff1a; <img src"../../asset…

Mybatis+Servlet+Mysql 整合的一个小项目:对初学者非常友好,有助于初学者很快的上手Java Web

文章目录前言为何要写&#xff1f;目录结构1 依赖配置1.1 创建一个web项目1.2 依赖需求分析1.3 pom.xml2 配置Mybatis2.1 mybatis-config.xml2.2 UserMapper.xml2.3 UserMapper.interface3 配置Tomcat4 Servlet类4.1 loginServlet014.2 registerRequest015 静态页面代码5.1 Htm…

Vue开发实例(13)之axios和mockjs的安装与使用

作者简介 作者名&#xff1a;编程界明世隐 简介&#xff1a;CSDN博客专家&#xff0c;从事软件开发多年&#xff0c;精通Java、JavaScript&#xff0c;博主也是从零开始一步步把学习成长、深知学习和积累的重要性&#xff0c;喜欢跟广大ADC一起打野升级&#xff0c;欢迎您关注&…

Vue3中 内置组件 Teleport 详解

1. 基本概念 1.1 简单理解 不管是 Vue2 还是 Vue3 中都有内置组件的存在&#xff0c;如 component 内置组件、transition 内置组件等等。内置组件就是官方给我们封装的全局组件&#xff0c;我们直接拿来用就可以了。 在 Vue3 中新增了 Teleport 内置组件&#xff0c;先来看下…

【JavaScript-数组全家福】

目录 前言 数组 1.创建 new Array数组 2.检测是否为数组 1.使用instanceof检测是否为数组 2.使用Array.isArray()来检测 3.添加删除数组方法 4.筛选数组 5.数组排序 6.数组索引方法 7.数组去重 8.数组转字符串 写在最后 前言 博主是&#x1f466;一个帅气的boy&#…

前端案例:飞机大战( js+dom 操作,代码完整,附图片素材)

目录 一、案例效果 二、实现思路 三、完整代码详细注释 四、涉及要点 五、案例素材 一、案例效果 二、实现思路 创建游戏背景板&#xff1b;创建我方战机&#xff0c;鼠标进入游戏面板后其随鼠标轨迹运动&#xff1b; onmousemove创建子弹&#xff0c;让子弹周期性的在战…

Grafana alert预警+钉钉通知

1 Grafana alert预警 如下图所示&#xff0c;主要是前3步&#xff0c;设置alert rules、contact points 、notification policies。alert rules主要设置触发警告的规则&#xff1b;contact points设置通过什么发送预警&#xff0c;如钉钉&#xff1b;notification policies 将…

鼠标事件、键盘事件,你听过嘛?

&#x1f4dc;个人简介 ⭐️个人主页&#xff1a;微风洋洋&#x1f64b;‍♂️ &#x1f351;博客领域&#xff1a;编程基础,后端 &#x1f345;写作风格&#xff1a;干货,干货,还是tmd的干货 &#x1f338;精选专栏&#xff1a;【JavaScript】 &#x1f680;支持洋锅&#xff…

Chrome-谷歌浏览器多开教程

Chrome谷歌浏览器多开教程在我们的日常生活中&#xff0c;我们常常在某一时刻需要在进行多个账号的查看&#xff0c;例如在跨境电商时&#xff0c;我们常常需要开多各店铺页面&#xff0c;又或者&#xff0c;我们在玩游戏时&#xff0c;需要开多个账号同时进行运作&#xff0c;…

一文通透从输入URL到页面渲染的全过程----高频面试

一文通透从输入URL到页面渲染的全过程----高频面试 喜欢大海 喜欢夕阳 写下便是永恒 文章目录一文通透从输入URL到页面渲染的全过程----高频面试重温进程与线程什么是进程什么是线程进程和线程的区别多进程和多线程JS为什么是单线程浏览器相关浏览器是多进程的浏览器包含哪些进…

jeecg-boot首页加载速度优化全过程

优化结果 前端和后端部署在轻量服务器: 以下结果都是三次强刷得到的 优化前: 优化后: 优化方案 开启Nginx压缩 方案来自于:jeecg官方文档 作用:通过nginx内置的压缩策略来压缩静态资源&#xff0c;提升资源请求速度 在nginx.conf 的 http 中加入以下片断: # gzip …

【微信小程序 | 实战开发】常用的视图容器类组件介绍和使用(1)

个人名片: 🐼作者简介:一名大二在校生,喜欢编程🎋 🐻‍❄️个人主页🥇:小新爱学习. 🐼个人WeChat:hmmwx53 🕊️系列专栏:🖼️ 零基础学Java——小白入门必备重识C语言——复习回顾

component lists rendered with v-for should have explicit keys

component lists rendered with v-for should have explicit keys 发现问题 关键报错 (Emitted value instead of an instance of Error) : component lists rendered with v-for should have explicit keys. See https://vuejs.org/guide/list.html#key for more info. 具体…

VUE之Element-ui文件上传详解

引言 对于文件上传&#xff0c;在开发主要涉及到以下两个方面&#xff1a; 单个文件上传和表单一起实现上传&#xff08;这种情况一般都是文件上传之后&#xff0c;后端返回保存在服务器的文件名&#xff0c;最后和我们的表单一起上传&#xff09; 单文件上传 element-ui中…

Cesium加载离线地图和离线地形

文章目录 前言一、Cesium加载离线地图 1.1 下载数据2.2 数据处理2.3 地图发布2.4下载速度改进 二、Cesium加载离线地形 2.1 下载数据2.2 数据处理2.3 地形发布2.4 遇到的问题 前言 直接把地图数据切片&#xff0c;然后通过nginx以静态服务方式发布。 使用工具&#xff1a;…