”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 每个 UI 开发人员都应该知道的聪明的 CSS 行话

每个 UI 开发人员都应该知道的聪明的 CSS 行话

发布于2024-11-02
浏览:579

Clever CSS One-Liners Every UI Developer Should Know

简介:简洁 CSS 的力量

作为一名 UI 开发人员,您总是在寻找简化代码并创建更高效​​、更引人注目的设计的方法。 CSS(层叠样式表)是您的武器库中的基本工具,掌握它可以显着提高您的生产力和工作质量。在这篇博文中,我们将探索 15 个独特的 CSS 行话,它们可以彻底改变您设计网页的方法。

这些紧凑的 CSS 技巧不仅可以节省时间,而且还展示了 CSS 的多功能性和强大功能。无论您是经验丰富的专业人士还是刚刚开始 UI 开发之旅,这些俏皮话都将为您的技能组合增添价值,并帮助您用更少的代码创建更精美、响应更快的设计。

让我们深入研究这些 CSS gem,看看它们如何改变您的开发过程!

1. 完美的对中技术

网页设计中最常见的挑战之一是将元素水平和垂直居中。这是一个 CSS 单行代码,可以轻松实现这一点:

.center {
  display: grid; place-items: center;
}

这个简单而强大的 CSS 技巧使用 CSS 网格将任何子元素置于其父容器中。 display: grid 属性创建一个网格容器,而 place-items: center 将网格项(在本例中为子元素)水平和垂直对齐在中心。

此方法适用于容器内的单个元素和多个元素。这是一个多功能的解决方案,可以让您免于为不同场景编写复杂的居中代码。

2. 响应式文本大小调整变得简单

创建响应式排版可能是一项挑战,但这个 CSS 一行代码使它变得轻而易举:

body {
  font-size: calc(1rem   0.5vw);
}

这种 calc() 函数的巧妙使用结合了基本字体大小 (1rem) 和视口宽度相关值 (0.5vw)。随着视口宽度的变化,字体大小也会相应调整,确保您的文本在不同的屏幕尺寸上仍然可读。

这种方法的优点在于它的简单性和灵活性。您可以通过修改计算中的值轻松调整基本尺寸和变化率。

3. 自定义滚动条样式

自定义滚动条可以为您的网站设计增添独特的风格。这是一个单行代码,允许您在基于 webkit 的浏览器中设置滚动条的样式:

