欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue2中實(shí)現(xiàn)dialog的封裝方式

 更新時(shí)間:2024年01月11日 09:19:42   作者:聶大哥  
這篇文章主要介紹了Vue2中實(shí)現(xiàn)dialog的封裝方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

最近在看公司以前的項(xiàng)目時(shí)發(fā)現(xiàn),很多表單內(nèi)容較多的dialog是寫(xiě)在列表組件內(nèi)的。

一個(gè)列表頁(yè)的查詢功能,其已經(jīng)包含了搜索的表單,再加上列表中的其他功能,例如:詳情、刪除、導(dǎo)出、導(dǎo)入、提交等操作都寫(xiě)在這一個(gè)組件了,維護(hù)起來(lái)十分繁瑣。

所以,當(dāng)面對(duì)這種彈窗式的內(nèi)容添加的需求時(shí),要么是跳轉(zhuǎn)路由到新的界面,要么是單獨(dú)封裝一個(gè)dialog組件。

這里借助這個(gè)機(jī)會(huì)展示一下dialog組件的封裝。

組件內(nèi)部只有一個(gè)dialog

dialog的控制可見(jiàn)變量最好寫(xiě)在該組件內(nèi),不要寫(xiě)在父組件通過(guò)傳props的方式來(lái)實(shí)現(xiàn),不然還要在父組件再維護(hù)一個(gè)變量,也是不夠特別優(yōu)雅。

<template>
        <el-dialog 
            title="新增"
            :visible="visibleDia"
            @close="closeDia"
            fullscreen
        >
        
            <!-- 彈窗內(nèi)容自定義 -->

            <div slot="footer">
                <el-button @click="saveInfo" type="primary">保存</el-button>
                <el-button @click="closeDia" type="primary" plain>取消</el-button>
            </div>
        </el-dialog>
</template>
<script>
export default {
    name: 'SaveDialog',
    data() {
        return {
            visibleDia: false,
        }
    },
    methods: {
        openDia() {
            this.visibleDia = true
        },
        closeDia() {
            this.visibleDia = false
        },
        saveInfo() {
        // 告訴父組件,保存成功
			this.$emit('saveSuccess', true)
			this.closeDia()
		}
    }
}
</script>

父組件調(diào)用

父組件調(diào)用彈窗組件時(shí)綁定一個(gè)ref屬性,可通過(guò)$refs調(diào)用此節(jié)點(diǎn)里的openDia方法,即可打開(kāi)彈窗;

關(guān)閉彈窗為彈窗組件內(nèi)的邏輯,等事件處理完進(jìn)行自關(guān)閉即可。

<template>
    <div>


		<!-- 頁(yè)面其他內(nèi)容 -->
		
		<el-button @click="handleAdd">新增</el-button>
		
		<save-dialog
			ref="saveDialog"
			@saveSuccess="saveSuccess"
		 />
    </div>    
</template>
<script>
import SaveDialog from './SaveDialog.vue'
export default {
    name: 'Index',
    components: { SaveDialog },
    methods: {
        handleAdd() {
            this.$refs.saveDialog.openDia()
        },
        saveSuccess() {
        	// 此方法被調(diào)用時(shí),說(shuō)明彈窗的新增內(nèi)容已完成
		}
    }
}
</script>

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論