我们都知道 CSS 曾经是 Web 开发中最具挑战性的部分。然而,现在变得更加困难了。
你可能不会相信,现在 CSS 可以定义属性、进行数学运算,甚至可以直接获取屏幕尺寸!本文将向您展示如何做到这一点。
定义属性
@property 规则是 CSS 中的一项新功能,允许开发人员创建自定义属性并设置其类型、继承和初始值。使用此功能,我们可以读取特定值并将其传递给自定义属性。
在下面的例子中,我们定义了两个自定义属性,--w_raw和--h_raw,分别代表屏幕的宽度和高度:
@property --w_raw { syntax: '<length>'; inherits: true; initial-value: 100vw; } @property --h_raw { syntax: '<length>'; inherits: true; initial-value: 100vh; } </length></length>
- 语法:''指定属性的类型是长度。
- 继承:true表示该属性可以继承。
- initial-value 将属性的初始值设置为 100vw 和 100vh,即视口的宽度和高度。
移除单位
现在,我们已经获得了屏幕的宽度和高度值,但它们仍然包含单位。我们如何去除单位以获得纯数值?这是一个数学问题,所以我们需要使用 CSS 中的数学工具:atan2(y, x) 和 tan()。
- atan2(y, x) 函数返回从 x 轴到点 (x, y) 的角度(以弧度为单位)。
- tan() 函数计算给定角度的正切。
结合这些,我们可以获得纯数值。这里,我们传递 var(--w_raw) 和 1px 作为参数来计算宽度的角度,然后将其转换为数字。这样,我们将宽度和高度转换为无单位值并将它们存储在 :root 的变量中。
:root { --w: tan(atan2(var(--w_raw), 1px)); --h: tan(atan2(var(--h_raw), 1px)); }
显示数字
既然数值存储在CSS中,我们如何显示它们呢?重要的是计数器!
body::before { content: counter(w) 'x' counter(h); counter-reset: h var(--h) w var(--w); }
我们在 body 上创建一个 ::before 伪元素来显示 CSS 内容。
- counter-reset 初始化计数器 h 和 w 并将其值设置为 var(--h) 和 var(--w)。
- 内容:计数器(w)“x”计数器(h);显示宽度和高度计数器,格式为“宽度 x 高度”。
完毕!
现在您已经纯粹在CSS中实现了屏幕尺寸指示器。
浏览器会实时更新--w和--h并显示在页面上。整个过程完全不需要 JavaScript。
您可以点击此处尝试在线演示。
以上是使用纯 CSS 获取屏幕尺寸的详细内容。更多信息请关注PHP中文网其他相关文章!

@keyframesandCSSTransitionsdifferincomplexity:@keyframesallowsfordetailedanimationsequences,whileCSSTransitionshandlesimplestatechanges.UseCSSTransitionsforhovereffectslikebuttoncolorchanges,and@keyframesforintricateanimationslikerotatingspinners.

我知道,我知道:有大量的内容管理系统选项可用,而我进行了几个测试,但实际上没有一个是一个,y&#039;知道吗?怪异的定价模型,艰难的自定义,有些甚至最终成为整个&

链接CSS文件到HTML可以通过在HTML的部分使用元素实现。1)使用标签链接本地CSS文件。2)多个CSS文件可通过添加多个标签实现。3)外部CSS文件使用绝对URL链接,如。4)确保正确使用文件路径和CSS文件加载顺序,优化性能可使用CSS预处理器合并文件。

选择Flexbox还是Grid取决于布局需求:1)Flexbox适用于一维布局,如导航栏;2)Grid适合二维布局,如杂志式布局。两者在项目中可结合使用,提升布局效果。

包含CSS文件的最佳方法是使用标签在HTML的部分引入外部CSS文件。1.使用标签引入外部CSS文件,如。2.对于小型调整,可以使用内联CSS,但应谨慎使用。3.大型项目可使用CSS预处理器如Sass或Less,通过@import导入其他CSS文件。4.为了性能,应合并CSS文件并使用CDN,同时使用工具如CSSNano进行压缩。

是的,youshouldlearnbothflexboxandgrid.1)flexboxisidealforone-demensional,flexiblelayoutslikenavigationmenus.2)gridexcelstcelsintwo-dimensional,confffferDesignssignssuchasmagagazineLayouts.3)blosebothenHancesSunHanceSlineHancesLayOutflexibilitibilitibilitibilitibilityAnderibilitibilityAndresponScormentilial anderingStruction

重构自己的代码看起来是什么样的?约翰·瑞亚(John Rhea)挑选了他写的一个旧的CSS动画,并介绍了优化它的思维过程。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

Atom编辑器mac版下载
最流行的的开源编辑器

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

禅工作室 13.0.1
功能强大的PHP集成开发环境

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

Dreamweaver Mac版
视觉化网页开发工具