我就不信ElementPlus 虚拟化选择器不能复制文本?

前言

某一天,产品突然找到我说:你这个选择下拉框,不太行啊。我一听,垂死病中惊坐起!嗯?!用的原原本本的组件,完完全全辛辛苦苦Ctrl+CCtrl+V来的,都没改多少,你竟然说不太行?你这是质疑我饿了么的能力!我要撸起袖子和你理论理论!%......& %......%......&%......&通过一番激烈的辩论,原来是用户要选择文本,我一听,原来如此,小需求,看我的!欣然答应.....然后发现似乎并不是那么回事.....

尝试了一下,按理说,选这个还是挺容易的来着,尝试了一下,嗯,正常的选择器是可以选择文本的,只是选择的同时,会触发一下菜单,但!这问题不大,又不是不能用,让用户兼容一下就好了~

但!我们组件用的是虚拟选择器,哎呀,好烦呐,根本不想换,换起来好麻烦,虚拟选择器就很难受了,如下,根本选不了.....

找了一圈网上的方案,如点击复制啦~,如选择控制啦~window.getSelection()啦~都挺好,不过对于我这个场景没啥用,感觉elmentplus还没有elment成熟,看来害真得自己来了

尝试

首先,想着是用聚焦,失焦的事件控制一下,失败,控制不了,然后,扫了一遍官方提供的属性.....emmm,好像有一个属性有点用------------ automatic-dropdown 用了一下,嗯?怎么就禁用了?文档里也说的不太详细,具体如下

很好,看不太懂,康康源码吧

搜寻一番后,嗷,大概懂嘞,只要这玩意为true,就不让触发菜单了,嘶...我收回之前的话,好像大有可为? 最后,通过控制该属性的变化,我得到了一个可以复制文本的(基本)完美虚拟选择器~如下

ini 复制代码
<script setup lang="ts">
import { ref } from 'vue'
const initials = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j']

const value = ref()
const select = ref()
const options = Array.from({ length: 1000 }).map((_, idx) => ({
  value: `Option ${idx + 1}`,
  label: `${initials[idx % 10]}${idx}`,
}))
const canShowOption = ref(true)
const handelChange = ()=>{
    canShowOption.value = true
}
const handelClick = ()=>{
  if(canShowOption.value){
      canShowOption.value = false
   }
}
</script>

<template>
  <div>
    <!-- <el-button @click="test">1111</el-button> -->
    <el-select-v2
      ref="select"
      v-model="value"
      :options="options"
      @change="handelChange"
      @click="handelClick"
      :automatic-dropdown="canShowOption"
      placeholder="Please select"
      size="large"
    />
  </div>
</template>

为啥说基本完美呢?emmmm,他这个,当选择的值变化的时候,需要双击才能打开下拉菜单,但!我们的用户这么聪明,应该能自己兼容这点小毛病吧?不会吧不会吧,打不开不知道多点几下吗?

完善

行吧,接着改,双击不行,我怎么判断用户是想复制还是想弹菜单啊?今天耶稣来了也......也会告诉我后面的那有个小箭头,就点小箭头下拉,其他的地方继续禁用不就行了?改他!

xml 复制代码
<script setup lang="ts">
import { onMounted, ref } from 'vue'
const initials = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j']

const value = ref()
const select = ref()
const options = Array.from({ length: 1000 }).map((_, idx) => ({
  value: `Option ${idx + 1}`,
  label: `${initials[idx % 10]}${idx}`,
}))
const canShowOption = ref(true)
const handelChange = ()=>{
    canShowOption.value = true
}
onMounted(()=>{
  select.value.$el.querySelector('.el-select-v2__suffix').addEventListener('click',()=>{
    if(canShowOption.value){
        canShowOption.value = false
    }
  })
})
</script>

<template>
  <div>
    <!-- <el-button @click="test">1111</el-button> -->
    <el-select-v2
      ref="select"
      v-model="value"
      :options="options"
      @change="handelChange"
      :automatic-dropdown="canShowOption"
      placeholder="Please select"
      size="large"
    />
  </div>
</template>

效果如下

到这基本这个功能就差不多了,本来还准备调用toggleMenu,但是再监听里直接改变量就似乎达到效果了,emmm,感觉是冒泡那片的问题,看看还有一堆需求堆着,算了,下次一定~ 最后感谢各位大佬阅读,指正!

相关推荐
chenbin___7 分钟前
react native中 createAsyncThunk 的详细说明,及用法示例(转自通义千问)
javascript·react native·react.js
摆烂工程师8 分钟前
(2025年11月)开发了 ChatGPT 导出聊天记录的插件,ChatGPT Free、Plus、Business、Team 等用户都可用
前端·后端·程序员
gongzemin18 分钟前
使用阿里云ECS部署前端应用
前端·vue.js·后端
用户411800341534119 分钟前
Flutter课题汇报
前端
环信22 分钟前
实战教程|快速上线音视频通话:手把手教你实现呼叫与接听全流程
前端
Dgua23 分钟前
✨TypeScript快速入门第一篇:从基础到 any、unknown、never 的实战解析
前端
海云前端123 分钟前
Vue3 大屏项目投屏功能开发:多显示器适配实践
前端
技术小丁39 分钟前
使用 HTML + JavaScript 实现酒店订房日期选择器(附完整源码)
前端·javascript
hashiqimiya40 分钟前
harmonyos的鸿蒙的跳转页面的部署
开发语言·前端·javascript
向日葵同志443301 小时前
使用@univerjs纯前端渲染excel, 显示图片、链接、样式
前端·react.js·excel