vue中modal传输数据并刷新部分页面数据方式

 更新时间:2022年04月08日 10:43:58   作者:搬砖小生  
这篇文章主要介绍了vue中modal传输数据并刷新部分页面数据方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

modal传输数据刷新部分页面数据

在modal中传入数据至页面,并且页面刷新。

我在网上看到了 vue的几种页面传值方式

下面展示一些 内联代码片

//$ router
this.$router.push({ query: { ids: record.id } })

这种方式会刷新整个页面

// router-link
<router-link :to="{ name: 'jeecg-ChildStatistics',query:{ids:record.id} } ">

这种属于一个页面跳转到另一个页面并传值,于是使用后还要去关闭modal并手动刷新才能看到穿过去的参数

后面在网上找到了 监听的方式来实现

下面展示一些 内联代码片。

// A code block
var foo = 'bar';
// An highlighted block
 methods:{
      fetchData(){
           console.log('路由发送变化doing...');
     }
  },
  created() {
        var self = this;
        self.fetchData();
  },
  watch:{
      '$route':'fetchData'
  },

vue中modal数据管理

在编写页面时经常会使用各组件库的Modal组件。一般Modal组件管理的数据非常多,通常一个页面中有多个Modal,如果不将各个Modal封装成组件的话,数据堆砌在主页面将使得代码难以阅读。但是封装也是一门学问。

完全不封装的Modal代码示例

当在主页面管理编写Modal及管理数据时,当有多个Modal时会使得数据繁杂混乱,难以阅读。

<template>
  <div>
    <Modal v-model="modal1">
      {{ data1 + data2 + data3 }}
    </Modal>
    <Modal v-model="modal1">
      {{ data1 + data2 + data3 }}
    </Modal>
  </div>
</template>
<script>
export default {
  name: "ModalTest",
  data() {
    return {
      modal1: false,
      data1: 1,
      data2: 2,
      data3: 3,
      modal2: false,
      data4: 1,
      data5: 2,
      data6: 3,
    };
  },
  methods: {
    getData() {
      reqest("http://api",{params:1}).then((res) => {
        this.data1 = res.data;
        this.modal1 = true;
      });
    },
    getData2() {
      reqest("http://api",{params:2}).then((res) => {
        this.data5 = res.data;
        this.modal2 = true;
      });
    },
  },
};
</script>

将Modal及其数据封装成组件

如下封装虽好,但是modal1、modal2,data1,data5以及数据请求方法的管理依然留在主页面,代码多起来后,依然显得混乱。

<template>
  <div>
    <modal-1 :modal1='modal1' :data1='data1'/>
    <modal-1 :modal2='modal2' :data5='data5'/>
  </div>
</template>
<script>
import modal1 from './modal1.vue';
import modal2 from './modal2.vue';
export default {
  name: "ModalTest",
  comments:{modal1,modal2},
  data() {
    return {
      modal1: false,
      data1: 1,
      modal2: false,
      data5: 2,
    };
  },
  methods: {
    getData() {
      reqest("http://api", { params: 1 }).then((res) => {
        this.data1 = res.data;
        this.modal1 = true;
      });
    },
    getData2() {
      reqest("http://api", { params: 2 }).then((res) => {
        this.data5 = res.data;
        this.modal2 = true;
      });
    },
  },
};
</script>
<template>
  <Modal v-model="modal1">
    {{ data1 + data2 + data3 }}
  </Modal>
</template>
<script>
export default {
  name:'modal1',
  prop:{
    data1:Number,
    modal1:Boolean,
  },
  data() {
    return {
      data2:2,
      data3:3,
    }
  }
}
</script>

将Modal数据进行完全封装

最好的封装是将数据请求与其他所有数据都进行封装。由父组件调用子组件的方法。

<template>
  <div>
    <modal-1 ref="modal1"/>
    <modal-1 ref="modal2"/>
  </div>
</template>
<script>
import modal1 from './modal1.vue';
import modal2 from './modal2.vue';
export default {
  name: "ModalTest",
  comments:{modal1,modal2},
  methods: {
    getData() {
      this.$refs.modal1.getData(1);
      this.$refs.modal2.getData(2);
    },
  },
};
</script>
<template>
  <Modal v-model="modal1">
    {{ data1 + data2 + data3 }}
  </Modal>
</template>
<script>
export default {
  name:'modal1',
  data() {
    return {
      modal1:false,
      data1:1,
      data2:2,
      data3:3,
    }
  },
  methods: {
     getData(params) {
      reqest("http://api", { params: params }).then((res) => {
        this.data1 = res.data;
        this.modal1 = true;
      });
    },
  },
}
</script>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。 

相关文章

  • vue require.context()的用法实例详解

    vue require.context()的用法实例详解

    require.context是webpack提供的一个api,通常用于批量注册组件,下面这篇文章主要给大家介绍了关于vue require.context()用法的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-04-04
  • 结合axios对项目中的api请求进行封装操作

    结合axios对项目中的api请求进行封装操作

    这篇文章主要介绍了结合axios对项目中的api请求进行封装操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • Vue预渲染:prerender-spa-plugin生成静态HTML与vue-meta-info更新meta

    Vue预渲染:prerender-spa-plugin生成静态HTML与vue-meta-info更新meta

    Vue.js中,prerender-spa-plugin和vue-meta-info插件的结合使用,提供了解决SEO问题的方案,prerender-spa-plugin通过预渲染技术生成静态HTML,而vue-meta-info则能动态管理页面元数据,本文将探讨如何使用这两个工具优化Vue.js项目的SEO表现,包括安装、配置及注意事项
    2024-10-10
  • 聊聊vue集成sweetalert2提示组件的问题

    聊聊vue集成sweetalert2提示组件的问题

    这篇文章主要介绍了vue 集成 sweetalert2 提示组件的问题,本文通过项目案例实例代码相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2021-11-11
  • 使用Vue实现网站SEO优化的方法示例

    使用Vue实现网站SEO优化的方法示例

    在如今这个数字化和信息化的时代,搜索引擎优化(SEO)已经成为网站成功的关键因素之一,在使用现代化框架如Vue.js进行开发时,开发者通常关注的是构建高效的单页面应用,本文将介绍如何使用Vue来优化网站的SEO,并提供一些示例代码帮助您实现这些优化
    2024-11-11
  • vue之“} expected“和“at-rule or selector expected“报错的解决

    vue之“} expected“和“at-rule or selector ex

    这篇文章主要介绍了vue之“} expected“和“at-rule or selector expected“报错的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • vue加载完成后的回调函数方法

    vue加载完成后的回调函数方法

    今天小编就为大家分享一篇vue加载完成后的回调函数方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • Antd form表单的使用、设值、取值、清空值方式

    Antd form表单的使用、设值、取值、清空值方式

    这篇文章主要介绍了Antd form表单的使用、设值、取值、清空值方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • Vue3实现九宫格抽奖的示例代码

    Vue3实现九宫格抽奖的示例代码

    这篇文章主要为大家详细介绍了如何利用Vue3实现九宫格抽奖的功能,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的可以了解一下
    2022-09-09
  • 详解vue computed的缓存实现原理

    详解vue computed的缓存实现原理

    这篇文章主要介绍了vue computed的缓存实现原理,帮助大家更好的理解和学习使用vue,感兴趣的朋友可以了解下
    2021-04-04

最新评论