[CSS]A Tale of CSS and Sass Precision(译)_html/css_WEB-ITnose
关于 CSS 和 Sass 布局的精确度
原文地址:http://www.sitepoint.com/a-tale-of-css-and-sass-precision/
在 Edenspiekermann,我们通过严格的代码审查来确保我们提交的代码足够完善。而关于数字的模糊性是我经常遇到的一个问题,特别是有小数点的数字。因此,在这里我会用一篇简单的文章阐明这个问题。
初始设置
为了使文章更容易理解,在进一步深入之前我们先用一个小小的代码块作为例子。
.list-item { float: left; width: 33%;}
有什么问题呢?
或许你会问,这个代码块有什么问题吗?表面上看来,确实没什么问题,这不就是一个典型的三列网格布局吗?
虽然 33% + 33% +33% 并不等于 100% 而是99 %。且在大多数情况下这个小小的差距并不会造成任何影响,但是当它作用在直线布局时,1% 的差距可能会造成很大的影响。要知道在 1400px及以上的容器中, 1% 的差距至少就是 14px了,这可是一个很大的间隙。
为什么我们不尝试移动一下小数点使它更加精确呢?我们可以把间隙减小到 1.4px甚至是 0.14px,这个距离可不会使我们烦恼了。那我们应该这样写:
.list-item { float: left; width: 33.33%;}
效果好了一些,但仍然不完美。这个问题已经在 John Albin Wilkins 发布的文章“ Responsive Design’s Dirty Little Secret”中被深入研究过了。如果你没读过这篇精彩的文章,你应该去读一下。
浏览器不能处理么?
这时候你可能会想,为什么浏览器就不能完美的解决这个问题呢?事实上,CSS 规范中并没有指定浏览器应该保留多少位精度的小数点。当 CSS 规范没有指定一项细则的时候,可以肯定的是每个浏览器都会有它自己的一套标准。
接下来引用一下上述文章中的段落:
在6列网格布局中,每列的宽度都是 100% ÷ 6 = 16.666667%。那么在 1000px 的视图中(只是为了使我们的计算更加容易),计算结果就是每列的宽度为 166.66667px。因为并没有明确的文档规定,所以浏览器厂商可以制定自己的规则。如果浏览器精确到最近的整数,在这个例子中,也即是 167px。但是因为 167 * 6 =1022px,因此在视图中我们无法给这 6 列提供足够的空间。相反的,如果浏览器把每列精确到 166px,那么就会在我们的视图中造成 4px 的间隙。
– John Albin Wilkins
这就是事实。旧版本的 IE 浏览器(主要是 IE6 和 IE7)会把数值转换为最接近的整数,从而导致布局缺陷。Webkit 浏览器会向下取整,这样防止布局的错位但会留下额外的空间。Opera(至少在以前的渲染引擎中)则会做一些奇怪的让人不解的东西。话说回来,关于这方面的规则并没有制定出来,所以又能责怪谁呢?不能怪浏览器使用的是像素来 渲染页面,这是肯定的,因此目前看来这是最好的结果。
无论如何,它几乎一团糟,我们会在文章结论部分再讨论这个问题。
那么 Sass 呢?
Sass 支持数字运算。这并不是新的领域并且实际上也用于 Sass 的新项目 (用于构建数字基础网格系统)。而我们能够做的就是告诉 Sass 我们希望把容器平分为三个部分。
.list-item { float: left; width: (100% / 3);}
我们也可以通过百分比函数 percentage(..)求得相同的结果。
.list-item { float: left; width: percentage(1 / 3);}
无论使用 Ruby 还是 LibSass,都可以保留五位 小数。这实际上是一个 问题,因为精度太低了。如果保留 10 位小数会更好,可惜这不是默认设置(尽管可以更改设置,但这并不是一个容易的方法)。
上面的代码产生的 CSS 效果如下:
.list-item { float: left; width: 33.33333%;}
这并不能解决我们的浏览器问题,但这简化了我们的样式表。通过所见即所得的计算模式,不仅使得我们不需要自己计算精度值,同时使得代码更加易读和维护。
不得不说这是一件好事。
两全其美
目前为止,我们已经了解到让 Sass 处理这些计算比我们自己手动算出来的数值精确多了。现在,最好的方法是让浏览器自己用最好的方法去处理这个运算。因此,我们可以使用 CSS 的 calc(..)函数。
.list-item { float: left; width: calc(100% / 3);}
这个代码块并不会被编译成其他东西,它由浏览器编译,然后由浏览器选择最佳方案。我可以坦诚的告诉你,我并不了解浏览器处理 calc(..)函数是否是和其他函数一样的流程。我推测它先执行运算,然后取整。有些浏览器似乎会把像素也带入计算。如果您有这方面的见解,欢迎在评论中分享。
对于那些 不支持 calc(..)表达式的浏览器 (主要是 IE8 和 Opera Mini),我们可以在 Sass 操作前放入一个静态表达式,通过这种方式达到平衡。
.list-item { float: left; width: (100% / 3); width: calc(100% / 3);}
结论
让我们回顾一下。首先,因为浏览器之前的差异性和缺乏统一的标准,所以基于百分比的布局很难处理。
其次,通过一些复杂运算而导致的硬编码值通常也不是一个好主意。我们可以通过 Sass 计算出近似值(浮点后五位数)。
更好的方法是,我们让浏览器自己计算近似值。在理想的情况下,浏览器可以同时掌控算数和渲染,那么它能生成最好的方案。朝这个方向前进,我们需要依赖 calc(..)函数的使用。
目前为止就讲这么多了。没有新的内容,但我想一个快速的回顾会对你有帮助的!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。

