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

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

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

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]删除
最新教程 更多>
  • 为什么尽管有效代码,为什么在PHP中捕获输入?
    为什么尽管有效代码,为什么在PHP中捕获输入?
    在php ;?>" method="post">The intention is to capture the input from the text box and display it when the submit button is clicked.但是,输出...
    编程 发布于2025-07-14
  • Python元类工作原理及类创建与定制
    Python元类工作原理及类创建与定制
    python中的metaclasses是什么? Metaclasses负责在Python中创建类对象。就像类创建实例一样,元类也创建类。他们提供了对类创建过程的控制层,允许自定义类行为和属性。在Python中理解类作为对象的概念,类是描述用于创建新实例或对象的蓝图的对象。这意味着类本身是使用类关...
    编程 发布于2025-07-14
  • 找到最大计数时,如何解决mySQL中的“组函数\”错误的“无效使用”?
    找到最大计数时,如何解决mySQL中的“组函数\”错误的“无效使用”?
    如何在mySQL中使用mySql 检索最大计数,您可能会遇到一个问题,您可能会在尝试使用以下命令:理解错误正确找到由名称列分组的值的最大计数,请使用以下修改后的查询: 计数(*)为c 来自EMP1 按名称组 c desc订购 限制1 查询说明 select语句提取名称列和每个名称...
    编程 发布于2025-07-14
  • 如何在Java中正确显示“ DD/MM/YYYY HH:MM:SS.SS”格式的当前日期和时间?
    如何在Java中正确显示“ DD/MM/YYYY HH:MM:SS.SS”格式的当前日期和时间?
    如何在“ dd/mm/yyyy hh:mm:mm:ss.ss”格式“ gormat 解决方案: args)抛出异常{ 日历cal = calendar.getInstance(); SimpleDateFormat SDF =新的SimpleDateFormat(“...
    编程 发布于2025-07-14
  • `console.log`显示修改后对象值异常的原因
    `console.log`显示修改后对象值异常的原因
    foo = [{id:1},{id:2},{id:3},{id:4},{id:id:5},],]; console.log('foo1',foo,foo.length); foo.splice(2,1); console.log('foo2', foo, foo....
    编程 发布于2025-07-14
  • 可以在纯CS中将多个粘性元素彼此堆叠在一起吗?
    可以在纯CS中将多个粘性元素彼此堆叠在一起吗?
    [2这里: https://webthemez.com/demo/sticky-multi-header-scroll/index.html </main> <section> { display:grid; grid-template-...
    编程 发布于2025-07-14
  • 如何使用不同数量列的联合数据库表?
    如何使用不同数量列的联合数据库表?
    合并列数不同的表 当尝试合并列数不同的数据库表时,可能会遇到挑战。一种直接的方法是在列数较少的表中,为缺失的列追加空值。 例如,考虑两个表,表 A 和表 B,其中表 A 的列数多于表 B。为了合并这些表,同时处理表 B 中缺失的列,请按照以下步骤操作: 确定表 B 中缺失的列,并将它们添加到表的末...
    编程 发布于2025-07-14
  • 同实例无需转储复制MySQL数据库方法
    同实例无需转储复制MySQL数据库方法
    在同一实例上复制一个MySQL数据库而无需转储在同一mySQL实例上复制数据库,而无需创建InterMediate sqql script。以下方法为传统的转储和IMPORT过程提供了更简单的替代方法。 直接管道数据 MySQL手动概述了一种允许将mysqldump直接输出到MySQL clie...
    编程 发布于2025-07-14
  • 如何使用组在MySQL中旋转数据?
    如何使用组在MySQL中旋转数据?
    在关系数据库中使用mySQL组使用mySQL组进行查询结果,在关系数据库中使用MySQL组,转移数据的数据是指重新排列的行和列的重排以增强数据可视化。在这里,我们面对一个共同的挑战:使用组的组将数据从基于行的基于列的转换为基于列。 Let's consider the following ...
    编程 发布于2025-07-14
  • 为什么PYTZ最初显示出意外的时区偏移?
    为什么PYTZ最初显示出意外的时区偏移?
    与pytz 最初从pytz获得特定的偏移。例如,亚洲/hong_kong最初显示一个七个小时37分钟的偏移: 差异源利用本地化将时区分配给日期,使用了适当的时区名称和偏移量。但是,直接使用DateTime构造器分配时区不允许进行正确的调整。 example pytz.timezone(...
    编程 发布于2025-07-14
  • 如何正确使用与PDO参数的查询一样?
    如何正确使用与PDO参数的查询一样?
    在pdo 中使用类似QUERIES在PDO中的Queries时,您可能会遇到类似疑问中描述的问题:此查询也可能不会返回结果,即使$ var1和$ var2包含有效的搜索词。错误在于不正确包含%符号。通过将变量包含在$ params数组中的%符号中,您确保将%字符正确替换到查询中。没有此修改,PDO...
    编程 发布于2025-07-14
  • 如何有效地选择熊猫数据框中的列?
    如何有效地选择熊猫数据框中的列?
    在处理数据操作任务时,在Pandas DataFrames 中选择列时,选择特定列的必要条件是必要的。在Pandas中,选择列的各种选项。选项1:使用列名 如果已知列索引,请使用ILOC函数选择它们。请注意,python索引基于零。 df1 = df.iloc [:,0:2]#使用索引0和1 c...
    编程 发布于2025-07-14
  • 如何在GO编译器中自定义编译优化?
    如何在GO编译器中自定义编译优化?
    在GO编译器中自定义编译优化 GO中的默认编译过程遵循特定的优化策略。 However, users may need to adjust these optimizations for specific requirements.Optimization Control in Go Compi...
    编程 发布于2025-07-14
  • C++20 Consteval函数中模板参数能否依赖于函数参数?
    C++20 Consteval函数中模板参数能否依赖于函数参数?
    [ consteval函数和模板参数依赖于函数参数在C 17中,模板参数不能依赖一个函数参数,因为编译器仍然需要对非contexexpr futcoriations contim at contexpr function进行评估。 compile time。 C 20引入恒定函数,必须在编译时进行...
    编程 发布于2025-07-14
  • CSS可以根据任何属性值来定位HTML元素吗?
    CSS可以根据任何属性值来定位HTML元素吗?
    靶向html元素,在CSS 中使用任何属性值,在CSS中,可以基于特定属性(如下所示)基于特定属性的基于特定属性的emants目标元素: 字体家庭:康斯拉斯(Consolas); } 但是,出现一个常见的问题:元素可以根据任何属性值而定位吗?本文探讨了此主题。的目标元素有任何任何属性值,属...
    编程 发布于2025-07-14

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

Copyright© 2022 湘ICP备2022001581号-3