Material Design 中使用 Chip 实现标签效果

在现代 Web 设计中,标签成为了一项必备的元素。标签能够提供有用的指示并使内容更易于理解和搜索。Material Design 中,Chip 是一种常用的元素,用于创建小型且易于识别的交互式元素,特别适用于标签和过滤器。

Chip 的基本使用

要在 Material Design 中使用 Chip,你需要使用 mdc-chip 类名和必需的 aria-label 属性来创建一个带有链接效果的 Chip:

-- -------- ---------------- ---------------- ---------
  ---- -------
----

Chip 也可以使用带有脚本动作的 js 来工作。你可以使用 js 对 Chip 进行一些基本的交互,例如添加/删除标记、激活/禁用标记等。

Chip 的不同样式

Material Design 提供了几种不同类型的 Chip 样式,适合不同的设计需要。

线框式

线框式 Chip 在用户点击或激活时展开,相当于传统标签的效果。要创建一个线框式 Chip,请使用 mdc-chip--outlined 类:

-- -------- --------------- ------------------- -------------------- ---- ---------
  -------- ---- -------
----

可删除的

可删除的 Chip 允许用户删除已选择的标记。要创建一个可删除的 Chip,请使用 mdc-chip--delete 类,并在内部添加一个包含删除图标的 <button> 元素:

-- -------- --------------- ------------------ ----------------- --------------------- ---- ---------
  --------- ---- -------
  ------- --------------------- ------------------------ --------------- ------------ -----------------------------
----

多彩样式

如果你想让你的标记看起来更加生动鲜明,可以使用多彩样式。要创建一个多彩样式的 Chip,请使用 mdc-chip--selected 类和一个包含你想要的颜色的自定义样式表:

-- -------- --------------- ------------------- ------------------ ---- ---------
  ------ ---- -------
----
------------------- -
  ----------------- --------
  ------ -----
-

Chip 的其他交互

Chip 还支持其他一些交互。例如,禁用/启用 Chip 的最佳做法是将禁用状态设置为 CSS 类 mdc-chip--disabled

Chip 还接受一些与交互相关的事件,例如clickkeydown 等,这些都可以使用 JavaScript 进行操作。

总结

Chip 是 Material Design 中非常重要的一种元素,特别适合于创建标签和过滤器。你可以根据自己的需要选择不同的样式,从而使 Chip 更加灵活多样。同时,你还需要在 JavaScript 或其他脚本动作中添加交互和事件处理,以实现更多的功能。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/64cddb1cb5eee0b5255cc210