::-webkit-scrollbar { width: 10px; background: #f1f1f1; border-radius: 10px; }

此 CSS 技巧针对 webkit 浏览器(如 Chrome 和 Safari)中的滚动条伪元素。您可以调整宽度、背景颜色和边框半径以符合您的设计偏好。虽然这不适用于所有浏览器,但对于支持它的浏览器来说这是一个很好的增强。

4. 创建截断文本效果

处理动态内容时,经常需要截断超过一定长度的文本。这个CSS单行代码为溢出的文本创建了省略号效果:

.truncate {
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

这种属性组合可确保文本保持在单行上(white-space: nowrap),隐藏任何溢出(overflow: hide),并在截断文本的末尾添加省略号 (...) (文本溢出:省略号)。

5.整个页面平滑滚动

实现平滑滚动可以极大地增强网站的用户体验。这是一个简单的 CSS 单行代码,可实现整个页面的平滑滚动:

html {
  scroll-behavior: smooth;
}

此属性可确保当用户单击页面中的锚链接时,浏览器平滑滚动到目标部分,而不是突然跳转。这是一个小小的改变,可以显着提高您网站的感知质量。

6. 创建响应式正方形

创建保持纵横比的完美方形元素可能很棘手,尤其是在响应式布局中。这是一个巧妙的 CSS 技巧来实现这一点:

.square {
  width: 50%; aspect-ratio: 1;
}

纵横比属性确保元素的高度始终与其宽度相匹配,从而创建一个完美的正方形。您可以根据需要调整宽度百分比,并且元素将在不同的屏幕尺寸上保持其正方形形状。

7. 自定义文本选择样式

自定义所选文本的外观可以为您的网站添加独特的风格。这是一个 CSS 语句来实现这一点:

::selection { background: #ffb7b7; color: #000000; }

这个 CSS 技巧允许您更改网站上所选文本的背景颜色和文本颜色。您可以调整颜色以匹配您网站的配色方案,从而创建有凝聚力的品牌体验。

8. 轻松切换深色模式

为您的网站实施深色模式可以改善用户体验,尤其是对于夜间浏览的用户。这是一个简单的基于 CSS 变量的方法:

body {
  --text-color: #333; --bg-color: #fff;
}
@media (prefers-color-scheme: dark) {
  body { --text-color: #fff; --bg-color: #333; }
}

此 CSS 技巧使用 CSS 变量来定义颜色,并使用媒体查询来检测用户的配色方案偏好。然后,您可以在整个 CSS 中使用这些变量来轻松在浅色和深色模式之间切换。

9. 创建毛玻璃效果

磨砂玻璃效果,也称为玻璃形态,在 UI 设计中越来越流行。下面是一个 CSS 语句来创建这种效果:

.frosted-glass {
  backdrop-filter: blur(10px); background-color: rgba(255, 255, 255, 0.5);
}

背景滤镜和半透明背景颜色的组合创造了美丽的磨砂玻璃效果。您可以调整模糊量和背景不透明度以获得所需的外观。

10.完美的圆角

为不同尺寸的元素创建完美的圆角可能具有挑战性。这是一个 CSS 技巧,可确保您的元素始终具有完美的圆角:

.round {
  border-radius: 9999px;
}

通过为 border-radius 设置一个非常大的值,可以确保角始终尽可能圆,无论元素的大小如何。这对于按钮、徽章或任何您想要一致圆角的元素特别有用。

11.简单的 CSS 网格布局

使用 CSS 网格创建复杂的布局并不一定很复杂。这是设置响应式网格的一行:

.grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

这个 CSS 技巧创建了一个网格,其中的列自动调整以适应可用空间。 minmax() 函数确保列的宽度至少为 200 像素,但可以增长以填充可用空间。这将使用最少的代码创建响应式布局。

12.流体版式

使用 CSS 单行代码可以创建在不同屏幕尺寸上平滑缩放的版式:

h1 {
  font-size: clamp(2rem, 5vw, 5rem);
}

clamp() 函数允许您设置文本的最小尺寸 (2rem)、首选尺寸 (5vw) 和最大尺寸 (5rem)。这可确保您的排版在所有设备尺寸上保持可读性和视觉吸引力。

13. 使用 CSS 创建三角形

有时您需要为 UI 元素创建简单的形状,例如三角形。这是一个用于创建三角形的 CSS 单行代码:

.triangle {
  width: 0; height: 0; border-left: 50px solid transparent; border-right: 50px solid transparent; border-bottom: 100px solid #333;
}

这个 CSS 技巧使用边框属性来创建三角形。通过调整边框宽度和颜色,您可以创建指向不同方向的三角形。

14.全出血布局

创建全出血布局,其中一些元素延伸到视口的边缘,而主要内容保持居中,可以使用以下 CSS 来实现:

.full-bleed {
  width: 100vw; margin-left: calc(50% - 50vw);
}

这个 CSS 技巧计算将元素扩展到视口的整个宽度所需的负边距,而不管父容器的宽度如何。它对于在受限布局内创建沉浸式背景部分或全角图像特别有用。

15.动画渐变背景

添加微妙的动画渐变背景可以为您的设计带来活力。下面是一个 CSS 语句来创建这种效果:

.animated-gradient {
  background: linear-gradient(270deg, #ff7e5f, #feb47b); background-size: 400% 400%; animation: gradient 15s ease infinite;
}
@keyframes gradient { 0% {background-position: 0% 50%} 50% {background-position: 100% 50%} 100% {background-position: 0% 50%} }

This CSS trick creates a gradient background that smoothly animates between colors. You can adjust the colors, animation duration, and easing function to suit your design needs.

结论:提升你的 CSS 游戏水平

这 15 个 CSS 行话展示了 CSS 在创建高效、响应灵敏且具有视觉吸引力的设计方面的强大功能和灵活性。通过将这些技巧融入您的工作流程中,您可以:

  1. 简化您的代码,使其更易于维护且更易于阅读。
  2. 通过优雅、简洁的解决方案解决常见的设计挑战。
  3. 通过流畅的动画和响应式布局增强用户体验。
  4. 以最小的努力创建更精美、更专业的界面。

请记住,掌握 CSS 的关键不仅仅是了解这些技巧,而是了解如何以及何时应用它们。当您将这些技术融入您的项目时,您将对 CSS 的功能以及它如何改变您的 UI 开发方法有更深入的了解。

不断尝试,保持好奇心,不要害怕突破 CSS 的可能性界限。您练习和探索的越多,您就会越熟练地创建令人惊叹、高效的网页设计。

这句话完美地概括了这些 CSS 俏皮话的精髓。他们证明,有时,最强大的解决方案也是最简单的。

当您继续作为 UI 开发人员的旅程时,请将这些 CSS 技巧保留在您的工具包中,但也要保持开放的心态,学习新技术并及时了解最新的 CSS 功能和最佳实践。 Web 开发的世界在不断发展,保持领先地位将确保您继续创建尖端、高效且美观的用户界面。

祝您编码愉快,愿您的 CSS 始终清晰、干净、聪明!

版本声明 本文转载于:https://dev.to/nnnirajn/15-clever-css-one-liners-every-ui-developer-should-know-50g7?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 大批
    大批
    [2 数组是对象,因此它们在JS中也具有方法。 切片(开始):在新数组中提取部分数组,而无需突变原始数组。 令ARR = ['a','b','c','d','e']; // USECASE:提取直到索引作...
    编程 发布于2025-04-17
  • 如何使用不同数量列的联合数据库表?
    如何使用不同数量列的联合数据库表?
    合并列数不同的表 当尝试合并列数不同的数据库表时,可能会遇到挑战。一种直接的方法是在列数较少的表中,为缺失的列追加空值。 例如,考虑两个表,表 A 和表 B,其中表 A 的列数多于表 B。为了合并这些表,同时处理表 B 中缺失的列,请按照以下步骤操作: 确定表 B 中缺失的列,并将它们添加到表的末...
    编程 发布于2025-04-17
  • JavaScript计算两个日期之间天数的方法
    JavaScript计算两个日期之间天数的方法
    How to Calculate the Difference Between Dates in JavascriptAs you attempt to determine the difference between two dates in Javascript, consider this s...
    编程 发布于2025-04-17
  • 为什么我在Silverlight Linq查询中获得“无法找到查询模式的实现”错误?
    为什么我在Silverlight Linq查询中获得“无法找到查询模式的实现”错误?
    查询模式实现缺失:解决“无法找到”错误在Silverlight应用程序中,尝试使用LINQ建立LINQ连接以错误而实现的数据库”,无法找到查询模式的实现。”当省略LINQ名称空间或查询类型缺少IEnumerable 实现时,通常会发生此错误。 解决问题来验证该类型的质量是至关重要的。在此特定实例中...
    编程 发布于2025-04-17
  • 在GO中构造SQL查询时,如何安全地加入文本和值?
    在GO中构造SQL查询时,如何安全地加入文本和值?
    在go中构造文本sql查询时,在go sql queries 中,在使用conting and contement和contement consem per时,尤其是在使用integer per当per当per时,per per per当per. [&​​&&&&&&&&&&&&&&&默元组方法在...
    编程 发布于2025-04-17
  • 如何将PANDAS DataFrame列转换为DateTime格式并按日期过滤?
    如何将PANDAS DataFrame列转换为DateTime格式并按日期过滤?
    Transform Pandas DataFrame Column to DateTime FormatScenario:Data within a Pandas DataFrame often exists in various formats, including strings.使用时间数据时...
    编程 发布于2025-04-17
  • 在Java中使用for-to-loop和迭代器进行收集遍历之间是否存在性能差异?
    在Java中使用for-to-loop和迭代器进行收集遍历之间是否存在性能差异?
    For Each Loop vs. Iterator: Efficiency in Collection TraversalIntroductionWhen traversing a collection in Java, the choice arises between using a for-...
    编程 发布于2025-04-17
  • 如何从PHP中的Unicode字符串中有效地产生对URL友好的sl。
    如何从PHP中的Unicode字符串中有效地产生对URL友好的sl。
    为有效的slug生成首先,该函数用指定的分隔符替换所有非字母或数字字符。此步骤可确保slug遵守URL惯例。随后,它采用ICONV函数将文本简化为us-ascii兼容格式,从而允许更广泛的字符集合兼容性。接下来,该函数使用正则表达式删除了不需要的字符,例如特殊字符和空格。此步骤可确保slug仅包含...
    编程 发布于2025-04-17
  • 如何使用Python有效地以相反顺序读取大型文件?
    如何使用Python有效地以相反顺序读取大型文件?
    在python 反向行读取器生成器 == ord('\ n'): 缓冲区=缓冲区[:-1] 剩余_size- = buf_size lines = buffer.split('\ n'....
    编程 发布于2025-04-17
  • 使用jQuery如何有效修改":after"伪元素的CSS属性?
    使用jQuery如何有效修改":after"伪元素的CSS属性?
    在jquery中了解伪元素的限制:访问“ selector 尝试修改“:”选择器的CSS属性时,您可能会遇到困难。 This is because pseudo-elements are not part of the DOM (Document Object Model) and are th...
    编程 发布于2025-04-17
  • 如何配置Pytesseract以使用数字输出的单位数字识别?
    如何配置Pytesseract以使用数字输出的单位数字识别?
    Pytesseract OCR具有单位数字识别和仅数字约束 在pytesseract的上下文中,在配置tesseract以识别单位数字和限制单个数字和限制输出对数字可能会提出质疑。 To address this issue, we delve into the specifics of Te...
    编程 发布于2025-04-17
  • PHP阵列键值异常:了解07和08的好奇情况
    PHP阵列键值异常:了解07和08的好奇情况
    PHP数组键值问题,使用07&08 在给定数月的数组中,键值07和08呈现令人困惑的行为时,就会出现一个不寻常的问题。运行print_r($月)返回意外结果:键“ 07”丢失,而键“ 08”分配给了9月的值。此问题源于PHP对领先零的解释。当一个数字带有0(例如07或08)的前缀时,PHP将其...
    编程 发布于2025-04-17
  • Java字符串非空且非null的有效检查方法
    Java字符串非空且非null的有效检查方法
    检查字符串是否不是null而不是空的 if(str!= null && str.isementy())二手: if(str!= null && str.length()== 0) option 3:trim()。isement(Isement() trim whitespace whitesp...
    编程 发布于2025-04-17
  • JavaScript中如何动态访问全局变量?
    JavaScript中如何动态访问全局变量?
    在JavaScript 一种方法是使用窗口对象存储和检索变量。通过引用全局范围,可以使用其名称动态访问变量。 //一个脚本 var somevarname_10 = 20; //另一个脚本 window.all_vars = {}; window.all_vars ['somevarnam...
    编程 发布于2025-04-17
  • 如何将MySQL数据库添加到Visual Studio 2012中的数据源对话框中?
    如何将MySQL数据库添加到Visual Studio 2012中的数据源对话框中?
    在Visual Studio 2012 尽管已安装了MySQL Connector v.6.5.4,但无法将MySQL数据库添加到实体框架的“ DataSource对话框”中。为了解决这一问题,至关重要的是要了解MySQL连接器v.6.5.5及以后的6.6.x版本将提供MySQL的官方Visual...
    编程 发布于2025-04-17

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3