webpack + vue 实现 弹窗功能

对于刚入门webpack + vue 不久的新人来说,这技术,确实有些不太友好,相比较于直接操纵dom元素的jQuery,直接操纵数据的 vue 在webpack框架下实现多级弹窗的效果,要麻烦很多。

需求背景:点击地图撒点,会有一个回调函数返回数据,然后需要根据返回的数据打开弹窗,显示详细内容。

一开始我是设置了一些全局的变量和方法,通过全局方法获得回调函数返回的数据,然后再将此数据赋值给全局变量,以供所有页面使用。

但是这里有两个问题:

1.全局变量无法在Mustache(双花括号)和 vue指令 里面使用,即:

v-if="popCon.show"       //控制弹窗显示和隐藏          popCon为popupController的缩写,此变量用来控制弹窗的显示隐藏

{{globalResult.name}}    //使用回调函数返回的数据在弹窗中显示  globalResult为回调函数返回的数据,在页面中展示

2.即使通过在data中使用 中间变量 来赋值使用,但是当全局变量的更新时,本地变量无法同步

data: {

  localCon: popCon,

  localResult: globalResult

}

v-if="localCon.show"

{{localCon.name}}      //这种情况,当 popCon 和 globalResult 发生变化时,localCon 和 localResult 无法同步

在无法绕开这两个问题的情况下,使用全局变量这种方式已经无法实现当前的需求。

所以,这里推荐使用 vuex 的全局变量来实现效果。

========================================

解决方案:

首先,在 vuex 的state中设置两个全局变量

const state = {

  popCon: {

    controller1: false,    //第一个弹窗显示控制,可以通过给弹窗的 X ,添加点击事件,赋值,来关闭窗口

    controller2: false     //第二个弹窗显示控制

  },

  globalResult: {          //此变量为回调函数返回的数据

    name: "名称"    

  }

}

然后,在相应的弹窗组件中使用这两个全局变量来达到效果

v-if="$store.state.popCon.controller1"  //显示效果,控制组件的显示效果,这里就不写组件的代码了

{{$store.state.globalResult.name}}     //数据效果

现在这里都是默认的数据,然后需要在回调函数中给全局变量赋值

一般来说,我们都是直接给变量赋值,也就是 $store.state.globalResult = result

但是 vue 官方不推荐直接修改state的属性

推荐我们使用mutations来修改state的属性

function callback (result) {

  vueObj.$store.commit('globalResult',result)  //这里就不解释 vuex 的 mutations的写法了

  vueObj.$store.commit('popCon',true)      //设置弹窗显示为 true,打开弹窗  这里的 popCon 是 mutations里面的一个方法名为 popCon 的函数,上一行 globalResult 同理

}

到这里,就已经实现了 通过vuex 来达到打开弹窗详情界面的功能。

通过点击某个地方,获取数据,然后打开详情页面,显示数据内容,点击关闭按钮关闭弹窗

如果需要实现多级详情弹窗,可以在弹窗界面中嵌套使用。

