@charset "UTF-8";
.markdown-body { line-height: 1.75; font-weight: 400; font-size: 15px; overflow-x: hidden; color: rgba(43, 43, 43, 1); font-family: -apple-system, system-ui, BlinkMacSystemFont, Helvetica Neue, PingFang SC, Hiragino Sans GB, Microsoft YaHei, Arial, sans-serif; background-image: linear-gradient(90deg, rgba(159, 219, 252, 0.15) 3%, rgba(0, 0, 0, 0) 0), linear-gradient(1turn, rgba(159, 219, 252, 0.15) 3%, rgba(0, 0, 0, 0) 0); background-size: 20px 20px; background-position: center }
.markdown-body h1, .markdown-body h2, .markdown-body h3, .markdown-body h4, .markdown-body h5, .markdown-body h6 { padding: 30px 0; margin-top: 35px; margin-bottom: 10px; color: rgba(77, 208, 225, 1) }
.markdown-body h1 { font-size: 30px; text-align: center; position: relative; width: max-content; margin: 0 auto }
.markdown-body h1:before { position: absolute; content: ""; z-index: -1; top: -20px; height: 100%; width: 100px; left: 0; right: 0; margin: 0 auto; background: url("") center / 64px 64px no-repeat; opacity: 0.84 }
.markdown-body h1:after { position: absolute; content: ""; width: 150%; left: -25%; height: 50%; bottom: 12px; border-radius: 50%; background: linear-gradient(rgba(0, 0, 0, 0) 80%, rgba(77, 208, 225, 0.8)); opacity: 0.6; animation: 6s linear infinite h1animate }
@keyframes h1Animate { 0% { background-position: right bottom } 50% { background-position: right } 100% { background-position: right bottom } }
.markdown-body h2 { display: block; border-bottom: 4px solid rgba(77, 208, 225, 1); position: relative; font-size: 24px; padding: 12px 32px; margin: 30px 0 }
.markdown-body h2:before { width: 24px; height: 24px; left: 0; top: 0; margin: auto; background-size: 24px 24px; background-image: url("") }
.markdown-body h2:after, .markdown-body h2:before { content: ""; display: block; position: absolute; bottom: 0 }
.markdown-body h2:after { right: 0; width: 400px; height: 10px; border-top-right-radius: 24px; background: linear-gradient(90deg, rgba(255, 255, 255, 1), rgba(77, 208, 225, 1)); max-width: 50vw }
.markdown-body h3 { margin: 30px 0; font-size: 18px; position: relative; padding: 4px 32px; width: max-content }
.markdown-body h3:before { border-bottom: 2px solid rgba(77, 208, 225, 1); width: 100%; content: ""; display: block; height: 28px; position: absolute; left: 0; top: 0; bottom: -2px; margin: auto; background-size: 28px 28px; background-image: url(""); background-repeat: no-repeat; animation: 2s infinite alternate h3animationbefore }
@keyframes h3AnimationBefore { 0% { width: 28px } 25% { width: 100% } 50% { width: 100% } 100% { width: 100% } }
.markdown-body h3:after { content: ""; display: block; width: 28px; height: 28px; position: absolute; border: 2px solid rgba(77, 208, 225, 1); border-radius: 50%; right: -15px; top: 0; bottom: 0; margin: auto; background-size: 28px 28px; background-image: url(""); animation: 2s infinite alternate h3animationafter }
@keyframes h3AnimationAfter { 0% { } 10% { } 50% { transform: rotate(-1turn) } 100% { transform: rotate(-1turn) } }
.markdown-body h4 { font-size: 16px }
.markdown-body h5 { font-size: 15px }
.markdown-body h6 { margin-top: 5px }
.markdown-body p { line-height: inherit; margin: 22px 0; letter-spacing: 2px; font-size: 14px; word-spacing: 2px }
.markdown-body img { max-width: 80%; border-radius: 6px; display: block; margin: 20px auto !important; object-fit: contain; box-shadow: 0 0 16px rgba(110, 110, 110, 0.45) }
.markdown-body figcaption { display: block; font-size: 13px; color: rgba(43, 43, 43, 1) }
.markdown-body figcaption:before { content: ""; background-image: url(""); display: inline-block; width: 18px; height: 18px; background-size: 18px; background-repeat: no-repeat; background-position: center; margin-right: 5px; margin-bottom: -5px }
.markdown-body hr { border-top: 1px solid rgba(77, 208, 225, 1); border-right: none; border-bottom: none; border-left: none; margin-top: 32px; margin-bottom: 32px }
.markdown-body del { color: rgba(77, 208, 225, 1) }
.markdown-body code { border-radius: 2px; overflow-x: auto; background-color: rgba(77, 208, 225, 0.08); color: rgba(38, 198, 218, 1); padding: 0.195em 0.4em }
.markdown-body pre { font-family: Menlo, Monaco, Consolas, Courier New, monospace; overflow: auto; position: relative; line-height: 1.75; box-shadow: 0 0 8px rgba(110, 110, 110, 0.45); border-radius: 4px; margin: 16px }
.markdown-body pre:before { content: ""; display: block; height: 30px; width: 100%; margin-bottom: -7px; background: url("") 10px 10px / 40px no-repeat }
.markdown-body pre>code { font-size: 12px; padding: 15px 12px; margin: 0; word-break: normal; display: block; overflow-x: auto; color: rgba(51, 51, 51, 1); background: rgba(248, 248, 248, 1) }
.markdown-body a { color: rgba(77, 208, 225, 1); border-bottom: 1px solid rgba(77, 208, 225, 1); font-weight: 400; text-decoration: none; margin: 0 4px }
.markdown-body a:active, .markdown-body a:hover { background-color: rgba(77, 208, 225, 0.1) }
.markdown-body strong { color: rgba(38, 198, 218, 1) }
.markdown-body strong:before { content: "「" }
.markdown-body strong:after { content: "」" }
.markdown-body em { font-style: normal; color: rgba(77, 208, 225, 1); font-weight: 700 }
.markdown-body table { display: inline-block !important; font-size: 12px; width: auto; max-width: 100%; overflow: auto; border: 1px solid rgba(246, 246, 246, 1) }
.markdown-body thead { background: rgba(246, 246, 246, 1); color: rgba(0, 0, 0, 1); text-align: left }
.markdown-body tr:nth-child(2n) { background-color: rgba(77, 208, 225, 0.05) }
.markdown-body td, .markdown-body th { padding: 12px 7px; line-height: 24px }
.markdown-body td { min-width: 120px }
.markdown-body blockquote { margin: 2em 0; padding: 24px 32px; border-left: 4px solid rgba(38, 198, 218, 1); background: rgba(77, 208, 225, 0.15); position: relative }
.markdown-body blockquote:before { content: "❝"; top: 8px; left: 8px; color: rgba(77, 208, 225, 1); font-size: 30px; line-height: 1; font-weight: 700; position: absolute; opacity: 0.7 }
.markdown-body blockquote:after { content: "❞"; font-size: 30px; position: absolute; right: 8px; bottom: 0; color: rgba(77, 208, 225, 1); opacity: 0.7 }
.markdown-body blockquote p { color: rgba(89, 89, 89, 1); line-height: 2 }
.markdown-body ol, .markdown-body ul { color: rgba(89, 89, 89, 1); padding-left: 28px }
.markdown-body ol li, .markdown-body ul li { margin-bottom: 0; list-style: inherit }
.markdown-body ol li .task-list-item, .markdown-body ul li .task-list-item { list-style: none }
.markdown-body ol li .task-list-item ol, .markdown-body ol li .task-list-item ul, .markdown-body ul li .task-list-item ol, .markdown-body ul li .task-list-item ul { margin-top: 0 }
.markdown-body ol ol, .markdown-body ol ul, .markdown-body ul ol, .markdown-body ul ul { margin-top: 3px }
.markdown-body ol li { padding-left: 6px }
@media (max-width: 720px) { .markdown-body h1 { font-size: 24px } .markdown-body h2 { font-size: 20px } .markdown-body h3 { font-size: 18px } }.markdown-body pre, .markdown-body pre>code.hljs { background: rgba(255, 255, 255, 1); color: rgba(0, 0, 0, 1) }
.hljs-comment, .hljs-quote, .hljs-variable { color: rgba(0, 128, 0, 1) }
.hljs-built_in, .hljs-keyword, .hljs-name, .hljs-selector-tag, .hljs-tag { color: rgba(0, 0, 255, 1) }
.hljs-addition, .hljs-attribute, .hljs-literal, .hljs-section, .hljs-string, .hljs-template-tag, .hljs-template-variable, .hljs-title, .hljs-type { color: rgba(163, 21, 21, 1) }
.hljs-deletion, .hljs-meta, .hljs-selector-attr, .hljs-selector-pseudo { color: rgba(43, 145, 175, 1) }
.hljs-doctag { color: rgba(128, 128, 128, 1) }
.hljs-attr { color: rgba(255, 0, 0, 1) }
.hljs-bullet, .hljs-link, .hljs-symbol { color: rgba(0, 176, 232, 1) }
.hljs-emphasis { font-style: italic }
.hljs-strong { font-weight: 700 }

