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

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

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

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]删除
最新教程 更多>
  • 使用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-05-03
  • Spark DataFrame添加常量列的妙招
    Spark DataFrame添加常量列的妙招
    在Spark Dataframe ,将常数列添加到Spark DataFrame,该列具有适用于所有行的任意值的Spark DataFrame,可以通过多种方式实现。使用文字值(SPARK 1.3)在尝试提供直接值时,用于此问题时,旨在为此目的的column方法可能会导致错误。 df.withCo...
    编程 发布于2025-05-03
  • 解决Spring Security 4.1及以上版本CORS问题指南
    解决Spring Security 4.1及以上版本CORS问题指南
    弹簧安全性cors filter:故障排除常见问题 在将Spring Security集成到现有项目中时,您可能会遇到与CORS相关的错误,如果像“访问Control-allo-allow-Origin”之类的标头,则无法设置在响应中。为了解决此问题,您可以实现自定义过滤器,例如代码段中的MyFi...
    编程 发布于2025-05-03
  • eval()vs. ast.literal_eval():对于用户输入,哪个Python函数更安全?
    eval()vs. ast.literal_eval():对于用户输入,哪个Python函数更安全?
    称量()和ast.literal_eval()中的Python Security 在使用用户输入时,必须优先确保安全性。强大的Python功能Eval()通常是作为潜在解决方案而出现的,但担心其潜在风险。 This article delves into the differences betwee...
    编程 发布于2025-05-03
  • 人脸检测失败原因及解决方案:Error -215
    人脸检测失败原因及解决方案:Error -215
    错误处理:解决“ error:( - 215)!empty()in Function openCv in Function MultSiscale中的“检测”中的错误:在功能检测中。”当Face Cascade分类器(即面部检测至关重要的组件)未正确加载时,通常会出现此错误。要解决此问题,必须...
    编程 发布于2025-05-03
  • 在细胞编辑后,如何维护自定义的JTable细胞渲染?
    在细胞编辑后,如何维护自定义的JTable细胞渲染?
    在JTable中维护jtable单元格渲染后,在JTable中,在JTable中实现自定义单元格渲染和编辑功能可以增强用户体验。但是,至关重要的是要确保即使在编辑操作后也保留所需的格式。在设置用于格式化“价格”列的“价格”列,用户遇到的数字格式丢失的“价格”列的“价格”之后,问题在设置自定义单元格...
    编程 发布于2025-05-03
  • 在Pandas中如何将年份和季度列合并为一个周期列?
    在Pandas中如何将年份和季度列合并为一个周期列?
    pandas data frame thing commans date lay neal and pree pree'和pree pree pree”,季度 2000 q2 这个目标是通过组合“年度”和“季度”列来创建一个新列,以获取以下结果: [python中的concate...
    编程 发布于2025-05-03
  • C++20 Consteval函数中模板参数能否依赖于函数参数?
    C++20 Consteval函数中模板参数能否依赖于函数参数?
    [ consteval函数和模板参数依赖于函数参数在C 17中,模板参数不能依赖一个函数参数,因为编译器仍然需要对非contexexpr futcoriations contim at contexpr function进行评估。 compile time。 C 20引入恒定函数,必须在编译时进行...
    编程 发布于2025-05-03
  • CSS可以根据任何属性值来定位HTML元素吗?
    CSS可以根据任何属性值来定位HTML元素吗?
    靶向html元素,在CSS 中使用任何属性值,在CSS中,可以基于特定属性(如下所示)基于特定属性的基于特定属性的emants目标元素: 字体家庭:康斯拉斯(Consolas); } 但是,出现一个常见的问题:元素可以根据任何属性值而定位吗?本文探讨了此主题。的目标元素有任何任何属性值,属...
    编程 发布于2025-05-03
  • 如何使用“ JSON”软件包解析JSON阵列?
    如何使用“ JSON”软件包解析JSON阵列?
    parsing JSON与JSON软件包 QUALDALS:考虑以下go代码:字符串 } func main(){ datajson:=`[“ 1”,“ 2”,“ 3”]`` arr:= jsontype {} 摘要:= = json.unmarshal([] byte(...
    编程 发布于2025-05-03
  • 如何处理PHP文件系统功能中的UTF-8文件名?
    如何处理PHP文件系统功能中的UTF-8文件名?
    在PHP的Filesystem functions中处理UTF-8 FileNames 在使用PHP的MKDIR函数中含有UTF-8字符的文件很多flusf-8字符时,您可能会在Windows Explorer中遇到comploreer grounder grounder grounder gro...
    编程 发布于2025-05-03
  • Go web应用何时关闭数据库连接?
    Go web应用何时关闭数据库连接?
    在GO Web Applications中管理数据库连接很少,考虑以下简化的web应用程序代码:出现的问题:何时应在DB连接上调用Close()方法?,该特定方案将自动关闭程序时,该程序将在EXITS EXITS EXITS出现时自动关闭。但是,其他考虑因素可能保证手动处理。选项1:隐式关闭终止数...
    编程 发布于2025-05-03
  • 如何从PHP中的数组中提取随机元素?
    如何从PHP中的数组中提取随机元素?
    从阵列中的随机选择,可以轻松从数组中获取随机项目。考虑以下数组:; 从此数组中检索一个随机项目,利用array_rand( array_rand()函数从数组返回一个随机键。通过将$项目数组索引使用此键,我们可以从数组中访问一个随机元素。这种方法为选择随机项目提供了一种直接且可靠的方法。
    编程 发布于2025-05-03
  • 您如何在Laravel Blade模板中定义变量?
    您如何在Laravel Blade模板中定义变量?
    在Laravel Blade模板中使用Elegance 在blade模板中如何分配变量对于存储以后使用的数据至关重要。在使用“ {{}}”分配变量的同时,它可能并不总是最优雅的解决方案。幸运的是,Blade通过@php Directive提供了更优雅的方法: $ old_section =“...
    编程 发布于2025-05-03
  • 如何使用替换指令在GO MOD中解析模块路径差异?
    如何使用替换指令在GO MOD中解析模块路径差异?
    在使用GO MOD时,在GO MOD 中克服模块路径差异时,可能会遇到冲突,其中可能会遇到一个冲突,其中3派对软件包将另一个带有导入套件的path package the Imptioned package the Imptioned package the Imported tocted pac...
    编程 发布于2025-05-03

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

Copyright© 2022 湘ICP备2022001581号-3