vue实现多级弹窗的更多相关文章

  1. 从零开始徒手撸一个vue的toast弹窗组件

    相信普通的vue组件大家都会写,定义 -> 引入 -> 注册 -> 使用,行云流水,一气呵成,但是如果我们今天是要自定义一个弹窗组件呢? 首先,我们来分析一下弹窗组件的特性(需求): ...

  2. vue 阻止冒泡弹窗小案例( 知识点:@click.stop=''")

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. vue中前端弹窗队列展示

    在前端写一个弹窗可能很简单,那如果同时有多个弹窗呢 这样的话就要考虑弹窗的展示问题,肯定是不能叠加在一起的,这时候就要通过队列(先进先出)来展示 思路就是根据队列来实现,至于具体的实现方式,可以在项目 ...

  4. Vue自定义Popup弹窗组件|vue仿ios、微信弹窗|vue右键弹层

    基于vue.js构建的轻量级Vue移动端弹出框组件Vpopup vpopup 汇聚了有赞Vant.京东NutUI等Vue组件库的Msg消息框.Popup弹层.Dialog对话框.Toast弱提示.Ac ...

  5. vue项目|在弹窗中引入uchart图表子组件不显示

    为了解决uchart作为子组件在主组件里引用但不显示的情况,(同样适用于弹窗之中)目前有三种方法. 1-解决方式 1>如果你使用的uchart子组件是从官方拿的例子:进入到uchart子组件将o ...

  6. vue在多级联动时,一些情况不用watch而用onchange会更好

    onchange事件在内容改变且失去焦点时触发,因此在一些多级联动需要清空次级内容的时候,用onchange就非常有用了,尤其是浏览器会提前加载数据的情况下.有篇文章可以看一下,链接. PS:路漫漫其 ...

  7. vue使用sweetalert2弹窗插件

    1). 安装 sweetalert2 npm install sweetalert2@7.15.1 --save 2). 封装 sweetalert2 在 src 新建 plugins 文件夹,然后新 ...

  8. vue+vue-video-player实现弹窗播放视频

    将视频播放器标签放在对话框标签中,实现弹窗 template 中 <el-dialog :visible.sync="dialogVisible" width='680px' ...

  9. vue 点击弹窗外框关闭弹框

    https://blog.csdn.net/zjw0742/article/details/77822777 ready() { document.addEventListener('click', ...

随机推荐

  1. MXNet 分布式环境部署

    MXNet 分布式环境部署 1. MxNet 分布式介绍 先忽略吧, 回头在填上去 2. 分布式部署方法 假设有两台主机ip地址分别是xxx.xxx.xxx.114 和 xxx.xxx.xxx.111 ...

  2. C# FTP操作类(获取文件和文件夹列表)

    一.如何获取某一目录下的文件和文件夹列表. 由于FtpWebRequest类只提供了WebRequestMethods.Ftp.ListDirectory方式和WebRequestMethods.Ft ...

  3. sql server中同时执行select和update语句死锁问题

    原始出处 http://oecpby.blog.51cto.com/2203338/457054 最近在项目中使用SqlServer的时候发现在高并发情况下,频繁更新和频繁查询引发死锁.通常我们知道如 ...

  4. git error:【fatal: unable to access 'https://github.com/userId/prjName.git/': err or setting certificate verify locations:】

    $ git pull origin master fatal: unable to access 'https://github.com/userId/prjName.git/': err or se ...

  5. QTimer掉坑出坑过程

    最近遇到一个问题,就是关于QTimer设置了10ms,结果不生效,很头疼啊,查了快一天了,终于知道为什么了? 先说下QTimer的使用方法: m_delayHideTimer这是QTimer的对象. ...

  6. 最短路径-Dijkstra算法与Floyd算法

    一.最短路径 ①在非网图中,最短路径是指两顶点之间经历的边数最少的路径. AE:1    ADE:2   ADCE:3   ABCE:3 ②在网图中,最短路径是指两顶点之间经历的边上权值之和最短的路径 ...

  7. 贴现率d与利率i

    一.复利中的实际利率 it=(1+i)t -(1+i)t-1  /   (1+i)t-1=i i 为常数, 而单利的实际利率递减 二.贴现 时间t的1元在时间零点的价值为贴现函数 记为 a-1(t) ...

  8. selenium 滑动解锁(drag_and_drop_by_offset)

    from selenium import webdriver from selenium.webdriver.common.action_chains import ActionChains from ...

  9. Oracle 数据库视图与基表的关系

    本文转载自:http://www.linuxidc.com/Linux/2015-03/115165.htm 一:首先解释什么是视图: 视图其实就是一条查询sql语句,用于显示一个或多个表或其他视图中 ...

  10. Springmvc 进行数据类型转换

    SpringMVC进行一些常用的数据类型转换,这里以Date 数据类型的转换为例. SpringMVC表单中输入日期,一般都是以字符串的形式输入,如何将字符形式的日期转换为Date 类型的呢?这里只需 ...