随着Web技术的不断进化,CSS作为网页样式定义的关键技术,也在不断引入新的特性,增强开发者的设计能力。在这篇文章中,我们来盘点一下那些CSS的新特性以及那些不为人知的冷门特性,并通过实际案例和代码演示它们的应用。

@supports规则

@supports规则允许你在CSS中进行特性检测,据此应用相应的样式。

应用场景

只有当浏览器支持CSS Grid时,才使用Grid布局。

@supports (display: grid) {
.container {
display: grid;
grid-template-columns: repeat(3, 1fr);
}
}

CSS Grid布局

CSS Grid(网格布局)是一种强大的布局系统,允许我们更加灵活地设计复杂的网页布局。

应用场景

创建一个杂志风格的布局,其中内容被分为多列和多行。

.container {
display: grid;
grid-template-columns: 1fr 2fr 1fr;
grid-template-rows: auto;
gap: 10px;
} .header {
grid-column: 1 / 4;
grid-row: 1;
} .main-content {
grid-column: 2 / 3;
grid-row: 2;
} .sidebar {
grid-column: 3 / 4;
grid-row: 2;
} .footer {
grid-column: 1 / 4;
grid-row: 3;
}

subgrid

说起来,subgrid 就像是网格的子弹,让你的布局设计有了新的层次。它允许网格项内部再次定义网格,颠覆你对于网页空间的想象

