当前位置: 首页 > news >正文

el-dropdown选中效果

vue2版本

<template>
	<el-dropdown size="mini" @command="handleCommand">
        <span class="el-dropdown-link">
        {{ selectedOption }}<i class="el-icon-arrow-down el-icon--right"></i>
        </span>
        <el-dropdown-menu slot="dropdown" placement="top-start">
            <el-dropdown-item v-for="item in options"
                              :command="beforeHandleCommand(item.value, item.label)"
                              :class="{'is-selected' : selectedValue === item.value}"
                              :icon="`${selectedValue === item.value ? 'el-icon-caret-right' : ''}`">{{ item.label }}</el-dropdown-item>
        </el-dropdown-menu>
    </el-dropdown>
</template>

<script>
    export default {
    	data() {
    		return {
            	selectedOption: "全部选项",
			    // 选中的值
			    selectedValue: "a",
                options: [
                    {
                      label: "全部选项",
                      value: "a"
                    },
                    {
                      label: "选项1",
                      value: "b"
                    },
                    {
                      label: "选项2",
                      value: "c"
                    },
                    {
                      label: "选项3",
                      value: "d"
                    }
                  ]
            };
        },
        methods: {
            handleCommand(command) {
              console.log(command);
              this.selectedOption = command.label;
              this.selectedValue = command.value;
              // TODO 获取值进行下一步操作
            },            
            beforeHandleCommand(value, label) {
              return {
                'value': value,
                'label': label
              }
            }
        }
    }
</script>

<style lang="scss" scoped>
    .el-dropdown-link {
      cursor: pointer;
      font-size: 12px;

    }
    .is-selected {
      color: #46A6FF; /* 自定义选中项的颜色 */
      background-color: #E8F4FF; /* 自定义选中项的背景色 */
    }
    .el-dropdown-menu .el-dropdown-menu__item {
      display: flex;
      align-items: center;
      justify-content: flex-end;
      padding: 0 25px 0 10px;
    }
</style>

vue3版本

<template>
	<el-dropdown size="small" placement="bottom-start" popper-class="dropDownStyle" @command="handleCommand">
          <span class="el-dropdown-link">
            {{ selectedOption }}
            <el-icon class="el-icon--right">
              <arrow-down />
            </el-icon>
          </span>
          <template #dropdown>
            <el-dropdown-menu>
              <el-dropdown-item v-for="item in options"
                                :command="beforeHandleCommand(item.value, item.label)"
                                :class="{'is-selected': selectedValue === item.value}"
                                :icon="selectedValue === item.value ? CaretRight : ''">{{ item.label }}</el-dropdown-item>
            </el-dropdown-menu>
          </template>
        </el-dropdown>
</template>

<script setup>
import {
  ArrowDown,
  CaretRight
} from '@element-plus/icons-vue'
const selectedOption = ref("全部选项")
// 选中的值
const selectedValue = ref("a")
// 下拉框数据
const options = [
  {
    label: "全部选项",
    value: "a"
  },
  {
    label: "选项1",
    value: "b"
  },
  {
    label: "选项2",
    value: "c"
  },
  {
    label: "选项3",
    value: "d"
  }
]
const handleCommand = (command) => {
  console.log(command);
  selectedOption.value = command.label;
  selectedValue.value = command.value;
  // TODO 获取值进行下一步操作
}
const beforeHandleCommand = (value, label) => {
  return {
    'value': value,
    'label': label
  }
}
</script>

<style lang="scss" scoped>
.el-dropdown-link {
  cursor: pointer;
  display: flex;
  align-items: center;
  font-size: 12px;
}

:global(.dropDownStyle .is-selected) {
  color: #46A6FF; /* 自定义选中项的颜色 */
  background-color: #E8F4FF; /* 自定义选中项的背景色 */
}

:global(.el-dropdown-menu .el-dropdown-menu__item) {
    display: flex;
    align-items: center;
    justify-content: right;
    padding: 0 20px;
  }    
</style>

效果

注意事项

vue2和vue3有两个地方区别

  • el-dropdown-item里属性icon的写法不同
    • vue2中图标使用了类似 class名称渲染 可以用表达式形式 :icon=“`${selectedValue === item.value ? ‘el-icon-caret-right’ : ‘’}`”
    • vue3中图标直接使用导入的图标名 :icon="selectedValue === item.value ? CaretRight : ''"
    • vue3用vue2的形式不生效
  • 样式使用不同
    • vue2直接定义(在项目中使用,不知道是否因为其他而影响)
    • vue3需要用到:global定义全局样式,这样才能生效。浏览器中通过右键-检查,查看源码得知,el-dropdown-item不在 #app 里,所以定义的样式无效,需要定义全局样式
image-20250219224659127.png

相关文章:

  • 企业内部真题
  • Openssl交叉编译
  • 【深度解析】最短路径算法:Dijkstra与Floyd-Warshall
  • 淘宝/天猫店铺订单数据导出、销售报表设计与数据分析指南
  • 算法-二叉树-判断二叉树是否相等
  • MATLAB学习之旅:从入门到基础实践
  • 面试题汇总
  • 智慧场馆运营系统
  • 分割 学习笔记cvpr2024
  • Linux-GlusterFS操作子卷
  • 多环境日志管理:使用Logback与Logstash集成实现高效日志处理
  • QT 建立一片区域某种颜色
  • 青龙圣者的训练脚本训练 Flux lora
  • 第1章:LangChain4j的聊天与语言模型
  • 05.Docker 容器命令
  • Python正则表达式学习
  • 【力扣Hot 100】栈2
  • 25届国网计算机考试知识难点及习题整理(持续更新)
  • Ubuntu22.04 - gflags的安装和使用
  • Linux 性能调优简单指南
  • 做公众号必备的网站/广东广州重大新闻
  • js做网站登录界面/网络营销有什么特点
  • 重庆网站建设 制作 设计 优惠价/地推团队接单平台
  • 长沙高端网站建设公司/重庆seo招聘
  • 做国际网站需要多少钱/关键词排名优化公司地址
  • 什么叫网站根目录/百度营销推广登录