解决elementui中el-dropdown下拉菜单禁用项没有鼠标悬浮禁用样式

简介: 解决elementui中el-dropdown下拉菜单禁用项没有鼠标悬浮禁用样式

问题描述

饿了么ui中的下拉菜单组件,如果某个下拉菜单被我们禁用了以后,颜色会置灰,点击也没反应了。但是存在的问题就是,当鼠标悬浮到对应的禁用项上面的时候,我们会神奇的发现,居然没出现鼠标禁用的样式,官方给出的竟然还是一个箭头的样式。问题图如下:

图是从官网上截取的

其实并不影响产品的使用,但是有的时候我们想要优化一下效果。使其达到鼠标移入出现禁用样式,如下图,就是我们想要的效果

禁用的时候鼠标悬浮时应为禁用的样式

代码实现

html部分

html部分就是常规操作,给下拉菜单绑定一个点击菜单项触发的事件回调,因为待会我们要点击这个下拉菜单。

<template>
  <div id="app">
    <el-dropdown trigger="click" @command="handleCommand">
      <span class="el-dropdown-link">
        下拉菜单<i class="el-icon-arrow-down el-icon--right"></i>
      </span>
      <el-dropdown-menu slot="dropdown">
        <el-dropdown-item command="沙县小吃">
          沙县小吃
        </el-dropdown-item>
        <el-dropdown-item command="兰州拉面">
          兰州拉面
        </el-dropdown-item>
        <el-dropdown-item command="肉夹馍" disabled>
          肉夹馍
        </el-dropdown-item>
      </el-dropdown-menu>
    </el-dropdown>
  </div>
</template>

css部分

审查禁用菜单项之后的DOM元素样式

pointer-events简介:简而言之给一个DOM元素加上这个语句后,那么这个DOM的点击事件就会失效,就是点击了没反应

解决方案就是我们不使用这个语句了,然后给禁用项加上cursor: not-allowed;就会出现鼠标悬浮禁用样式。

<style lang="less" scoped>
/deep/ .el-dropdown-menu__item.is-disabled {
  pointer-events: auto !important;
  cursor: not-allowed;
}
</style>

不过会产生一个新问题,就是:禁用项的样式虽然是有了,但是禁用项也可以点击了。这个就是不应该的,当然有问题就会有解决方案,我们可以通过js去控制是否可以点击。至于怎么控制,我们先看一下官方文档。

然后我们打印对应的两个参数

如果我们再点击肉夹馍,我们会发现,打印出来的e的内容中的disabled的值就位true,所以发现规律了,就可以做控制了。即为:只有当e.disabled的值为false的时候(说明未被禁用),那么我们才在对应的回调中做相关的事情,否则就忽略

js代码部分

<script>
export default {
  name: "app",
  data() {
    return {};
  },
  methods: {
    handleCommand(whichSelect,e){
      // 必须为禁用才能做一些事情
      if(whichSelect == "沙县小吃" && e.disabled == false){
        console.log("沙县小吃");
      }else if(whichSelect == "兰州拉面" && e.disabled == false){
        console.log("兰州拉面");
      }else if(whichSelect == "肉夹馍" && e.disabled == false){
        console.log("肉夹馍");
      }
    }
  },
};
</script>

总结

经过这样一波操作,就能达到我们想要的效果了。最终效果图示第二张图。

我们程序员,常常是解决了一个问题,又会出现新的问题,但是只要耐心思考,翻阅资料,问题基本上都可以解决的
相关文章
|
7月前
Element UI之el-tabs的样式修改字体颜色、下划线、选中/未选中
Element UI之el-tabs的样式修改字体颜色、下划线、选中/未选中
1617 0
|
7月前
|
前端开发
解决elementUI弹出框关闭后再打开el-select下拉框无法选中的问题
解决elementUI弹出框关闭后再打开el-select下拉框无法选中的问题
174 0
element 下拉菜单el-dropdown如何更改样式?
element 下拉菜单el-dropdown如何更改样式?
997 0
|
3月前
|
前端开发
element菜单组件样式修改NavMenu导航菜单
本文介绍了如何修改Element UI的NavMenu导航菜单组件的样式,包括激活菜单项的颜色、菜单项hover颜色、父级菜单hover颜色以及菜单行高。提供了相应的CSS代码示例,并展示了如何将这些样式应用到实际的NavMenu组件中。
185 3
element菜单组件样式修改NavMenu导航菜单
|
3月前
|
JavaScript
ElementUI的el-dialog弹窗修改设置可拖拽可最大化
该方案通过自定义Vue指令实现ElementUI的`el-dialog`弹窗的拖拽和最大化功能。只需在`main.js`中引入并注册指令,然后在Vue组件中绑定指令即可。支持自定义参数控制是否允许最大化和拖拽,并提供最大化后的回调函数。具体使用方法详见示例代码。
383 0
ElementUI的el-dialog弹窗修改设置可拖拽可最大化
|
5月前
|
数据安全/隐私保护
Element UI 密码输入框--可切换显示隐藏,自定义图标
Element UI 密码输入框--可切换显示隐藏,自定义图标
220 0
|
5月前
Element UI 自定义/修改下拉弹窗的样式(如级联选择器的下拉弹窗样式)
Element UI 自定义/修改下拉弹窗的样式(如级联选择器的下拉弹窗样式)
487 0
|
6月前
|
前端开发 JavaScript
vue+el-select下拉多选实现,全选,反选,清空功能源码
vue+el-select下拉多选实现,全选,反选,清空功能源码
91 0
|
7月前
基于elementUI的el-table组件实现按住某一行数据上下滑动选中/选择或取消选中/选择鼠标经过的行
基于elementUI的el-table组件实现按住某一行数据上下滑动选中/选择或取消选中/选择鼠标经过的行
|
7月前
点击div显示下拉框,然后下拉框中的点击事件不生效。
点击div显示下拉框,然后下拉框中的点击事件不生效。