0


关于onMounted和onUpdated的触发

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

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

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

  1. //父组件代码
  2. <cloudDiskDialog v-if="visibleCloudDisk" :dialogData="dialogData"></cloudDiskDialog>
  3. // 定义传递给弹框的数据
  4. const dialogData = reactive({
  5. visible: false,
  6. ......
  7. })
  8. const visibleCloudDisk = ref(false) //v-if绑定的值
  9. //打开子组件弹窗
  10. function viewCloudDisk() {
  11. //弹窗visible为true
  12. dialogData.visible = true
  13. //v-if绑定的值也为true
  14. visibleCloudDisk.value = true
  15. }
  1. //子组件代码
  2. <el-dialog
  3. class="confirmDialog"
  4. //控制弹窗打开关闭
  5. v-model="props.dialogData.visible"
  6. :title="'云硬盘详情'"
  7. :destroy-on-close="true"
  8. :close-on-click-modal="false"
  9. @close="closeDialog"
  10. >
  11. ......
  12. </el-dialog>

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

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

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

  1. <template>
  2. <div class="confirmDialog-wrapper">
  3. //值必须写在el-dialog标签的外面,因为el-dialog有插槽,插槽会影响onUpdated触发
  4. {{ testValue }}
  5. <!-- 画质选择弹窗 -->
  6. <el-dialog
  7. class="confirmDialog"
  8. v-model="visible"
  9. title="画质选择"
  10. :destroy-on-close="true"
  11. :close-on-click-modal="false"
  12. :show-close="true"
  13. >
  14. <span class="title">分辨率</span>
  15. <button @click="testing">测试</button>
  16. //省略弹窗代码
  17. </el-dialog>
  18. </div>
  19. </template>
  20. <script lang="ts" setup>
  21. import {onUpdated } from 'vue'
  22. let testValue = ref('')
  23. //测试按钮的回调
  24. function testing() {
  25. testValue.value = Math.random()
  26. }
  27. onUpdated(() => {
  28. console.log('onUpadate')
  29. })
  30. </script>

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

  1. //父组件代码
  2. <div>
  3. <button @click="test">测试</button>
  4. <selectImgQualityDialog
  5. :flag="flag"
  6. ></selectImgQualityDialog>
  7. </div>
  8. //传递给子组件的值
  9. const flag = ref(true)
  10. //测试按钮的回调
  11. function test() {
  12. flag.value = !flag.value
  13. }

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


本文转载自: https://blog.csdn.net/zmy967131/article/details/142960400
版权归原作者 前端小怪兽zmy 所有, 如有侵权,请联系我们删除。

“关于onMounted和onUpdated的触发”的评论:

还没有评论