HTML、CSS和JavaScript在Web開發中的作用分別是:1.HTML定義網頁結構,2.CSS控製網頁樣式,3.JavaScript添加動態行為。它們共同構建了現代網站的框架、美觀和交互性。

HTML的未來趨勢是語義化和Web組件,CSS的未來趨勢是CSS-in-JS和CSSHoudini,JavaScript的未來趨勢是WebAssembly和Serverless。 1.HTML的語義化提高可訪問性和SEO效果,Web組件提升開發效率但需注意瀏覽器兼容性。 2.CSS-in-JS增強樣式管理靈活性但可能增大文件體積,CSSHoudini允許直接操作CSS渲染。 3.WebAssembly優化瀏覽器應用性能但學習曲線陡,Serverless簡化開發但需優化冷啟動問題。

HTML的未來充滿了無限可能。 1)新功能和標準將包括更多的語義化標籤和WebComponents的普及。 2)網頁設計趨勢將繼續向響應式和無障礙設計發展。 3)性能優化將通過響應式圖片加載和延遲加載技術提升用戶體驗。

HTML、CSS和JavaScript在網頁開發中的角色分別是:HTML負責內容結構,CSS負責樣式,JavaScript負責動態行為。 1.HTML通過標籤定義網頁結構和內容,確保語義化。 2.CSS通過選擇器和屬性控製網頁樣式,使其美觀易讀。 3.JavaScript通過腳本控製網頁行為,實現動態和交互功能。

HTML是構建網頁結構的基石。 1.HTML定義內容結構和語義,使用、、等標籤。 2.提供語義化標記,如、、等,提升SEO效果。 3.通過標籤實現用戶交互,需注意表單驗證。 4.使用、等高級元素結合JavaScript實現動態效果。 5.常見錯誤包括標籤未閉合和屬性值未加引號,需使用驗證工具。 6.優化策略包括減少HTTP請求、壓縮HTML、使用語義化標籤等。

HTML的作用是通過標籤和屬性定義網頁的結構和內容。 1.HTML通過到、等標籤組織內容,使其易於閱讀和理解。 2.使用語義化標籤如、等增強可訪問性和SEO。 3.優化HTML代碼可以提高網頁加載速度和用戶體驗。

HTMLISNOTAPROGRAMMENGUAGE; ITISAMARKUMARKUPLAGUAGE.1)htmlStructures andFormatSwebContentusingtags.2)itworkswithcsssforstylingandjavascript for Interactivity,增強WebevebDevelopment。
