牛骨文教育服务平台(让学习变的简单)
博文笔记

vue 组件弹出框点击显示隐藏

创建时间:2017-12-28 投稿人: 浏览次数:1530

本案实现的效果如下图
这里写图片描述
由于我的更改密码弹出框是一个组件引用的,所以在一开始是隐藏的,这就需要在当前的页面上对弹出框组件设置v-show,但是在弹出框显示出来的时候,操作执行完后当前页面的更改按钮已经被弹出框覆盖了。所以只能在弹出页面点击取消实现关闭隐藏弹出框。这样就需要写两个点击事件,但是两个点击事件就会有冲突,需要点击两下才能使弹出框显示和隐藏。然后我就用的以下方法,希望可以帮到大家!!!
代码如下
1.在当前页面中(主页面)

<template>
    ......
    <ul>
        <li><span @click="ModifyPassword()">更改密码</span></li> //点击事件
    </ul>
    ......
    //组件传一个点击事件@hidden="hiddenShow",而这个点击事件就是下面的hiddenShow()函数
    <ModifyPassword @hidden="hiddenShow" v-show="ModifyPassword_pop_up">  </ModifyPassword>   //调用组件
</template>
<script>
  import ModifyPassword from "@/components/pop-up/ModifyPassword.vue  //引入组件
  export default {
    data(){
      return{
        date:"",
        ModifyPassword_pop_up:false,
        history_pop_up:false
      }
    },
    components:{
      ModifyPassword  //引用组件
    },
    methods:{
      //更改密码弹出框显示(组件引用的弹出框)
      ModifyPassword(){
        this.ModifyPassword_pop_up=true
      },
      //更改密码弹出框隐藏(传给组件一个点击事件)
      hiddenShow(){
        let that = this;
        that.ModifyPassword_pop_up = false
      }
    }
  }
</script>

2.在弹出框组件页面中(更改密码)

<template>
    ......
    <div class="foot">
            <input type="button" name="OK" value="提交" class="yes" >
            //在取消按钮这里调用点击事件
            <input type="button" name="cancel" value="取消" class="no" @click="Hidden()">
          </div>
    ......
</ModifyPassword>  
</template>
<script>
  export default {
    data(){
      return{}
    },
    methods:{
      //本更改密码弹出框的显示隐藏事件
      Hidden(){
        //通过$emit引用组件传过来的hidden()事件
        this.$emit("hidden")
      }
    }
  }
</script>

虽然Vue 有很多UI组件。但是让内容比较多比较复杂的时候,还是需要自己写一个的。本案主要是运用了$emit监听,组件传事件。如果有更好的方案欢迎大家一起交流。

声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。