本篇文章為大家帶來了關於vue的相關知識,其中主要介紹了關於vue3基於element-plus的組件二次封裝資料雙向綁定的相關內容,在實際開發中,經常需要基於element-plus封裝一些自己的客製化元件,方便快速建立我們目前的業務,下面一起來看一下,希望對大家有幫助。
【相關推薦:javascript影片教學、vue.js教學】
基於element-plus的二次封裝資料雙向綁定
在實際開發中,經常需要基於element-plus封裝一些自己的客製化元件,方便快速建立我們目前的業務。在vue2.0中父子元件資料的雙向綁定通常都是透過在props中傳值:value.sync,在子元件中使用,this.$emit(“update:value”, value)的方式,那麼我們怎麼在vue3中實作類似的父子元件的雙向綁定呢?
在vue2中,資料的回應式是基於Object.defineProperty物件進行資料的雙向綁定,這種劫持 發布訂閱的模式並不能很好的偵測物件、陣列等複雜類型的資料。在vue3的資料的響應式是基於proxy的set、get方法,相對於Object.defineProperty的劫持,proxy代理的方式更為優雅。
具體實作想法如下:
表單的label和對應的選擇器、輸入框
##效果預覽
el-input子元件的封裝baseInput.vue<template>
<div>
<div>{{ props.blockName }}</div>
<el-input></el-input>
</div>
</template>
<script>
import { computed } from 'vue'
const props = defineProps({
blockName: {
type: String,
default: ''
},
value: {
type: String,
default: ''
}
})
const emits = defineEmits(['update:value'])
// 通过重写计算属性的set和get方法,将计算属性的结果绑定在输入框的model中
const chanValue = computed({
get: () => props.value,
set: (val) => {
emits('update:value', val)
}
})
</script>
el-select子元件的封裝baseSelect.vue<template>
<div>
<div>{{ props.blockName }}</div>
<el-select>
<el-option></el-option>
</el-select>
</div>
</template>
<script>
import { computed } from 'vue'
const props = defineProps({
blockName: {
type: String,
default: ''
},
value: {
type: String,
default: ''
},
placeholder: {
type: String,
default: '请选择'
},
options: {
type: Array,
default() {
return [{ value: '', label: '' }]
}
},
// 一下三个属性配合多选使用
multiple: {
type: Boolean,
default: false
},
filterable: {
type: Boolean,
default: false
},
allowCreate: {
type: Boolean,
default: false
}
})
const chanValue = computed({
get: () => props.value,
set: (val) => {
emits('update:value', val)
}
})
const emits = defineEmits(['update:value'])
</script>
其他元件的呼叫<baseinput></baseinput>
<baseselect></baseselect>
#說明
利用computed的set,get方法,你可以進行父子元件的雙向綁定,再也不用擔心,子元件無法修改父元件的props而煩惱,其他的element的元件,大致實現思路都是如此。 基礎的dialog彈框el-dialog子元件的封裝baseDialog.vue<template>
<div>
<el-dialog>
<div>{{props.title}}</div>
<slot></slot>
<template>
<span>
<button>取消</button>
<button>确定</button>
</span>
</template>
</el-dialog>
</div>
</template>
<script>
import { computed } from 'vue'
const props = defineProps({
title: {
type: String,
default:''
},
isShow: {
type: Boolean,
default: false
}
})
const emits = defineEmits(['update:isShow'])
const handlerCancer = () => {
emits('update:isShow', false)
}
const handlerSubmit = () => {
// dialog 点击确定按钮之前处理相关业务逻辑
emits('update:isShow', false)
}
const getShow = computed({
get: () => props.isShow,
set: (val) => {
emits('update:isShow', val)
}
})
</script>
其他元件的呼叫<basedialog>
<div>对应的插槽内容</div>
</basedialog>
注意事項v-model雙向綁定預設的props名稱為value,像dialog這種綁定的是isShow,需要在v-model後面宣告雙向綁定定的props參數名稱v-model:isShow,像input,select這種輸入框綁定預設為value,所以可以忽略不寫。若你綁定其他值(即除了value以外的其他參數值),則需要v-model:isShow宣告【相關推薦:以上是實例詳解vue基於element-plus的組件二次封裝的詳細內容。更多資訊請關注PHP中文網其他相關文章!

vue中props可以传递函数;vue中可以将字符串、数组、数字和对象作为props传递,props主要用于组件的传值,目的为了接收外面传过来的数据,语法为“export default {methods: {myFunction() {// ...}}};”。

如何覆盖组件库样式?下面本篇文章给大家介绍一下React和Vue项目中优雅地覆盖组件库样式的方法,希望对大家有所帮助!

本篇文章带大家聊聊vue指令中的修饰符,对比一下vue中的指令修饰符和dom事件中的event对象,介绍一下常用的事件修饰符,希望对大家有所帮助!

react与vue的虚拟dom没有区别;react和vue的虚拟dom都是用js对象来模拟真实DOM,用虚拟DOM的diff来最小化更新真实DOM,可以减小不必要的性能损耗,按颗粒度分为不同的类型比较同层级dom节点,进行增、删、移的操作。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

禪工作室 13.0.1
強大的PHP整合開發環境

SublimeText3漢化版
中文版,非常好用

SublimeText3 Linux新版
SublimeText3 Linux最新版

記事本++7.3.1
好用且免費的程式碼編輯器

Dreamweaver CS6
視覺化網頁開發工具