猜你喜欢

  • 使用 ES10 中的 Object.getOwnPropertyDescriptors() 获取对象属性

    引言 ES6 带来了许多 JavaScript 的新功能,更好地控制和管理对象属性是其中的一项重要功能。ES10 中新增了一个方法 Object.getOwnPropertyDescriptors()...

    1 年前
  • 常用的 CSS Reset 方案:Eric Meyer Reset 和 Normalize.css

    CSS Reset 是一种重要的前端技术,它可以帮助我们消除浏览器之间的差异,使页面在不同的浏览器中呈现出一致的样式。在这篇文章中,我们将介绍两种常用的 CSS Reset 方案:Eric Meyer...

    1 年前
  • 在 Angular 2+ 中如何实现路由间的数据共享

    Angular 2+是一个非常强大且流行的前端框架,它提供了很多便利的功能来帮助我们开发Web应用程序。其中,路由是Angular 2+框架中非常重要的一部分,用于处理对不同组件的导航。

    1 年前
  • 在 Cypress 中使用 Node.js API 进行测试用例编写及优化

    前言 Cypress 是一个现代的前端自动化测试工具,其特点是易于使用、高效,并且能够无缝集成到现有的前端开发工作流中。通常情况下,我们使用 Cypress 内置的命令来编写测试用例,但是有时会遇到一...

    1 年前
  • 使用 Mocha 测试 AngularJS 应用程序

    Mocha 是一个 JavaScript 测试框架,可以用来编写自动化测试用例。在前端开发中,Mocha 可以用来测试 AngularJS 应用程序。本文将介绍如何使用 Mocha 进行 Angula...

    1 年前
  • Koa 中使用 async/await 的最佳实践

    在 Node.js 的 web 应用开发领域中,Koa 是一款轻量级的框架,它基于中间件机制实现了 HTTP 请求处理、错误处理、路由等功能。Koa 采用了 JavaScript 中的 async/a...

    1 年前
  • SSE 中使用 Last-Event-ID 解决丢失消息问题

    前言 服务端发送事件(Server-Sent Events,SSE)是一种从服务器到客户端单向的通信技术,也是现代化 Web 应用程序的重要组成部分。SSE 是一种比 WebSocket 更简单、更轻...

    1 年前
  • 如何使用 Headless CMS 快速搭建各类型网站?

    在现代互联网时代,网站的内容和用户体验已经成为了商业成功的关键。而 Headless CMS 成为了为提供内容给各种单页应用、移动应用和 IoT 设备等客户端渠道的最佳解决方案。

    1 年前
  • React 项目如何集成 ESLint?

    什么是 ESLint? ESLint 是一个开源的 JavaScript 语法检测工具,它可以帮助我们在开发过程中找到代码中的潜在问题,从而提高代码质量和开发效率。

    1 年前
  • RESTful API 中正确使用请求头信息的指南

    在开发 RESTful API 中,请求头(request header)是很重要的一部分,它能够帮助开发者正确地处理客户端发送的请求,限制一些不必要的访问,增强 API 的安全性等等。

    1 年前
  • 在 ECMAScript 2015 中使用 Object.assign 简化对象操作

    前言 对象是 JavaScript 编程语言中最基本的数据类型之一,也是前端开发当中最常用的数据类型之一。在 JavaScript 编程中,我们经常需要对对象进行操作和处理。

    1 年前
  • ES7 中新增的 Array.prototype.find 方法使用技巧

    JavaScript 是一种非常强大的语言,但是它的标准总是在不断地发展和更新。在 ES7 中,我们看到了 Array.prototype.find 方法这一重要的新增特性。

    1 年前
  • 使用 Babel 编译 ES2015 的正确姿势

    随着 Web 技术的发展,越来越多的前端开发人员选择使用 ES2015 的新特性来编写代码。由于一些浏览器和旧版 Node.js 不支持这些新特性,开发人员需要使用 Babel 将代码转换为 ES5,...

    1 年前
  • 在 Hapi 中使用 Redis 实现缓存

    概述 在前端领域,缓存技术一直是提高应用性能的重要手段之一。其中,Redis 是一种高性能、内存数据结构存储系统,可以作为缓存使用。而 Hapi 是 Node.js 构建的一款 Web 框架,提供了方...

    1 年前
  • 响应式设计中解决 Safari 中网格布局降级显示问题的方法

    在现代的响应式设计中,网格布局(grid layout)已经成为了一个非常流行的布局方式。它不仅能够帮助开发者快速构建复杂的页面布局,而且还能够让页面适应不同的设备和屏幕大小。

    1 年前
  • Sequelize ORM 中查询多个关联数据表

    Sequelize 是一个基于 Node.js 的 ORM 框架,用于管理 SQL 数据库。它提供了丰富的 API,支持创建、查询、更新和删除数据,同时支持多种数据库的操作。

    1 年前
  • 使用 ES8 的 Rest/Spread 操作符解决数组的处理问题

    在前端开发中,我们经常会遇到需要对数组进行一系列操作的场景。但是,随着业务的复杂度的增加,对数组进行操作的难度也越来越大。为了解决这个问题,ES6引入了Rest/Spread操作符,而在ES8中,Re...

    1 年前
  • 详解 Webpack 中的多种输出方式

    前言 在开发前端项目的过程中,常常需要将多个 JavaScript 文件打包为一个文件便于部署和使用。Webpack 是一个强大的模块打包工具,能够实现一些非常强大的功能,其中包括多种不同的输出方式。

    1 年前
  • TypeScript 中对象的深拷贝实现方法和示例

    什么是深拷贝 深拷贝是指在拷贝一个对象时,不仅仅要拷贝该对象,还要递归地拷贝该对象的所有子对象。这样拷贝出来的对象与原始对象完全独立,修改一个对象不会影响另一个对象。

    1 年前
  • ECMAScript 2020 中的 Promise.allSettled 能力及使用场景

    ECMAScript 2020 中的 Promise.allSettled 能力及使用场景 在现代的 JavaScript 中,Promise 对象已成为非常重要的异步编程方式。

    1 年前

相关推荐

    暂无文章