Vue.js实现在下拉列表区域外点击即可关闭下拉列表的功能(自定义下拉列表)

发布时间 - 2026-01-11 01:31:49    点击率:

在开发过程中,为了效果好看,往往需要自己开发一个下拉列表,而不是使用 HTML 自身的 select 下拉列表。然而当编写自定义下拉列表的时候,就会碰到一个问题:如果用户在下拉列表的范围外进行鼠标点击的操作,如何关闭已经打开的下拉列表?

解决思路如下:在 DOM 的根节点上添加一个 click 事件,同时下拉列表内阻止事件的默认行为和冒泡。当响应这个点击事件的时候,说明是在下拉列表范围外的点击(因为下拉列表内阻止了事件的冒泡),就可以关闭已经打开的下拉列表。

如果是纯 JS 代码,有人可能会使用 document.onclick 来添加根节点事件。不过,我现在使用 Vue.js,会选择使用 Vue.js 的方式处理这个问题。

Vue.js 使用组件化的方式组织代码,会有一个根组件,可以在这个根组件上加上 @click 事件,来响应区域外的点击事件。在一个完整的应用中,可能有多种场景需要这种区域外点击关闭的功能。除了最普通的表单里的下拉列表外,还可能是网站右上角的消息提示框,或者菜单。比较合适的做法是把点击事件的具体处理逻辑放到各个组件中去。

那么如何让各个子组件响应根组件上的点击事件呢?可以使用Vuex来做到这一点。在这里 Vuex 起到了组件之间互相传递信息的作用。

读者可以在这个网址下载我编写的 Demo 项目:

推荐读者使用 yarn install 安装所需的依赖。

下面说一下关键代码:

程序入口 main.js:

import Vue from 'vue'
import App from './App.vue'
import VueRouter from 'vue-router'
import routes from './router'
import VueSuperagent from 'vue-superagent'
import Vuex from 'vuex'
import 'babel-polyfill';
import store from './vuex/store';
Vue.use(VueRouter);
Vue.use(VueSuperagent);
Vue.use(Vuex);
const router = new VueRouter({
 mode: 'history',
 routes
})
new Vue({
 el: '#app',
 router,
 store,
 render: h => h(App)
})

根节点 App.vue,添加了点击事件。

<template>
 <div @click="clickRoot">
  <router-view></router-view>
 </div>
</template>
<script>
  export default {
    methods:{
      clickRoot(event){
        this.$store.dispatch("clickRootNumAction", 1);
      }
    }
  }
</script>

以上所述是小编给大家介绍的Vue.js实现在下拉列表区域外点击即可关闭下拉列表的功能(自定义下拉列表),希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!


# vuejs  # 下拉列表  # jQuery+vue.js实现的九宫格拼图游戏完整实例【附源码下载】  # 详解使用Vue.Js结合Jquery Ajax加载数据的两种方式  # Vue.js 通过jQuery ajax获取数据实现更新后重新渲染页面的方法  # vue.js2.0点击获取自己的属性和jquery方法  # Vue.js列表渲染绑定jQuery插件的正确姿势  # Vue.js表单标签中的单选按钮、复选按钮和下拉列表的取值问题  # vue表单绑定实现多选框和下拉列表的实例  # vue下拉列表功能实例代码  # Vue.js做select下拉列表的实例(ul-li标签仿select标签)  # vue 1.x 交互实现仿百度下拉列表示例  # jQuery+vue.js实现的多选下拉列表功能示例  # 在这个  # 自定义  # 小编  # 就会  # 是在  # 在这里  # 会有  # 我现在  # 这个问题  # 所需  # 给大家  # 可以使用  # 一个问题  # 中去  # 表单  # 所述  # 有多种  # 给我留言  # 还可能  # 就可以 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何打造高效商业网站?建站目的决定转化率  香港服务器租用每月最低只需15元?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  HTML透明颜色代码怎么让图片透明_给img元素加透明色的技巧【方法】  Python自动化办公教程_ExcelWordPDF批量处理案例  装修招标网站设计制作流程,装修招标流程?  轻松掌握MySQL函数中的last_insert_id()  如何用免费手机建站系统零基础打造专业网站?  简单实现jsp分页  如何在不使用负向后查找的情况下匹配特定条件前的换行符  jQuery中的100个技巧汇总  Laravel怎么使用Blade模板引擎_Laravel模板继承与Component组件复用【手册】  微信小程序 input输入框控件详解及实例(多种示例)  Laravel如何优化应用性能?(缓存和优化命令)  如何生成腾讯云建站专用兑换码?  laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  JavaScript如何实现类型判断_typeof和instanceof有什么区别  活动邀请函制作网站有哪些,活动邀请函文案?  Laravel辅助函数有哪些_Laravel Helpers常用助手函数大全  Laravel如何从数据库删除数据_Laravel destroy和delete方法区别  如何快速启动建站代理加盟业务?  高端网站建设与定制开发一站式解决方案 中企动力  Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】  桂林网站制作公司有哪些,桂林马拉松怎么报名?  北京网站制作公司哪家好一点,北京租房网站有哪些?  Laravel如何使用Service Container和依赖注入?(代码示例)  JavaScript如何实现路由_前端路由原理是什么  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  Laravel如何正确地在控制器和模型之间分配逻辑_Laravel代码职责分离与架构建议  Laravel如何使用Livewire构建动态组件?(入门代码)  ChatGPT回答中断怎么办 引导AI继续输出完整内容的方法  Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程  Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧  Android使用GridView实现日历的简单功能  如何在新浪SAE免费搭建个人博客?  ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】  详解MySQL数据库的安装与密码配置  如何彻底删除建站之星生成的Banner?  HTML5打空格有哪些误区_新手常犯的空格使用错误【技巧】  如何做网站制作流程,*游戏网站怎么搭建?  js实现点击每个li节点,都弹出其文本值及修改  js实现获取鼠标当前的位置  Python正则表达式进阶教程_复杂匹配与分组替换解析  大型企业网站制作流程,做网站需要注册公司吗?  Laravel如何使用Vite进行前端资源打包?(配置示例)  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  如何快速使用云服务器搭建个人网站?  香港服务器部署网站为何提示未备案?  Laravel如何处理文件下载请求?(Response示例)