Material Design 风格的 CSS 按钮集

Material Design 是 Google 设计的一种界面设计语言,广泛应用于各种应用和网站的设计中。其中,按钮是页面中常用的交互元素之一,因此设计出好看且易用的按钮显得尤为重要。在本文中,我们将介绍一系列 Material Design 风格的 CSS 按钮,帮助前端开发者设计出优秀的按钮。

基础按钮

代码:

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

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

效果如下:

这是一个简单的平面风格按钮,应用了 Material Design 中的基础元素。我们使用了统一的字体、字号、颜色和阴影来体现视觉层次感和设计一致性。按钮具有响应式能力,使得按钮在鼠标悬浮时可以产生动态阴影效果。

透明按钮

代码:

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

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

效果如下:

透明按钮与基础按钮相比区别在于颜色和阴影。为了使按钮整体体现扁平化风格,我们将按钮背景色设为透明。边框及文字颜色为 Material Design 中的标准颜色,使按钮在透明的幕布上非常显眼。

文字按钮

代码:

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

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

效果如下:

文字按钮采用了类似于链接的形式,使按钮看上去更加的轻盈。同样采用了标准颜色,辅之以松散的静态阴影,并在鼠标悬浮时增加灵动的动态效果。

圆形按钮

代码:

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

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

效果如下:

圆形按钮是 Material Design 中常用的一种形式,具有简明易懂的视觉效果。我们切换了形状和字号,同时使按钮颜色更亮眼,以用于各种重要的场合。按钮还采用了动态阴影以增加交互体验。

带图标的按钮

代码:

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

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

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

效果如下:

带图标的按钮是一种常见的形式,常常应用于导航和特定操作。我们在按钮内嵌入了 Material Design 风格的图标,并根据图标形状和字号适当调整按钮的大小。同样,按钮扁平化,具有响应式能力,并在悬浮时产生动态阴影。

按钮组

代码:

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

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

效果如下:

按钮组是由多个按钮按照一定布局方式组合而成的。我们可以利用 CSS 中的 Flexbox 布局技术轻松实现这种布局方式。在按钮组中,我们增加了一个 .btn-active 类表示按钮组的默认状态。在这个例子中,我们将第一个按钮作为默认处于激活状态的按钮,使用绿色背景色的方式来凸显它。

总结

本文展示了六个 Material Design 风格的按钮样式,可以供开发者们使用或参考,并依据实际需要进行定制。同时,我们通过这些按钮样式的设计与实现,可以学习到如何通过响应式设计、阴影、颜色搭配以及图标等元素来打造一个好看且易用的按钮。希望这些样式能够对你的前端开发工作有所帮助。

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


