【Material-UI】多选模式(Multiple values)与Autocomplete的高级用法解析

news2025/1/12 19:53:56

文章目录

    • 一、多选模式的基本用法
    • 二、高级用法
      • 1. 固定选项(Fixed options)
      • 2. 复选框(Checkboxes)
      • 3. 限制标签显示数量(Limit tags)
    • 三、性能优化与最佳实践
      • 1. 筛选已选项(filterSelectedOptions)
      • 2. 只读模式(readOnly)
    • 四、总结

在现代Web应用中,多选功能常被用于标签(tags)管理、选择多个偏好项等场景。Material-UI的Autocomplete组件提供了强大的多选功能,使用户能够轻松选择多个值。本文将详细介绍如何使用Autocomplete的多选模式,包括固定标签、复选框、限制标签数量等高级用法。

一、多选模式的基本用法

Autocomplete组件中启用多选模式非常简单,只需设置multiple属性为true。这样,用户就可以选择多个选项,这些选项会以标签的形式显示在输入框中。

示例代码

import React from 'react';
import Autocomplete from '@mui/material/Autocomplete';
import TextField from '@mui/material/TextField';

const top100Films = [
  { title: 'The Shawshank Redemption', year: 1994 },
  { title: 'The Godfather', year: 1972 },
  { title: 'The Dark Knight', year: 2008 },
  // 更多电影数据...
];

function MultipleAutocomplete() {
  return (
    <Autocomplete
      multiple
      options={top100Films}
      getOptionLabel={(option) => option.title}
      renderInput={(params) => <TextField {...params} label="Favorites" placeholder="Select movies" />}
    />
  );
}

export default MultipleAutocomplete;

在上述代码中,我们通过multiple属性启用了多选模式,options属性提供了可选项数据,而getOptionLabel属性用于指定选项的显示文本。

二、高级用法

1. 固定选项(Fixed options)

在某些情况下,可能需要一些标签始终存在且不可移除。我们可以通过设置选项的disabled属性来实现这一功能。例如,可以将某些选项设为“固定标签”,用户不能删除它们。

示例代码

<Autocomplete
  multiple
  options={top100Films}
  getOptionLabel={(option) => option.title}
  defaultValue={[top100Films[0], top100Films[1]]}
  renderInput={(params) => <TextField {...params} label="Fixed tag" />}
  renderTags={(value, getTagProps) =>
    value.map((option, index) => (
      <Chip
        label={option.title}
        {...getTagProps({ index })}
        disabled={index === 0} // 第一个标签为固定标签
      />
    ))
  }
/>

在这个例子中,第一个标签被设置为disabled,用户无法删除该标签。

2. 复选框(Checkboxes)

在多选模式下,复选框可以用来明确表示选项是否被选中。通过使用Checkbox组件,可以实现这一功能,使得用户体验更加直观。

示例代码

import Checkbox from '@mui/material/Checkbox';

<Autocomplete
  multiple
  options={top100Films}
  disableCloseOnSelect
  getOptionLabel={(option) => option.title}
  renderOption={(props, option, { selected }) => (
    <li {...props}>
      <Checkbox
        icon={icon}
        checkedIcon={checkedIcon}
        style={{ marginRight: 8 }}
        checked={selected}
      />
      {option.title}
    </li>
  )}
  renderInput={(params) => <TextField {...params} label="Favorites" placeholder="Select movies" />}
/>

在这个示例中,我们使用renderOption属性自定义了每个选项的渲染,加入了Checkbox组件以显示选中状态。

3. 限制标签显示数量(Limit tags)

在多选模式下,如果选中的选项很多,可能会导致输入框变得混乱。limitTags属性允许我们限制在输入框中显示的标签数量,当超过该数量时,其他标签会以“+N”的形式显示。

示例代码

<Autocomplete
  multiple
  limitTags={2}
  options={top100Films}
  getOptionLabel={(option) => option.title}
  defaultValue={[top100Films[13], top100Films[12], top100Films[11]]}
  renderInput={(params) => <TextField {...params} label="limitTags" placeholder="Favorites" />}
  sx={{ width: '500px' }}
/>

在这个示例中,我们将limitTags设置为2,因此当选中的标签超过两个时,额外的标签会被隐藏,并显示为“+N”的形式。

三、性能优化与最佳实践

1. 筛选已选项(filterSelectedOptions)

在多选模式下,如果选项非常多,可以使用filterSelectedOptions属性来隐藏已选中的选项,防止用户重复选择。这在数据量大且选项不需要重复选择的场景中特别有用。

2. 只读模式(readOnly)