应用场景

创建一个多层次的卡片布局

.card {
display: grid;
grid-template-rows: auto;
grid-template-columns: subgrid;
} .card-content {
display: grid;
grid-template-columns: 1fr 2fr;
gap: 15px;
}

@container

CSS容器查询,这可是响应式设计的新篇章。你的组件样式现在可以基于父容器的大小来调整,而不仅仅是视口尺寸。

应用场景

让卡片在容器尺寸变化时改变布局

@container (min-width: 500px) {
.card {
padding: 2rem;
}
}

:is()伪类

:is() 伪类就像是一把万能钥匙,它可以让你的选择器变得简洁而强大,避免了复杂的选择器嵌套。

应用场景

为多种不同的元素应用相同的样式,而不再需要书写冗长的选择器

:is(.header, .footer, .sidebar) {
background-color: peachpuff;
}

color-scheme属性

color-scheme属性让我们可以为网页轻松定义一个亮色和暗色模式。让用户的眼睛在夜晚也能享受舒适的浏览体验。

应用场景

让你的网页跟随系统主题自动切换色彩模式

:root {
color-scheme: light dark;
}

contain属性

contain属性可以对元素的布局、样式和绘制等进行限制,提升页面的性能。

应用场景

优化滚动列表的性能,避免列表外的渲染影响内部。

.scroll-list {
contain: strict;
overflow-y: auto;
height: 200px;
}

CSS变量

CSS变量(也称为自定义属性)允许你在文档中定义可重用的值。

应用场景

统一管理一个网站的主题颜色。

:root {
--main-color: #3498db;
--accent-color: #e74c3c;
} body {
background-color: var(--main-color);
color: white;
} .button {
background-color: var(--accent-color);
}

CSS滤镜

CSS滤镜提供了一种方法来对元素的渲染进行图形效果处理,如模糊或颜色偏移。

应用场景

为图片添加一个模糊效果。

.blur-image {
filter: blur(5px);
}

CSS Scroll Snap

CSS Scroll Snap允许开发者创建具有“吸附”效果的滚动容器,使得滚动时元素可以停在预定义的位置。

应用场景

创建一个全屏滚动的幻灯片效果。

.container {
scroll-snap-type: y mandatory;
overflow-y: scroll;
height: 100vh;
} .slide {
scroll-snap-align: start;
height: 100vh;
}

aspect-ratio属性

这个新属性允许你在不依赖特定宽高数值的情况下,定义一个盒子的宽高比。

应用场景

创建一个视频播放器容器,它需要保持16:9的宽高比。

