element抽屉的再次封装

平时用element比较多,里边的有个抽屉的插件,我们的项目一般用这个功能的时候,都会再里边加个确定,取消按钮,所以就需要封装一下,方便使用

 <el-dialog :visible.sync="visibleDialog">
    <!--内容区域的默认插槽-->
    <slot></slot>
    <span>
      <el-button @click="handleCancel">取 消</el-button>
      <el-button type="primary" @click="handleConfirm">
            确 定
      </el-button>
    </span>
  </el-dialog>

<script>
export default {
  props: {
    // 显示隐藏弹框
    visible: {
      type: Boolean,
      default: false
    }
  },
  computed: {
    // 通过计算属性,对.sync进行转换,外部也可以直接使用visible.sync
    visibleDialog: {
      get() {
        return this.visible;
      },
      set(val) {
        this.$emit("update:visible",val);
      }
    }
  },
  methods: {
    // 取消事件
    handleCancel() {
      this.$emit("cancel");
    },
    // 确定事件
    handleConfirm() {
      this.$emit("confirm");
    }
  }
};
</script>

调用的话

<custom-dialog
    :visible.sync="visibleDialog"
    @confirm="handleConfirm"
    @cancel="handleCancel"
  >
    这是一段内容
  </custom-dialog>

 

posted @ 2020-08-30 11:36  纯白棒球帽  阅读(395)  评论(0编辑  收藏  举报