在某些情况下,我们可能需要将多选输入框设置为只读模式,以防止用户编辑已选择的标签。可以通过设置readOnly属性实现这一功能。

示例代码

<Autocomplete
  multiple
  options={top100Films}
  readOnly
  value={[top100Films[0], top100Films[1]]}
  getOptionLabel={(option) => option.title}
  renderInput={(params) => <TextField {...params} label="Read-only" />}
  sx={{ width: '500px' }}
/>

四、总结

Material-UI的Autocomplete组件提供了强大而灵活的多选功能,使得复杂的数据选择和标签管理变得更加简单。无论是固定选项、复选框还是限制标签显示数量,这些功能都极大地提升了用户体验。在实际应用中,根据具体需求选择合适的属性和配置,可以让多选功能更好地服务于用户。

希望本文能帮助您深入了解Autocomplete的多选模式,并在您的项目中充分利用这些功能。如果您有任何问题或进一步的探讨,欢迎留言交流。

推荐:

  • JavaScript
  • react
  • vue

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1980269.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Scratch的下载与安装

如果你在某搜索引擎用这个&#xff0c;就是离被骗钱不远了 添加图片注释&#xff0c;不超过 140 字&#xff08;可选&#xff09; 废话不多说&#xff0c;直接放软件安装包。重要的事情说三遍&#xff0c;收费的全是骗人的&#xff01;收费的全是骗人的&#xff01;收费的全是…

【C++题解】1015. 鸡兔同笼问题

欢迎关注本专栏《C从零基础到信奥赛入门级&#xff08;CSP-J&#xff09;》 问题&#xff1a;1015. 鸡兔同笼问题 类型&#xff1a;简单穷举 题目描述&#xff1a; 鸡兔同笼问题&#xff1a;一个笼子里面有鸡若干只&#xff0c;兔若干只。共有头 50 个&#xff0c;共有腿 16…

C语言的回调函数(详解qsort函数)

在上一篇文章中我们学习了指针与数组之间的关系&#xff0c;学习了指针数组&#xff0c;数组指针变量&#xff0c;函数指针变量和函数指针数组。那么接下来我们要学习的是一个利用函数指针变量去解决和简化各种问题的回调函数。 一、回调函数 回调函数在编程中是一种很常见的…

pip install -r requirements.txt下载某个.whl文件较慢的问题

访问PYPI官网。搜索该文件名字 如果不是自己要的版本&#xff0c;点击左边的Release history。 选择版本后再次在Download files页面下载.whl文件 下载完之后切换至自己的项目解释器虚拟环境。 python -m pip install 文件名.whl 如果你改名python.exe为python3.exe&#xff…

【消息队列】RabbitMQ 面试篇

&#x1f397;️ 主页&#xff1a;小夜时雨 &#x1f397;️专栏&#xff1a;消息队列 &#x1f397;️如何活着&#xff0c;是我找寻的方向 目录 1. RabbitMQ 有哪些工作模式&#xff1f;2. 如何保证消息不丢失&#xff08;可靠性&#xff09;3. 什么是死信队列&#xff0c;如…

基于K210智能人脸识别+车牌识别系统(完整工程资料源码)

运行效果&#xff1a; 基于K210的智能人脸与车牌识别系统工程 目录&#xff1a; 运行效果&#xff1a; 目录&#xff1a; 前言&#xff1a; 一、国内外研究现状与发展趋势 二、相关技术基础 2.1 人脸识别技术 2.2 车牌识别技术 三、智能小区门禁系统设计 3.1 系统设计方案 3.2 …

【网络编程】网络原理(一)

系列文章目录 1、 初识网络 2、网络编程的基础使用&#xff08;一&#xff09; 文章目录 系列文章目录前言一、端口号的使用二、UDP报文学习1.报文格式2.MD5算法 总结 前言 在前文中&#xff0c;主要对UDP和TCP协议有了简单的了解&#xff0c;而这两种协议是负责传输层的内容…

组件设计原则

state数据结构设计 用数据描述所有内容数据要结构化&#xff0c;易于程序操作&#xff08;遍历、查找&#xff09;数据要可扩展&#xff0c;以便增加新的功能 组件设计组件通讯 从功能上拆分层次尽量让组件原子化容器组件&#xff08;只管理数据&#xff09;& UI组件&am…

【MySQL】库操作,数据类型

目录 MySQL简介SQL语句分类库操作语句展示数据库创建数据库使用数据库删除数据库 数据类型整型浮点型字符串日期类型 MySQL简介 数据库有关系型数据库和非关系型数据库。 关系型数据库&#xff1a;是指采用了关系模型来组织数据的数据库。 简单来说&#xff0c;关系模型指的就…

