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

Naive UI 级联选择器 Cascader的:render-lable怎么使用(Vue3 + TS)(鼠标悬停该条数据的时候展示全部内容)

项目场景:

在渲染Cascader级联选择器后,当文字过长的时候,多出来的部分会显示成省略号,这使我们不能很清晰的看到该条数据的完整信息,就需要加一个鼠标悬停展示完整内容。


解决方案:

vue:

<n-cascader clearable v-model:value="unit" placeholder="所属地市" :title="unit" :options="options" check-strategy="child" @update-value="handleUpdateValue" :render-label="renderlabel" />

js:

const unit = ref<string>()
const options = ref<CascaderOption[]>([
    {
      "value": "1",
      "label": "选项1",
      "disabled": false,
      "children": [
        {
          "value": "1-1",
          "label": "子选项1-1",
          "disabled": false,
          "children": [
            {
              "value": "1-1-1",
              "label": "孙选项1-1-1",
              "disabled": false
            }
          ]
        }
      ]
    },
    {
      "value": "2",
      "label": "选项2",
      "disabled": true,
      "children": [
        {
          "value": "2-1",
          "label": "子选项2-1",
          "disabled": false
        }
      ])
//这里其实就是创建了虚拟节点,这里就不赘述了,可以看前两篇笔记,有详细的解释
//这里解释一下 placement: 'left-end'  为什么可以在这里加这句话
//是因为Naive的 弹出提示 Tooltip组件支持placement属性,即popover 的弹出位置,
//我们这里是创建了一个NTooltip弹出提示的虚拟节点,传入的属性必须是这个NTooltip组件支持的属性才可以生效,
//换句话说就是h创建虚拟DOM的第二个参数设置的属性是传递给组件的,
const renderlabel = (option: { value?: string | number, label?: string }) => {
    return h(NTooltip, {
        placement: 'left-end'
    }, {
        trigger: () => h('span', option.label),
        default: () => {
            return h('span', {
                style: {
                    color: '#526ade',
                }
            }, option.label as string)
        },
    })
}
const handleUpdateValue = function (value: string, option: CascaderProps) {
 
}

总结来说,renderLabel 函数创建了一个带有提示的标签,当用户将鼠标悬停在标签上时,会显示一个提示框,提示框的内容和标签文本相同,但颜色可能会根据主题的不同而变化。这个函数通常用于下拉选择框组件中,为每个选项提供一个带有提示的标签。


http://www.kler.cn/a/382215.html

相关文章:

  • python验证码滑块图像识别
  • AI笔筒操作说明及应用场景
  • 实现GUI界面中的logo图片的编码与隐藏
  • QML —— QML调用C++两种方法(附完整测试源码)
  • 使用SQLark如何将Oracle迁移到达梦数据库
  • 金箍棒变化-第15届蓝桥杯国赛Scratch初/中级组真题第1题
  • uni-app跨域set-cookie
  • 算法日记 18 day 二叉树
  • Mysql数据库的UDF提权
  • 小张求职记五
  • 【Qt】QVariant.toString().toStdString().data()
  • 引领汽车行业未来,3D数字化技术如何改变汽车行业?
  • springboot - 定时任务
  • FloodFill 算法 专题
  • 【Excel】区域单元格选择(一)
  • Java的Object类常用的方法(详述版本)
  • 钉钉向广告低头
  • Copy From 勇哥的机器视觉实验项目
  • 使用Jest进行JavaScript单元测试
  • [vulnhub]DC: 5
  • C语言中的结构体详解
  • 使用Python分析股票价格数据并计算移动平均线的实用指南
  • ISO 26262标准下的汽车电子软件开发
  • 对标 Windows Copilot 的 UOS AI,升级后更能打了
  • 2024-11-05 问AI: [AI面试题] 人工智能开发和部署的道德考虑是什么?
  • socket的一些option