您好,欢迎访问一九零五行业门户网

实例详解vue基于element-plus的组件二次封装

本篇文章给大家带来了关于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 class="base-input flex align-center">    <div v-if="props.blockname">{{ props.blockname }}</div>    <el-input placeholder="请输入" v-model="chanvalue"></el-input>  </div></template><script setup>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 class="base-select flex align-center">    <div>{{ props.blockname }}</div>    <el-select v-model="chanvalue" :multiple="props.multiple" :filterable="props.filterable" :allow-create="props.allowcreate" :placeholder="placeholder" >      <el-option v-for="item in props.options" :key="item.value" :value="item.value" :label="item.label" />    </el-select>  </div></template><script setup>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 blockname="传入的label名称" v-model:value="双向绑定的数据" /><baseselect blockname="传入的label名称" :options="选择器的选项值" v-model:value="双向绑定的数据" />
说明利用computed的set,get方法,你可以进行父子组件的双向绑定,再也不用担心,子组件无法修改父组件的props而烦恼,其他的element的组件,大致实现思路都是如此。
基础的dialog弹框
el-dialog子组件的封装 basedialog.vue<template>  <div>    <el-dialog v-model="getshow" width="65%" :before-close="handlercancer">      <div>{{props.title}}</div>      <slot/>      <template #footer>        <span>          <button @click="handlercancer">取消</button>          <button @click="handlersubmit">确定</button>        </span>      </template>    </el-dialog>  </div></template><script setup>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 title="传入的标题名称" v-model:isshow="isshow">   <div>对应的插槽内容</div></basedialog>
注意事项v-model双向绑定默认的props名称为value,像dialog这种绑定的是isshow,需要在v-model后面声明双向绑定的props参数名称v-model:isshow,像input,select这种输入框绑定默认为value,所以可以忽略不写。若你绑定其他值(即除了value以外的其他参数值),则需要v-model:isshow声明
【相关推荐:javascript视频教程、vue.js教程】
以上就是实例详解vue基于element-plus的组件二次封装的详细内容。
其它类似信息

推荐信息