关于onMounted和onUpdated的触发

一、在项目中,使用父组件页面+子组件(el-Dialog)弹窗的结构

如果在子组件dialog中使用onMounted,那么这个onMounted在父组件加载的时候就会触发(尽管这个时候弹窗没打开)

解决方法:对子组件使用v-if,一开始v-if=false,打开子组件的时候,才把v-if变成true

javascript 复制代码
//父组件代码

<cloudDiskDialog v-if="visibleCloudDisk" :dialogData="dialogData"></cloudDiskDialog>
// 定义传递给弹框的数据
const dialogData = reactive({
  visible: false,
  ......
})

const visibleCloudDisk = ref(false) //v-if绑定的值

//打开子组件弹窗
function viewCloudDisk() {
  //弹窗visible为true
  dialogData.visible = true
  //v-if绑定的值也为true
  visibleCloudDisk.value = true
}
javascript 复制代码
//子组件代码   
 <el-dialog
      class="confirmDialog"
      //控制弹窗打开关闭
      v-model="props.dialogData.visible"
      :title="'云硬盘详情'"
      :destroy-on-close="true"
      :close-on-click-modal="false"
      @close="closeDialog"
    >
  ......
  </el-dialog>

二、(子组件)OnUpdate触发机制

1、(子组件)响应式值用在了页面上,且该值在改变

点击测试按钮,OnUpdated会一直触发

javascript 复制代码
<template>
  <div class="confirmDialog-wrapper">
  //值必须写在el-dialog标签的外面,因为el-dialog有插槽,插槽会影响onUpdated触发
    {{ testValue }}
    <!-- 画质选择弹窗 -->
    <el-dialog
      class="confirmDialog"
      v-model="visible"
      title="画质选择"
      :destroy-on-close="true"
      :close-on-click-modal="false"
      :show-close="true"
    >
      <span class="title">分辨率</span>
      <button @click="testing">测试</button>
      //省略弹窗代码
    </el-dialog>
  </div>
</template>

<script lang="ts" setup>
import {onUpdated } from 'vue'

let testValue = ref('')
//测试按钮的回调
function testing() {
  testValue.value = Math.random()
}

onUpdated(() => {
  console.log('onUpadate')
})
</script>

二、父组件传递给子组件的响应式值改变了(尽管子组件没有使用defineProps接受该值)

javascript 复制代码
//父组件代码
<div>
  <button @click="test">测试</button>
  <selectImgQualityDialog
    :flag="flag"
  ></selectImgQualityDialog>
</div>

//传递给子组件的值
const flag = ref(true)
//测试按钮的回调
function test() {
  flag.value = !flag.value
}

按父组件的测试按钮,此时在子组件selectImgQualityDialog里,onUpdated在一直执行

相关推荐
Jammingpro4 小时前
【Vue专题】前端JS基础Part1(含模版字符串、解构赋值、变量常量与对象)
前端·javascript·vue.js
jiangzhihao05157 小时前
前端自动翻译插件webpack-auto-i18n-plugin的使用
前端·webpack·node.js
软件技术NINI10 小时前
html css网页制作成品——HTML+CSS盐津铺子网页设计(5页)附源码
前端·css·html
mapbar_front11 小时前
面试问题—我的问题问完了,你还有什么想问我的吗?
前端·面试
quweiie11 小时前
thinkphp8+layui多图上传,带删除\排序功能
前端·javascript·layui
李鸿耀11 小时前
React 项目 SVG 图标太难管?用这套自动化方案一键搞定!
前端
闲蛋小超人笑嘻嘻11 小时前
树形结构渲染 + 选择(Vue3 + ElementPlus)
前端·javascript·vue.js
叶梅树12 小时前
从零构建A股量化交易工具:基于Qlib的全栈系统指南
前端·后端·算法
巴博尔12 小时前
uniapp的IOS中首次进入,无网络问题
前端·javascript·ios·uni-app
焚 城12 小时前
UniApp 实现双语功能
javascript·vue.js·uni-app