this.$emit(‘update:isVisible‘, false)作用

这个写是不是很新颖,传父组件传值!这是什么鬼。。。

假设你有以下逻辑业务。在A页面弹出一个组件B,A组件里面使用B组件,是否展示B组件你使用的是baselineShow变量控制!

javascript 复制代码
<BaselineData :isVisible.sync="baselineShow" @addNewCrfAction="addNewCrfAction"/>

而B组件里面是你封装的el-dialog!如下,B组件内的代码为:

javascript 复制代码
<template>
    <el-dialog title="选择CRF" :visible.sync="isVisible" width="850px"
        append-to-body
        :close-on-click-modal="closeOnClickModal"
        :show-close="showClose"
        :before-close="handleClose">

        <div class="mt-20 flex wrap main-box" v-loading="apiLoading">
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
        </div>
        <span slot="footer" class="dialog-footer">
            <el-link type="primary" class="mr-15" @click="checkedClear">清空</el-link>
            <el-button type="primary" @click="submit">确定</el-button>
            <el-button type="plain" @click="cancel">取消</el-button>
        </span>
    </el-dialog>
</template>

<script>
import crudCrfs from '@/api/crf/template'
export default {
    props: {
        isVisible: {
            type: Boolean,
            default:false
        },
        closeOnClickModal: {
            type: Boolean,
            default:true
        },
        showClose: {
            type: Boolean,
            default:true
        },
        showAddOption: {
            type: Boolean,
            default:true
        },
    },
    data() {
        return {
            list: [],
            apiLoading:true
        }
    },
    created(){
        crudCrfs.getAllCrfs().then(res=>{
            res.forEach(e=>{
                e.selected = false
                e.subTitle = '包含' + e.groupCount + '个题组,' + e.componentCount + '字段'
                this.list.addObject(e)
            })
            this.apiLoading = false
        })
    },
    methods: {
        handleClose() {
            this.$emit('update:isVisible', false);
        },
        checkedItems(i, num) {
            i.selected = !i.selected
        },
        checkedClear() {
            this.list.filter(e=>e.selected).forEach(element => {
                element.selected = false
            });
        },
        submit() {
            let activeList = []
            this.list.filter(e=>e.selected).forEach((element,index) => {
                // activeList.addObject(index)
                activeList.addObject(element)
            });
            this.$emit('baselineSubmit', activeList)
            this.$emit('update:isVisible', false);
            this.dataBlock.callLogicDataBlock("addedBaselineSuccess", { "state": 'success' })
        },
        addNewCrfAction(){
            this.$emit('update:isVisible', false);
            this.$emit('addNewCrfAction',{})
        },
        cancel(){
            this.$emit('update:isVisible', false);
            this.$emit('cancelAction',{})
        }
    }
}
</script>

<style>
    .addCrf {
        height: 60px;
        width: 200px;
        line-height: 60px;

        border: 1px dashed lightgray;

        background-color: rgb(245, 245, 245);
    }
    .items-w {
        width: 244px;
    }
    .main-box {
        max-height: 300px;
        overflow-y: auto;
    }
    .items-check {
        right: 10px;
        top: 25px;
    }
</style>

在A页面弹出B组件:

此时当你在B组件内部关闭弹窗时,你就不得不在A组件里面同步更新A组件里面的变量baselineShow!否则下次无法弹出此页面。那如何在B组件内部同步修改A组件内的值呢?

核心代码:告诉B组件哪个变量要进行同步修改,进行如下标记;

:isVisible.sync="baselineShow"

切换A里面使用的时候不能这样使用: v-if="baselineShow",如果这样使用则达不到预期的效果!!

javascript 复制代码
<BaselineData v-if="baselineShow" :isVisible.sync="baselineShow" @addNewCrfAction="addNewCrfAction"/>

在B组件内部关闭弹窗时调用:则不必再去手动维护A组件内部的变量baselineShow!

this.$emit('update:isVisible', false);

同样B组件内部的props定义也要注意!

javascript 复制代码
props: {
        isVisible: {
            type: Boolean,
            default:false
        },
}
相关推荐
hackeroink32 分钟前
【2024版】最新推荐好用的XSS漏洞扫描利用工具_xss扫描工具
前端·xss
迷雾漫步者2 小时前
Flutter组件————FloatingActionButton
前端·flutter·dart
向前看-3 小时前
验证码机制
前端·后端
燃先生._.4 小时前
Day-03 Vue(生命周期、生命周期钩子八个函数、工程化开发和脚手架、组件化开发、根组件、局部注册和全局注册的步骤)
前端·javascript·vue.js
高山我梦口香糖5 小时前
[react]searchParams转普通对象
开发语言·前端·javascript
m0_748235245 小时前
前端实现获取后端返回的文件流并下载
前端·状态模式
m0_748240255 小时前
前端如何检测用户登录状态是否过期
前端
black^sugar5 小时前
纯前端实现更新检测
开发语言·前端·javascript
寻找沙漠的人6 小时前
前端知识补充—CSS
前端·css