Vue实现简单弹窗效果

 更新时间:2022年09月20日 14:25:58   作者:y-zk  
这篇文章主要为大家详细介绍了Vue实现简单弹窗效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了Vue实现简单弹窗效果的具体代码,供大家参考,具体内容如下

选中input 弹出选项框

显示弹窗

首先要在components中新建两个组件 要实现子组件向父组件传值

selest.vue 里面的内容

<template>
  <div>
    <h1>选择管理员</h1>
    <div class="sel" @click="show">{{ str }}</div>
    <template v-if="bol">
      <alt @ok="getData($event)" @cancel="close"></alt>
    </template>
  </div>
</template>

<script>
import Alt from "./alt.vue";
export default {
  name: "Select",
  data() {
    return {
      bol: false,
      str: '',
    };
  },
  components: {
    Alt,
  },
  methods: {
    show() {
      this.bol = true;
    },
    // 获取数据方法
    getData(data) {
      // 关闭弹出层
      this.bol = false;
      console.log(data);
      this.str = data;
    },
    // 关闭弹窗
    close() {
      // 关闭弹出层
      this.bol = false;
    },
  },
};
</script>

<style scoped>
.sel {
  width: 200px;
  height: 40px;
  border: 1px solid #ccc;
  line-height: 40px;
  text-align: center;
  cursor: pointer;
  margin: 0 auto;
}
</style>

alt.vue 里面的内容

<template>
  <div class="mark">
    <div class="alert">
      <!-- 内容 -->
      <div class="cont">
        <div>
          <!-- 左边的列表 -->
          <dl class="left">
            <dt>
              <label><input type="checkbox" v-model="allBol" :checke="allBol" @change="all" />全选</label>
            </dt>
            <dd v-for="(item,index) in arrL" :key="index">
              <label>
                <input type="checkbox" :checked="item.bol" v-model="item.bol" @change="only(index)" />
                <img :src="item.headurl" alt="">
                <span>{{item.name}}</span>
              </label>
            </dd>
          </dl>
        </div>
        <div>
         <dl class="left">
            <dd v-for="(item,index) in arrR" :key="index">
              <label>
                <img :src="item.headurl" alt="">
                <span>{{item.name}}</span>
              </label>
              <em @click="del(item,index)">×</em>
            </dd>
          </dl>
        </div>
      </div>
      <!-- 按钮 -->
      <div class="btns">
        <button @click="sure">确定</button>
        <button @click="cancel">取消</button>
      </div>
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      allBol: false,
      arrL: [
        { name: '花木兰', id: 1, headurl: require('../assets/logo.png'), bol: false },
        { name: '拓跋焘', id: 2, headurl: require('../assets/logo.png'), bol: false },
        { name: '宇文泰', id: 1, headurl: require('../assets/logo.png'), bol: false },
        { name: '宇文成都', id: 1, headurl: require('../assets/logo.png'), bol: false },
        { name: '宇文护', id: 1, headurl: require('../assets/logo.png'), bol: false },
        { name: '宇文拓', id: 1, headurl: require('../assets/logo.png'), bol: false }
      ],
      arrR: []
    }
  },
  methods: {
    // 点击全选
    all() {
      // 清空一个数组
      this.arrR = []; // 第一种
      // this.arrR.length = 0; // 第二种
      this.arrL.map(item => {
        item.bol = this.allBol;
        if(this.allBol) {
          this.arrR.push(item);
        }
      })
    },
    // 点击单选
    only(n) {
     if (this.arrL[n].bol) {
       this.arrR.push(this.arrL[n])
     }else {
       let index = this.arrR.indexOf(this.arrL[n]);
       this.arrR.splice(index,1);
       this.allBol = false
     }
    },
    // 删除
    del(obj, index) {
      let n = this.arrL.indexOf(obj);
      this.arrL[n].bol = false;
      this.arrR.splice(index, 1)
    },
    // 点击确定
    sure() {
      let arr = [];
      this.arrR.map(item => {
        arr.push(item.name)
      })
      this.$emit('ok', arr.join(','));
    },
    // 点击取消
    cancel() {
      this.$emit('cancel')
    },
  }
};
</script>

