- CSS 教程
- CSS - 教程
- CSS - 简介
- CSS - 语法
- CSS - 选择器
- CSS - 包含
- CSS - 度量单位
- CSS - 颜色
- CSS - 背景
- CSS - 字体
- CSS - 文本
- CSS - 图像
- CSS - 链接
- CSS - 表格
- CSS - 边框
- CSS - border-block 属性
- CSS - 边框内联
- CSS - 边距
- CSS - 列表
- CSS - Padding 属性
- CSS - 光标
- CSS - 轮廓
- CSS - 维度
- CSS - 滚动条
- CSS - 内联块
- CSS - 下拉列表
- CSS - visibility 属性
- CSS - Overflow 属性
- CSS - 清除修复
- CSS - float(浮点)
- CSS - 箭头
- CSS - resize 属性
- CSS - quotes 属性
- CSS - order 属性
- CSS - Position 属性
- CSS - hypens 属性
- CSS - :hover(悬停)
- CSS - display(显示)
- CSS - focus 属性
- CSS - zoom(缩放)
- CSS - translate 属性
- CSS - Height 属性
- CSS - hyphenate-character 属性
- CSS - Width 属性
- CSS - opacity 属性
- CSS - z-index 属性
- CSS - bottom 属性
- CSS - 导航栏
- CSS - 覆盖
- CSS - 表单
- CSS - 对齐
- CSS - 图标
- CSS - 图片库
- CSS - 注释
- CSS - 加载器
- CSS - Atrribute 选择器属性
- CSS - 运算器
- CSS - root
- CSS - 盒子模型
- CSS - 计数器
- CSS - Clip (Obsolete) 属性
- CSS - writing-mode 属性
- CSS - Unicode-bidi 属性
- CSS - min-content 属性
- CSS - 全部
- CSS - inset 属性
- CSS - isolation 属性
- CSS - overscroll-behavior 属性
- CSS - justify-items 属性
- CSS - justify-self 属性
- CSS - tab-size 属性
- CSS - pointer-event 属性
- CSS - place-content 属性
- CSS - place-items 属性
- CSS - place-self 属性
- CSS - max-block-size 属性
- CSS - min-block-size 属性
- CSS - mix-blend-mode 属性
- CSS - max-inline-size 属性
- CSS - min-inline-size 属性
- CSS - offset 属性
- CSS - accent-color 属性
- CSS - user-select 属性
- CSS 高级
- CSS - grid 属性
- CSS - Grid 布局
- CSS - flexbox
- CSS - vertical-align 属性
- css - positioning
- css - layers
- css - pseudo_classes
- CSS - 伪元素
- CSS - @ 规则
- CSS 滤镜 - text-effect 属性
- CSS 分页媒体
- CSS 打印
- CSS - 布局
- CSS - 验证
- CSS - 图像精灵
- CSS - !important
- CSS - 数据类型
- CSS3 教程
- CSS - 圆角
- CSS - 边框图像
- CSS - 多种背景
- CSS - 渐变
- CSS - box-shadow 属性
- CSS - box-decoration-break 属性
- CSS - caret-color 属性
- CSS - text-shadow 属性
- CSS - 2D 转换
- CSS - 3D 变换
- CSS - transition 属性
- CSS - 动画
- CSS - 多列布局
- CSS - 盒子大小调整
- CSS - 工具提示
- CSS - buttons
- CSS - 分页
- CSS - 变量
- CSS - 媒体查询
- CSS - 值函数
- CSS - 数学函数
- CSS - Mask 属性
- CSS - shape-outside 属性
- CSS - 样式图像
- CSS - 特异性
- CSS - 自定义属性
- CSS 响应式
- CSS - 响应式网页设计 (RWD)
- CSS - 响应式设计视口
- CSS - 响应式网格视图
- CSS - 响应式媒体查询
- CSS - 响应式图像
- CSS - 响应式视频
- CSS - 响应式框架
- CSS 引用
- CSS - 所有属性列表
- CSS - 颜色引用
- CSS - 浏览器支持参考
- CSS - 网页字体
- CSS 工具
- CSS - PX 到 EM 的转换
CSS - @ 规则
在 CSS 中,at rules 是以“@”符号开头的特殊指令或语句。它们用于控制或修改样式表的行为,通常用于定义媒体查询、导入外部样式表或指定字体等任务。
at-rules 是一种扩展和增强 CSS 功能的方法,超越了基本选择器和属性值对。
at-rules 以 at (@) 符号开头,后跟标识符,并进一步包含直到下一个分号 (;) 或下一个 CSS 块的所有内容。
语法
/*一般结构 */
@identifier (RULE);
@ 规则的类型
常规
CSS 根据标识符提供不同的常规 at-rules,每个规则都有不同的语法。
- @charset:指定外部样式表的字符编码。
- @import:用于将外部CSS文件导入到当前样式表中。
- @namespace:用于在 CSS 样式表中声明和定义 XML 命名空间。
嵌 套
嵌套语句的子集,既用作独立样式表语句,又用作条件组规则中的组件。
- @media:如果设备满足使用媒体查询定义的条件的条件,则应用条件组规则的内容。
- @supports:如果浏览器满足给定条件,则应用条件组规则的内容。
- @page:定义打印页面的布局。
- @font-face:定义要在网页中使用的自定义字体。
- @keyframes:定义 CSS 动画序列中中间步骤的方面。
- @counter-style:定义未预定义的不同自定义计数器样式。
- @font-feature-values:定义 font-variant-alternates 中在 OpenType 中激活的功能的通用名称。它处理备用字形的使用,这些字形在 @font-feature-values 中定义
- @property:定义自定义属性和变量的用法。
- @layer:定义一个层并设置优先级顺序,当有多个级联层时。
CSS 规则 - @page示例
以下是 @page 的用法示例:
<html>
<head>
<style>
@page :first {
margin-left: 80%;
margin-top: 80%;
}
p {
page-break-after: always;
}
</style>
</head>
<body>
<p>Page One.</p>
<p>Page Two.</p>
<button>Print</button>
<script>
document.querySelector("button").addEventListener("click", () => {
window.print();
});
</script>
</body>
</html>
CSS 规则 - @keyframes示例
以下是 @keyframes 的用法示例:
<html>
<head>
<style>
p {
animation-duration: 3s;
animation-name: slidein;
}
@keyframes slidein {
from {
margin-left: 100%;
width: 300%;
}
to {
margin-left: 0%;
width: 100%;
}
}
</style>
</head>
<body>
<p>
The text appears from right to left
</p>
</body>
</html>
CSS 规则 - @property示例
以下是 @property 的用法示例:
<html>
<head>
<style>
@property --item-size {
syntax: "<percentage>";
inherits: true;
initial-value: 40%;
}
.container {
display: flex;
height: 100px;
border: 3px dotted black;
/* set custom property values on parent */
--item-size: 50%;
--item-color: tomato;
--item-border: 5px solid green;
}
/* use custom properties to set item size and background color */
.item {
width: var(--item-size);
height: var(--item-size);
border: var(--item-border);
background-color: var(--item-color);
}
/* set custom property values on element itself */
.second {
--item-size: initial;
--item-color: inherit;
}
</style>
</head>
<body>
<div class="container">
<div class="first item">First Item</div>
<div class="second item">Second Item</div>
</div>
<script>
window.CSS.registerProperty({
name: "--item-color",
syntax: "<color>",
inherits: false,
initialValue: "peachpuff",
});
</script>
</body>
</html>
CSS @ Rules- 规则列表
下表列出了所有 CSS @ Rules:
@Rule | 例子 |
---|---|
@charset | @charset "UTF-8"; |
@container | @container (width > 400px) { h1 {font-size: 2em;} } |
@counter-style | @counter-style sample {} |
@font-face | @font-face { font-family: "CustomFont"; src: url("customfont.woff2") format("woff2"); } |
@font-feature-value | @font-feature-values "CustomFont" {@swash { fancy: 2; }} |
@font-palette-values | @font-palette-values One { font-family: "Bungee Spice";} |
@import | @import ur(); |
@keyframes | @keyframes sample-slide { from { transform: translateY(100%) } } |
@layer | @layer sample-layer{ .margin-lg { margin: 5px; } } |
@media | @media screen and (max-width: 600px) {} |
@namespace | @namespace svg url(); |
@page | @page { size: 5in 6in; margin-left: 4in } |
@property | @property sample-property { rules } |
@supports | @supports (transform-origin: 10% 10%) {} |