科普文:JUC系列之ConcurrentLinkedQueue非阻塞队列用法

概叙 **Queue接口与List、Set同一级别&#xff0c;都是继承了Collection接口**。队列是一种数据结构&#xff0e;它有两个基本操作&#xff1a;在队列尾部加人一个元素&#xff0c;和从队列头部移除一个元素&#xff0c;队列以一种先进先出的方式管理数据。 队列分为两种&#…

pikachu漏洞平台~文件包含漏洞

在PHP程序中使用文件包含的对象可以被前端的用户控制且没有经过过滤或严格的定义&#xff0c;用户可以将其他的文件作为参数带入到PHP代码中解释执行&#xff0c;从而造成敏感信息泄露/程序文件读取/GetShell等危害的漏洞。 0x01文件包含漏洞 连接成功&#xff0c;完毕&#x…

聚焦IOC容器刷新环节postProcessBeanFactory(BeanFactory后置处理)专项

目录 一、IOC容器的刷新环节快速回顾 二、postProcessBeanFactory源码展示分析 &#xff08;一&#xff09;模版方法postProcessBeanFactory &#xff08;二&#xff09;AnnotationConfigServletWebServerApplicationContext 调用父类的 postProcessBeanFactory 包扫描 …

oracle(19c)用户管理

简介 本文介绍 Oracle 中的用户管理&#xff0c;包含以下内容&#xff1a; 概念介绍 系统用户 解锁 hr 用户 创建用户 用户相关案例 使用 Profile 管理用户口令 Oracle 的认证方式 重置管理员(sys)密码 1. 概念介绍 使用前可以自行安装oracle数据库 oracle19c安装&a…

【系统架构设计师】二十四、安全架构设计理论与实践④

目录 六、数据库系统的安全设计 6.1 数据库的完整性设计 6.1.1 数据库完整性设计原则 6.1.2 数据库完整性的作用 6.1.3 数据库完整性设计示例 七、系统架构的脆弱性分析 7.1 软件脆弱性的特点和分类 7.2 软件脆弱性的生命周期 7.2.1 脆弱性的引入阶段 7.2.2 产生破坏…

pythonflaskMYSQL自驾游搜索系统32127-计算机毕业设计项目选题推荐(附源码)

目 录 摘要 1 绪论 1.1研究背景 1.2爬虫技术 1.3flask框架介绍 2 1.4论文结构与章节安排 3 2 自驾游搜索系统分析 4 2.1 可行性分析 4 2.2 系统流程分析 4 2.2.1数据增加流程 5 2.3.2数据修改流程 5 2.3.3数据删除流程 5 2.3 系统功能分析 5 2.3.1 功能性分析 6 2.3.2 非功…

C++初阶学习——探索STL奥秘——模拟实现string类

1、string类的构造 上面的代码从表面看没什么问题&#xff0c;但是运行后会发现程序有多处bug 但是如上图一样&#xff0c;这样改进依然有bug 因为我们编写无参构造函数的时候&#xff0c;肯定要让_str默认为nullptr&#xff0c;但是这样的话&#xff0c;在main函数中创建对象…

使用npm全局安装typescript

查看npm安装 npm -v 安装typescript npm i -g typescript 查看安装 tsc 这就是标致着安装完成。

uBlock Origin很快将无法在Chrome上使用 开发者发布情况说明

Chrome v127 版开始扩展程序页面将自动显示即将不再支持的扩展程序&#xff0c;包括知名的广告拦截扩展程序 uBlock Origin 也在谷歌的警告列表中。昨天 uBO 团队发布新的支持文档对目前的情况进行说明&#xff0c;简单来说就是 Chrome 将不再支持基于 Manifest v2 开发的扩展程…

【设计模式入门】设计模式全解析:23种经典模式介绍与评级指南(设计师必备)

文章目录 设计模式简介引言七项基本原则创建型模式单例模式&#xff08;Singleton&#xff09;工厂方法模式&#xff08;Factory Method&#xff09;抽象工厂模式&#xff08;Abstract Factory&#xff09;建造者模式&#xff08;Builder&#xff09;原型模式&#xff08;Proto…

文件夹图标变白色无法打开:高效数据恢复指南

在日常使用电脑的过程中&#xff0c;我们可能会遇到一种令人困扰的情况——文件夹图标突然变成白色且无法正常打开。这一现象不仅影响了文件管理的便捷性&#xff0c;还可能意味着重要数据的丢失风险。本文将深入探讨这一现象的原因&#xff0c;并提供一种专业且高效的数据恢复…