<style scoped>
.mark {
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  position: fixed;
  left: 0;
  top: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.alert{
  background: #fff;
  width: 800px;
  height: 600px;
}
.cont {
  display: flex;
  height: 500px;
}
.cont>div {
  flex: 1;
}
.cont>div:nth-child(1) {
  border-right: 1px #ccc solid;
}
.btns {
  height: 100px;
  text-align: center;
}
.left dd {
  height: 50px;
  margin-bottom: 10px;
  position: relative;
}
.left dd label {
  display: flex;
  height: 50px;
  align-items: center;
  cursor: pointer;
}
.left dd label:hover {
  background: #f0f0f0;
}
.left dd label img {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  margin: 0 5px;
}
.left dd em {
  cursor: pointer;
  position: absolute;
  width: 50px;
  height: 50px;
  font-size: 30px;
  text-align: center;
  line-height: 50px;
  right: 0;
  top: 0;
  transition: all 0.8s;
}
.left dd em:hover{
  transform: rotate(360deg);
}

</style>

在App.vue 里面写

<template>
  <div id="app">
    <div id="nav">
      <router-link to="/select">选择管理员</router-link>
    </div>
    <router-view/>
  </div>
</template>

在router 下面的index.js 里面添加路由

import Vue from 'vue'
import VueRouter from 'vue-router'
import Home from '../views/Home.vue'

Vue.use(VueRouter)

const routes = [
  {
    path: '/',
    name: 'Home',
    component: Home
  },
  {
    path: '/about',
    name: 'About',
    component: function () {
      return import('../views/About.vue')
    }
  },
  // 创建的路由
  {
    path: '/select',
    name: 'Select',
    component: () => import('../components/selest.vue')
  }
]

const router = new VueRouter({
  mode: 'history',
  base: process.env.BASE_URL,
  routes
})

export default router

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

相关文章

  • 羊了个羊通关脚本Vue node实现版本

    羊了个羊通关脚本Vue node实现版本

    这篇文章主要为大家介绍了羊了个羊通关脚本Vue node实现版本,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • vue3实现页面跳转的示例代码

    vue3实现页面跳转的示例代码

    这篇文章给大家介绍了vue3如何实现页面跳转,文中通过代码示例给大家介绍的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2024-02-02
  • 详解Vue项目中出现Loading chunk {n} failed问题的解决方法

    详解Vue项目中出现Loading chunk {n} failed问题的解决方法

    这篇文章主要介绍了详解Vue项目中出现Loading chunk {n} failed问题的解决方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09
  • 浅谈使用mpvue开发小程序需要注意和了解的知识点

    浅谈使用mpvue开发小程序需要注意和了解的知识点

    这篇文章主要介绍了浅谈使用mpvue开发小程序需要注意和了解的知识点,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-05-05
  • Vue开发实现滑动验证组件

    Vue开发实现滑动验证组件

    这篇文章主要为大家详细介绍了如何利用Vue开发实现简单的滑动验证组件,并且适配移动和PC,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2023-07-07
  • Vue3中使用Pinia的方法详细介绍

    Vue3中使用Pinia的方法详细介绍

    这篇文章主要给大家介绍了关于Vue3中使用Pinia的相关资料,pinia是一个用于vue的状态管理库,类似于vuex,是vue的另一种状态管理工具,文中介绍的非常详细,需要的朋友可以参考下
    2024-01-01
  • 在vue3中使用el-tree-select实现树形下拉选择器效果

    在vue3中使用el-tree-select实现树形下拉选择器效果

    el-tree-select是一个含有下拉菜单的树形选择器,结合了 el-tree 和 el-select 两个组件的功能,这篇文章主要介绍了在vue3中使用el-tree-select做一个树形下拉选择器,需要的朋友可以参考下
    2024-03-03
  • Vue插槽slot全部使用方法示例解析

    Vue插槽slot全部使用方法示例解析

    插槽就是子组件中的提供给父组件使用的一个占位符,用<slot></slot> 表示,父组件可以在这个占位符中填充任何模板代码,如 HTML、组件等,填充的内容会替换子组件的<slot></slot>标签,这篇文章主要介绍了Vue插槽的理解和使用,需要的朋友可以参考下
    2023-03-03
  • Vue.js slot插槽的作用域插槽用法详解

    Vue.js slot插槽的作用域插槽用法详解

    这篇文章主要介绍了Vue.js slot插槽的作用域插槽用法详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-09-09
  • 通过vue-cli来学习修改Webpack多环境配置和发布问题

    通过vue-cli来学习修改Webpack多环境配置和发布问题

    这篇文章主要介绍了随着Vue-cli来'学'并'改'Webpack之多环境配置和发布的相关知识,本文将会根据一些实际的业务需求,先学习vue-cli生成的模版,然后在进行相关修改,感兴趣的朋友一起跟着小编学习吧
    2017-12-12

最新评论