.video-container {
aspect-ratio: 16 / 9;
width: 100%;
background-color: black;
}

冷门特性

有时候,时尚界的小众潮流会意外火起来。同样,在CSS的世界里,那些冷门特性也可能突然成为你的秘密武器

CSS currentColor

currentColor关键字是一个冷门但非常有用的CSS特性,它允许你引用元素当前颜色(即color属性的值)。

应用场景

为边框和文本设置相同的颜色。

div {
color: #3498db;
border: 2px solid currentColor; /* 边框颜色将会是#3498db */
}

:focus-within伪类

:focus-within伪类是一个选择器,当元素内部的任何子元素具有焦点时,它可以选中该元素。

应用场景

当输入框获得焦点时,高亮整个表单区域。

.form-container:focus-within {
background-color: lightyellow;
} input:focus {
outline: none;
border-color: #3498db;
}

CSS Shapes

CSS Shapes 允许你通过指定几何形状来定义元素周围内容的流动方式。

应用场景

文字围绕一个圆形图片流动。

.shape-outside {
width: 200px;
height: 200px;
shape-outside: circle(50%);
float: left;
margin-right: 20px;
}

clip-path

clip-path属性允许你剪切元素到基本形状或SVG路径。

应用场景

创建一个菱形的用户头像。

.diamond-avatar {
width: 100px;
height: 100px;
background-image: url('avatar.jpg');
clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
}

object-fit和object-position

这些属性工作起来就像background-sizebackground-position,但是对于<img><video>元素。

应用场景

完美地填充一个不同尺寸的图片容器,同时保持图片的比例。

.img-container img {
width: 100%;
height: 100%;
object-fit: cover; /* 保持图片的比例,同时填满容器 */
object-position: center; /* 图片居中显示 */
}

writing-mode

writing-mode让文字垂直或水平展示。

应用场景

构建一个垂直的导航菜单

.vertical-text {
writing-mode: vertical-rl;
text-orientation: upright;
}

mix-blend-mode

mix-blend-mode属性,让元素与背景玩起了颜色的混合游戏。

应用场景

让文字根据背景色智能变色

.blend-text {
mix-blend-mode: difference;
}

all属性

遇到那些需要从头开始的样式设计时,all属性一键复位所有属性。

应用场景

在一个组件中重置所有继承来的样式

.reset-all {
all: unset;
}

总结

CSS的世界像是个无尽的时尚秘境,新特性就像是每个季度新推出的时装系列,让网页设计不断焕发新韵味。而那些冷门特性,则像是时尚界独具匠心的复古风,潜藏着无限的可能。别小看这些小众的风格,它们能让你的设计从平淡无奇的大众脸脱颖而出,成为独树一帜的存在。

现在,让我们脱掉单调的外衣,拥抱CSS新特性的色彩世界。不管是在网页布局的广阔天地里追求创新,还是在细微的样式调整中发现美的惊喜,CSS总能给你想要的那份灵感和能量。记住,时尚的潮流总是在变,而你,就是那个引领潮流的人。

