vue iview封装模态框的方法

 更新时间:2022年07月05日 17:24:27   作者:周家大小姐.  
这篇文章主要为大家详细介绍了vue iview封装模态框的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了vue iview封装模态框的具体代码,供大家参考,具体内容如下

子组件

<template>
  <Modal
    :value="isShowModal"
    :width="width"
    :title="title"
    @on-visible-change="getFaultModalStatusChange"
  >
    <slot name="content"></slot>
    <div slot="footer">
      <div>
        <Button type="success" :loading="loading" @click="submit">确认</Button>
        <Button class="cancelButton" @click="cancel">取消</Button>
      </div>
    </div>
  </Modal>
</template>
 
<script>
export default {
  name: "ModalBlock",
  props: {
    isShowModal: {
      type: Boolean,
      default: false
    },
    title: {
      type: String
    },
    width: {
      type: Number
    },
    loading: {
      type: Boolean,
      default: false
    }
  },
  methods: {
    cancel: function() {
      this.$emit("modalCancel");
    },
    submit() {
      this.$emit("modalSubmit");
    },
    getFaultModalStatusChange(e) {
      this.$emit("modalStatusChange", e);
    }
  }
};
</script>
 
<style scoped>
</style>

父组件引入

<template>
  <div>
    <Button type="primary" @click="isShowModal = true">Display dialog box</Button>
    <modal-block
      :isShowModal="isShowModal"
      title="搜索框"
      :width="640"
      @modalSubmit="modalSubmit"
      @modalCancel="modalCancel"
      @modalStatusChange="modalStatusChange"
    >
      <div slot="content">
        <Row>
          <Col span="12">
            <div>
              <Input
                v-model="SearchVal"
                icon="ios-search"
                placeholder="Enter something..."
                style="width: 200px"
                @on-click="handleSearch"
                autocomplete
              />
            </div>
            <div style="height:300px;overflow-y: scroll; margin-top:15px;">
              <RadioGroup v-model="listVal" vertical @on-change="changeSerachVal">
                <Radio :label="item.label" v-for="(item,i) in searchList" :key="i">
                  <span>{{item.value}}</span>
                  <Icon :type="item.icon" />
                </Radio>
              </RadioGroup>
            </div>
          </Col>
          <Col span="12">{{searDtail}}</Col>
        </Row>
      </div>
    </modal-block>
  </div>
</template>
<script>
import ModalBlock from "@/common/ModalItem/ModalSerach";
 
export default {
  name: "ImageUpload",
  components: { ModalBlock },
 
  data() {
    return {
      width: 640,
      SearchVal: "",
      listVal: "",
      searDtail: "",
      isShowModal: false,
 
      searchList: [
        {
          label: "1",
          icon: "logo-apple",
          value: "111111"
        },
        {
          label: "2",
          icon: "logo-apple",
          value: "111111"
        },
        {
          label: "3",
          icon: "logo-apple",
          value: "111111"
        },
        {
          label: "3",
          icon: "logo-apple",
          value: "111111"
        },
        {
          label: "4",
 
          icon: "logo-apple",
          value: "111111"
        },
        {
          label: "5",
 
          icon: "logo-apple",
          value: "111111"
        }
      ]
    };
  },
  methods: {
    // 模态输入框搜索
    handleSearch() {
      console.log(`modalSubmit11111111`);
    },
    // 点击模态框单选框触发事件
    changeSerachVal(e) {
      if (e == 1) {
        this.searDtail = "1111";
      } else if (e == 2) {
        this.searDtail = "22222222222";
      }
    },
    // 模态框确定事件
    modalSubmit() {
      this.isShowModal = false;
    },
    // 模态框取消事件
 
    modalCancel() {
      this.isShowModal = false;
    },
    // 模态框关闭触发事件
    modalStatusChange(e) {
      if (e === false) {
        this.isShowModal = false;
      }
    }
  }
};
</script>
<style scoped>
</style>

一定要加 @on-visible-change="getFaultModalStatusChange" 这个事件,不然点击按钮的时候会报错

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • vue路由传参的基本实现方式小结【三种方式】

    vue路由传参的基本实现方式小结【三种方式】

    这篇文章主要介绍了vue路由传参的基本实现方式,结合实例形式总结分析了vue.js路由传参的三种实现方式,包括params显示传参、不显示参数以及query显示参数传参,需要的朋友可以参考下
    2020-02-02
  • vue项目依赖升级报错处理方式

    vue项目依赖升级报错处理方式

    这篇文章主要介绍了vue项目依赖升级报错处理方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • vite创建vue3项目页面引用public下js文件失败解决办法

    vite创建vue3项目页面引用public下js文件失败解决办法

    Vue3相较于之前的版本有了不少变化,如引用全局Js文件,这篇文章主要给大家介绍了关于vite创建vue3项目页面引用public下js文件失败的解决办法,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-11-11
  • vue-cli3.0.4中webpack的dist路径如何修改

    vue-cli3.0.4中webpack的dist路径如何修改

    这篇文章主要介绍了vue-cli3.0.4中webpack的dist路径如何修改,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • Vue中nextTick的原理分析

    Vue中nextTick的原理分析

    本文详细介绍了Vue中nextTick的原理和使用方法,Vue采用异步渲染机制,通过nextTick可以确保在DOM更新后执行回调,nextTick依赖微任务和宏任务,优先使用Promise,降级到MutationObserver/setTimeout,Vue3进一步优化了nextTick,减少了复杂度并提升了性能
    2025-02-02
  • vue在组件中使用v-model的场景

    vue在组件中使用v-model的场景

    这篇文章主要介绍了vue在组件中使用v-model的场景,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-07-07
  • vue使用Echarts绘制地图完整步骤

    vue使用Echarts绘制地图完整步骤

    这篇文章主要给大家介绍了关于vue使用Echarts绘制地图的相关资料,Apache ECharts一个基于JavaScript的开源可视化图表库,提供了常规的折线图、柱状图、散点图、饼图、K线图,用于统计的盒形图,需要的朋友可以参考下
    2023-09-09
  • vue的ssr服务端渲染示例详解

    vue的ssr服务端渲染示例详解

    这篇文章主要给大家介绍了关于vue的ssr服务端渲染的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • vue2中使用sass并配置全局的sass样式变量的方法

    vue2中使用sass并配置全局的sass样式变量的方法

    这篇文章主要介绍了vue2中使用sass并配置全局的sass样式变量的方法,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-09-09
  • vue2.x中h函数(createElement)与vue3中的h函数详解

    vue2.x中h函数(createElement)与vue3中的h函数详解

    h函数本质就是createElement(),h函数其实是createVNode的语法糖,返回的就是一个Js普通对象,下面这篇文章主要给大家介绍了关于vue2.x中h函数(createElement)与vue3中h函数的相关资料,需要的朋友可以参考下
    2022-12-12

最新评论