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
        },
}
相关推荐
小白小白从不日白1 分钟前
react 组件通讯
前端·react.js
罗_三金12 分钟前
前端框架对比和选择?
javascript·前端框架·vue·react·angular
Redstone Monstrosity19 分钟前
字节二面
前端·面试
东方翱翔26 分钟前
CSS的三种基本选择器
前端·css
Fan_web1 小时前
JavaScript高级——闭包应用-自定义js模块
开发语言·前端·javascript·css·html
yanglamei19621 小时前
基于GIKT深度知识追踪模型的习题推荐系统源代码+数据库+使用说明,后端采用flask,前端采用vue
前端·数据库·flask
千穹凌帝1 小时前
SpinalHDL之结构(二)
开发语言·前端·fpga开发
冯宝宝^1 小时前
基于mongodb+flask(Python)+vue的实验室器材管理系统
vue.js·python·flask
dot.Net安全矩阵1 小时前
.NET内网实战:通过命令行解密Web.config
前端·学习·安全·web安全·矩阵·.net
叫我:松哥1 小时前
基于Python flask的医院管理学院,医生能够增加/删除/修改/删除病人的数据信息,有可视化分析
javascript·后端·python·mysql·信息可视化·flask·bootstrap