那些神奇的CSS特性,你都有用过么?的更多相关文章

  1. 深入探讨 CSS 特性检测 @supports 与 Modernizr

    什么是 CSS 特性检测?我们知道,前端技术日新月异的今天,各种新技术新属性层出不穷.在 CSS 层面亦不例外. 一些新属性能极大提升用户体验以及减少工程师的工作量,并且在当下的前端氛围下: 很多实验 ...

  2. 2017年值得学习的3个CSS特性

    原文:https://bitsofco.de/3-new-css-features-to-learn-in-2017/译文:http://caibaojian.com/3-new-css-featur ...

  3. css基础(css书写 背景设置 标签分类 css特性)

      css书写位置   行内式写法 <p style="color:red;" font-size:12px;></p> 外联式写法 <link re ...

  4. 容易被忽略CSS特性

    CSS初学感觉很简单,但随着学习的深入才感觉CSS的水由多深,平常总会遇到各种坑,先总结一些经常遇到的坑 大小写不敏感 虽然我们平时在写CSS的时候都是用小写,但其实CSS并不是大小写敏感的 .tes ...

  5. 容易被忽略的CSS特性

    CSS初学感觉很简单,但随着学习的深入才感觉CSS的水由多深,平常总会遇到各种坑,先总结一些经常遇到的坑 大小写不敏感 虽然我们平时在写CSS的时候都是用小写,但其实CSS并不是大小写敏感的 .tes ...

  6. CSS布局十八般武艺都在这里了

    CSS布局十八般武艺都在这里了 Shelley Lee 4 个月前 布局是CSS中一个重要部分,本文总结了CSS布局中的常用技巧,包括常用的水平居中.垂直居中方法,以及单列布局.多列布局的多种实现方式 ...

  7. 【转】容易被忽略CSS特性

    这里主要是为了留个备份,更好的排版请查看原文: http://www.cnblogs.com/dolphinX/p/3511300.html //以下为全文转载 CSS初学感觉很简单,但随着学习的深入 ...

  8. 即将来到: CSS Feature Queries (CSS特性查询)

    Feature Queries 是CSS3 Conditional Rules specification中的一部分,它支持“@supports”规则,“@supports”规则可以用来测试浏览器是否 ...

  9. 神奇的CSS sprites,制作特效的新方法

    本文主要内容简译自Dava Shea的英文文章 CSS Sprites: Image Slicing’s Kiss of Death,如果觉得博主讲的含糊不清的话,可以看作者原文. 熟悉了常规切图的我 ...

  10. 开局一张图,构建神奇的 CSS 效果

    假设,我们有这样一张 Gif 图: 利用 CSS,我们尝试来搞一些事情. 图片的 Glitch Art 风 在这篇文章中 --CSS 故障艺术,我们介绍了利用混合模式制作一种晕眩感觉的视觉效果.有点类 ...

随机推荐

  1. DeepSeek本地性能调优

    技术背景 大模型性能调优是一个很复杂的工程,涉及到很多细节,如果真要对模型动刀子,还需要对模型和数据集本身有非常好的理解.这里我们仅仅考虑模型加载过程中,可以优化的一些参数配置.关于DeepSeek在 ...

  2. JS实现隐藏手机号码中间4位数

    代码COPY 3. 使用正则 function geTel(tel){ var reg = /^(\d{3})\d{4}(\d{4})$/; return tel.replace(reg, " ...

  3. autMan奥特曼机器人-内置Redis

    autMan内置了redis服务,有的脚本运行需要redis支持 几个注意事项: 启用redis服务后要重启autMan生效,关闭一样的道理. 启用redis服务后会增加约200M的内存占用 多个au ...

  4. Typecho浏览统计和热门文章调用插件TePostViews

    TePostViews是一款简单的typecho热门文章调用插件,通过该插件可以显示每篇文章的阅读次数,以及调用阅读次数最多或者评论数最多的文章作为热门文章调用,用户可以自由选择调用依据和调用文章的数 ...

  5. Sqoop - [01] 概述

    将关系型数据库(Oracle.MySQL.PG等)数据与Hadoop数据进行转换的工具. 一.Sqoop1和Sqoop2的区别 Sqoop1由client端直接接入Hadoop,任务通过解析生成对应的 ...

  6. Python装饰器:套层壳我变得更强了!

    Python装饰器:套层壳我变得更强了 Python装饰器:套层壳我变得更强了 关于作用域和闭包可以聊点什么? 什么是作用域 什么是闭包 装饰器:套层壳我变得更强了 参考资料 昨天阅读了<Pyt ...

  7. NCS开发学习笔记-基础篇-前言

    nRF5 SDK 与 nRF Connect SDK 目前Nordic有2套并存的SDK:老的nRF5 SDK和新的nRF Connect SDK(简称NCS),两套SDK相互独立. nRF5 SDK ...

  8. 介绍一下opentcs

    OpenTCS是一个开源的自动运载系统(Automated Guided Vehicle,AGV)控制系统.它旨在管理和控制自动化运输车辆,例如AGV或自动搬运车(AMR),在工业和商业环境中执行各种 ...

  9. 非容器环境中使用Selenium,提升Chrome与ChromeDiver兼容性

    背景 在 Windows 环境下使用 Selenium 时,Chrome 浏览器版本与 ChromeDriver 版本的兼容性问题是一个常见的困扰. 由于 Chrome 频繁更新,而 ChromeDr ...

  10. WebGL 的简易入门教程

    目录 前言 第一节 绘制出了一个点 效果演示 逐行解释 向量类型 第二节 动态传递点数据 变量修饰符 完整代码 第三节 缓冲区和画线 类型化数组 绘制的方式 完整代码 第四节 彩色线段 精度修饰符 完 ...