IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Vue 中点击一个按钮显示一个弹窗的2种不同组件封装 -> 正文阅读

[JavaScript知识库]Vue 中点击一个按钮显示一个弹窗的2种不同组件封装

封装一:只把弹窗封装成一个单独的组件

1. 弹窗组件 my-dialog.vue

<template>
  <el-dialog
    title="选择水果"
    :visible.sync="dialogVisible"
    width="30%"
    @close="handleClose"
  >
    <el-checkbox-group v-model="checkList">
      <el-checkbox
        v-for="it in optionList"
        :key="it.value"
        :label="it.value"
      >{{it.text}}</el-checkbox>
    </el-checkbox-group>

    <span slot="footer">
      <el-button @click="dialogVisible = false">取 消</el-button>
      <el-button type="primary" @click="dialogVisible = false">确 定</el-button>
    </span>
  </el-dialog>
</template>

<script>
export default {
  props: {
    visible: Boolean,
  },
  data () {
    this.optionList = [
      { value: 'apple', text: '苹果' },
      { value: 'orange', text: '橘子' },
      { value: 'pear', text: '梨' },
    ]
    return {
      dialogVisible: this.visible,
      checkList: [],
    };
  },
  methods: {
    handleClose() {
      this.$emit('update:visible', false);
    }
  },
}
</script>

<style>

</style>

2. 点击的按钮所在的业务组件

<template>
  <div>
    <!-- 其他业务 -->
    <!-- 其他业务 -->
    <!-- 其他业务 -->
    <el-button type="primary" @click="visible = true">显示弹窗</el-button>
    <MyDialog
      v-if="visible"
      :visible.sync="visible"
    />
  </div>
</template>

<script>
import MyDialog from '../components/my-dialog.vue';
export default {
  name: "Home",
  data() {
    return {
      visible: false,
    }
  },
  components: {
    MyDialog,
  },
};
</script>

优点:弹窗组件上可以加v-if,就可以不用手动去初始化data数据了。

缺点:按钮和弹窗没有跟业务代码混在一起,没有完全解耦。

封装二:按钮 + 弹窗 封装在同一个组件里

1. 按钮 + 弹窗组件 show-dialog-btn.vue

<template>
<span>
  <slot :show="show"></slot>
  <el-dialog
    title="选择水果"
    :visible.sync="dialogVisible"
    width="30%"
  >
    <el-checkbox-group v-model="checkList">
      <el-checkbox
        v-for="it in optionList"
        :key="it.value"
        :label="it.value"
      >{{it.text}}</el-checkbox>
    </el-checkbox-group>

    <span slot="footer">
      <el-button @click="dialogVisible = false">取 消</el-button>
      <el-button type="primary" @click="dialogVisible = false">确 定</el-button>
    </span>
  </el-dialog>
</span>
</template>

<script>
export default {
  data () {
    this.optionList = [
      { value: 'apple', text: '苹果' },
      { value: 'orange', text: '橘子' },
      { value: 'pear', text: '梨' },
    ];
    // 初始化的data
    this.initData = {
      checkList: [],
    }
    return {
      dialogVisible: false,
      ...JSON.parse(JSON.stringify(this.initData)),
    };
  },
  methods: {
    show() {
      this.dialogVisible = true;
    },
  },
  watch: {
    dialogVisible(val) {
      if (!val) return;
      Object.assign(this, JSON.parse(JSON.stringify(this.initData)));
    }
  },
}
</script>

<style>

</style>

2. 使用组件

<ShowDialogBtn>
  <template slot-scope="{show}">
    <a @click="show">显示弹窗</a>
  </template>
</ShowDialogBtn>

优点:1.?按钮 + 弹窗的整个组件跟业务组件解耦的比较干净。

? ? ? ? ? ?2. 按钮通过 slot 传入,看业务代码的时候也很好知道这个是什么按钮。

缺点:要在组件显示或关闭时手动初始化data数据。

还有一种按钮 + 弹窗封装在一起的方法是,按钮不用 slot 传入,而是直接写在组件里面:

<template>
<span>
  <a @click="show">显示弹窗</a>
  <el-dialog
    title="选择水果"
    :visible.sync="dialogVisible"
    width="30%"
  >
    <el-checkbox-group v-model="checkList">
      <el-checkbox
        v-for="it in optionList"
        :key="it.value"
        :label="it.value"
      >{{it.text}}</el-checkbox>
    </el-checkbox-group>

    <span slot="footer">
      <el-button @click="dialogVisible = false">取 消</el-button>
      <el-button type="primary" @click="dialogVisible = false">确 定</el-button>
    </span>
  </el-dialog>
</span>
</template>

<script>
export default {
  data () {
    this.optionList = [
      { value: 'apple', text: '苹果' },
      { value: 'orange', text: '橘子' },
      { value: 'pear', text: '梨' },
    ];
    // 初始化的data
    this.initData = {
      checkList: [],
    }
    return {
      dialogVisible: false,
      ...JSON.parse(JSON.stringify(this.initData)),
    };
  },
  methods: {
    show() {
      this.dialogVisible = true;
    },
  },
  watch: {
    dialogVisible(val) {
      if (!val) return;
      Object.assign(this, JSON.parse(JSON.stringify(this.initData)));
    }
  },
}
</script>

<style>

</style>
<ShowDialogBtn/>

优点:跟业务代码解耦的最彻底。

缺点:1.?一眼看不出这是哪个功能按钮,还要看一下组件里的代码。

? ? ? ? ? ?2.?要在组件显示或关闭时手动初始化data数据。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-12-13 12:43:13  更:2021-12-13 12:45:06 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 2:19:32-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码