vue自定义弹窗点击除了自己区域外关闭弹窗

这里使用到vue的自定义指令

javascript 复制代码
         <div class="item" v-clickoutside="clickoutside1">
            <div @click="opencity" class="text"
              :style="{ color: popup.iscitypop || okcitylist.length != 0 ? '#FF9500' : '#000000' }">选择地区
            </div>
            <i v-if="popup.iscitypop || okcitylist.length != 0" class=" el-icon-arrow-up"
              :style="{ color: popup.iscitypop || okcitylist.length != 0 ? '#FF9500' : '#000000' }"></i>
            <i v-else class="el-icon-arrow-down"
              :style="{ color: popup.iscitypop || okcitylist.length != 0 ? '#FF9500' : '#000000' }"></i>
            //绝对定位样式 popup.iscitypop true展示 false隐藏
            <div class="poppad" v-if="popup.iscitypop">
              <div class="tit" v-for="(item, index) in citylist" :key="index">
                {{ item.n }}
                <div class="cit">
                  <div class="items" :class="its.isactive ? 'active' : ''" v-for="(its, ind) in item.s" :key="ind"
                    @click.stop="changeCity(its, ind)">
                    {{ its.n }}
                  </div>
                </div>
              </div>
            </div>
          </div>


export default {
  directives: {
    clickoutside: {
      bind: function (el, binding, vnode) {
        function documentHandler(e) {
          if (el.contains(e.target)) {
            return false;
          }
          if (binding.expression) {
            binding.value(e);
          }
        }
        el.__vueClickOutside__ = documentHandler;
        document.addEventListener("click", documentHandler);
      },
      unbind: function (el, binding) {
        document.removeEventListener("click", el.__vueClickOutside__);
        delete el.__vueClickOutside__;
      }
    }
  },
}
相关推荐
幸福指北5 分钟前
我用 Tauri + Vue 3 + Rust 开发了一款跨平台网络连接监控工具Portview,性能炸裂!
前端·网络·vue.js·tcp/ip·rust
炁场悟道6 分钟前
基于vue3的极简登录架构设计
前端
光影少年9 分钟前
Webpack的核心概念?常见优化手段?
前端·webpack·掘金·金石计划
han_10 分钟前
前端性能优化之白屏、卡顿指标和网络环境采集篇
前端·javascript·性能优化
Flyfreelylss19 分钟前
DOM 注入实践:在 React 中优雅地扩展第三方组件
前端·react.js
北城笑笑28 分钟前
Vue 100 ,Metaspace memory lack Error( 元空间内存不足 )
java·前端·javascript·vue
谏书稀28 分钟前
vue项目(pnpm)迁移到无网环境开发
前端·javascript·vue.js
Han.miracle33 分钟前
Spring IoC 与 DI 核心知识点综合测试题
java·前端·数据库
-杨豫35 分钟前
JavaScript入门到精通全套资料,以及核心进阶ES6语法,API,js高级等基础知识和实战教程
开发语言·javascript·es6
im_AMBER44 分钟前
react-i18next 国际化支持
前端·react.js·前端框架