猜你喜欢

  • GraphQL 中如何处理时间日期数据

    前言 在客户端和服务器端之间传输数据的过程中,时间和日期数据属于比较常用的数据类型。在 GraphQL 中如何处理这些数据呢?本文将会为大家介绍 GraphQL 中如何处理时间日期数据。

    1 年前
  • 无障碍场景下 MacOS 下的 WebView 事件处理

    随着计算机在社会和生活中的广泛应用,无障碍技术也成为了我们不可忽视的重要方面。在传统的桌面应用程序中,我们通常使用鼠标和键盘来与用户进行交互,但是对于一些身体残障的用户,使用鼠标和键盘操作可能会带来困...

    1 年前
  • Serverless 架构下的全栈可视化

    Serverless 架构是一种新兴的云计算架构模式,也是近年来云计算领域的热门话题之一。其特点在于摒弃了传统的服务器模式,利用云厂商的服务器资源和服务,实现快速部署、弹性伸缩以及按需计费等优势。

    1 年前
  • 如何使用 ES6 中的生成器函数处理异步流程

    JavaScript 中的异步编程是一个非常重要的主题,在前端开发中尤为重要。ES6 中的生成器函数为我们处理异步流程提供了一种更加优雅的方式。 什么是生成器函数 生成器函数是 ES6 中引入的新语法...

    1 年前
  • 在 Jest 配置表中设置 Typescript

    什么是 Jest? Jest 是 Facebook 开发的 Javascript 测试框架,在前端开发中被广泛使用。 Jest 作为一款测试框架的魅力在于它的速度和开箱即用的能力。

    1 年前
  • 基于 Material Design 的手机版博客设计方案

    近年来,随着移动互联网的兴起,移动设备的使用越来越普及。因此,设计一款适用于手机设备的博客成为了很多网站开发者的目标。而在这样的需求下,Material Design 设计理念成为一种很好的选择,因为...

    1 年前
  • 利用 Tailwind CSS 实现不同状态下的样式切换的技巧

    Tailwind CSS 是一种基于类名的 CSS 框架,它提供了丰富的样式类来帮助开发者快速构建美观的界面。在实际项目开发中,我们经常需要根据不同的状态(如 hover、active、focus 等...

    1 年前
  • PM2 如何实现应用的自动重启

    当我们运行一个 Node.js 应用程序时,如果出现了一些错误,可能会导致程序崩溃。我们需要手动重启应用来恢复服务,这会带来一些不必要的麻烦和延迟。PM2 可以帮助我们实现应用的自动重启,让我们的应用...

    1 年前
  • Cypress 自动化测试实践:如何使用 Docker 优化测试环境

    前端自动化测试在日常开发中变得越来越重要。Cypress 是一款目前非常流行的自动化测试框架,它具有可靠性、快速性和易用性,可以让我们的测试变得更加高效和简单。但是,对于大型项目或者团队合作,测试环境...

    1 年前
  • 在 PWA 应用中如何使用 Fetch API 进行数据获取

    在 PWA 应用中如何使用 Fetch API 进行数据获取 1. 引言 随着移动互联网的普及,PWA 作为一种新型的 Web 应用模式,已经成为了前端开发的热门话题。

    1 年前
  • ES7 中的 Generator 函数

    Generator 函数是 ES6 中新加入的一个重要特性,其基本概念是用于生成 Iterator 的一种新型函数,而在 ES7 中,Generator 函数又进一步完善和加强了。

    1 年前
  • Enzyme: Java 开发中的生物信息学基础

    什么是 Enzyme Enzyme 是一款生物信息学工具,可以用于在 DNA 序列数据上进行各种操作,包括读取、修改、分析和比较等。在 Java 开发中,Enzyme 是一个非常实用的工具库,它提供了...

    1 年前
  • 将 Koa 部署到 Nginx 上的完整脚本

    Koa 是一个基于 Node.js 的 Web 开发框架,提供了一个简洁高效的基础框架,可以帮助开发者快速搭建 Web 应用程序。在实际项目中,我们经常需要将 Koa 应用程序部署到 Nginx 上,...

    1 年前
  • 使用 Babel 和 Webpack 开发 Angular2 应用

    在现代前端开发中,Babel 和 Webpack 都是非常常见的工具。Babel 可以让你使用最新的 JavaScript 语言特性,而 Webpack 可以自动化打包、优化和压缩你的代码。

    1 年前
  • CSS Flexbox 实现流式布局方案

    什么是流式布局? 流式布局又称为响应式布局,是指随着屏幕尺寸的变化,网页内容会自动的调整布局以适应不同设备的展示。流式布局是现代 Web 设计必不可少的技术,因为人们现在使用各种不同的设备来访问网站,...

    1 年前
  • 优化 Angular 应用的性能:RxJS 中的细节

    RxJS 是 Angular 框架中的一个核心库,它提供了强大的响应式编程能力,使得我们可以更加快速和高效的编写前端应用。然而,在实际的项目中,我们常常会面临性能问题,造成应用的卡顿和响应变慢,这时候...

    1 年前
  • 使用 Mocha 和 SuperTest 进行接口自动化测试

    随着前端开发的不断发展,现代化的Web应用程序架构变得越来越复杂。在开发过程中,无论您是在开发单页面应用,还是传统的多页面应用程序,都必须确保API接口的可靠性和正确性,以及客户端与服务端的协调配合。

    1 年前
  • Mongoose 中的 Embeds 和 Refs 使用技巧

    前言 Mongoose 是一个 MongoDB 处理库,它提供了一种简单的方式,来为你的应用创建数据库模型。Mongoose 支持多种数据类型,其中包括嵌套的数据类型。

    1 年前
  • 如何在 Redux 中实现请求 OAuth 数据的最佳实践

    OAuth 是一种授权机制,用于允许一个应用程序访问另一个应用程序的用户数据。在前端应用程序中,我们通常会使用 OAuth 作为用户身份验证和访问授权的一种方式,以访问第三方 API。

    1 年前
  • Socket.io 如何使用 websocket 代替 polling 传输方式

    前言 在前端开发过程中,我们经常需要使用实时通信(Real-Time Communication,简称 RTC)功能,比如与服务器进行双向数据传输。而传统的轮询(polling)方式虽然能够实现实时通...

    1 年前

相关推荐

    暂无文章