What?
image-rendering作为现阶段还处于实验性质中的css属性,他的作用是在浏览器对图片进行比例缩放时,设置其缩放使用的算法,从而来得到我们最终想要的图片结果。而且这个属性可以应用于img,canvas和background-image中。
Note
由于该属性未得到所有浏览器的支持,本文直接在文章里应用该属性,所以阅读此文时请使用最新版本的浏览器
Usage
image{ image-rendering:auto;}
其可选的值有:
使用默认算法,即将图片色彩进行平滑缩放,不同的浏览器采用的算法不一,如:firefox 3.0后的gecko使用双线性插值(bilinear interpolation)算法
使用算法达达到在绽放时保持对比度和边缘,在加工时不平滑色彩和使用模糊
当图片放大时,单纯地去放大像素点,缩小时与auto效果一样
Demo
pixelated
我们先来放主角一!
看到了吗?这就是主角,一个大小为2*2像素的图片……
(图片君:你个鬼把我设计这么小,赶快把爷整大,不然削你!)
既然大哥发话了,小弟不能不听命,分分钟给大哥加了个width:400px
可是放大后……
(我:大哥,这还是你吗?你怎么变得这么色彩绚烂了)
(图片君:真是B了狗了!你对我做了什么)
(我:大哥,这不是我的错,是浏览器对你放大时使用了默认的算法把你的色彩平滑处理了……其实,现在还是挺好看的嘛!)
(图片君:别跟我扯犊子,给我整回来!!!!!)
大哥一怒,我连忙加点去给大家做整容手术,在它的属性里加了image-redering:pixelated
(我:这才是你嘛,大哥)
(图片君:这次不错,我还是我,是颜色不一样的烟火)
从大哥那里学到了pixelated的作用,而它在实际中的作用是怎么样的呢?
比如我有一个内容为zhiyishou.com的二维码君,它的大小为50px*50px
二维码君虽说不小,但是比变壮后的大哥小多了,二维码君也来找我想说整整容,变成大哥那样
于是,我直接把它变大,成了这样:
这……你英姿飒爽的轮廓呢?看来还是不对,思索了一下是和大哥的病一样
我二话没说,直接把刚学会的pixelated加在了二维码君的身上
这才是俊朗的二维码君嘛!!
crisp-edges
从w3c官网上请来了一位嘉宾,它来和我们演示crisp-edges的用法:
我们把嘉宾君进行放大:
这是嘉宾君在普通放大后的结果,即使用auto来做色彩平滑,我们试试在嘉宾君身上使用pixelated,看看会怎么样
嘉宾君有点不耐烦了,有事要走,赶快给它加上crisp-edges看看效果(由于各个浏览器对该属性的支持还不太统一,所以得做单独配置)
img{ width: 400px; image-rendering: -moz-crisp-edges; /* Firefox */ image-rendering: -o-crisp-edges; /* Opera */ image-rendering: -webkit-optimize-contrast;/* Webkit (non-standard naming) */ image-rendering: crisp-edges; -ms-interpolation-mode: nearest-neighbor; /* IE (non-standard property) */}
可以看出来嘉宾君的边缘没有像第一次那样被平滑掉,尽可能保持自己的边缘,但是整个图片做了模糊处理,所以不像上面的pixelated一样棱角分明。
这个效果可以对图片缩放时进行效果的优化,但和pixelated的应用场景不一样。
Finally
我感觉这个属性最实用的还是pixelated,对于这个属性的使用,我们不能去绝对地依赖它来实现某种效果,只能说是用它去做优化,要做到有它的参与更好,没有也不差什么,因为这个属性太新了,在chrome中出现也是chrome41,而且chrome目前还不支持crisp-edges值
Chrome | ? 41+Safari | * 7.1+Firefox | * 35+Opera | 28+IE | NopeAndroid | NopeiOS | * 7.1+? Supports pixelated but not crisp-edges* Supports crisp-edges but not pixelated
参考
image-rendering on MDN
image-rendering on W3C
image-rendering article
Finish.

HTML是构建网页结构的基石。1.HTML定义内容结构和语义,使用、、等标签。2.提供语义化标记,如、、等,提升SEO效果。3.通过标签实现用户交互,需注意表单验证。4.使用、等高级元素结合JavaScript实现动态效果。5.常见错误包括标签未闭合和属性值未加引号,需使用验证工具。6.优化策略包括减少HTTP请求、压缩HTML、使用语义化标签等。

HTML是一种用于构建网页的语言,通过标签和属性定义网页结构和内容。1)HTML通过标签组织文档结构,如、。2)浏览器解析HTML构建DOM并渲染网页。3)HTML5的新特性如、、增强了多媒体功能。4)常见错误包括标签未闭合和属性值未加引号。5)优化建议包括使用语义化标签和减少文件大小。

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

HTML的作用是通过标签和属性定义网页的结构和内容。1.HTML通过到、等标签组织内容,使其易于阅读和理解。2.使用语义化标签如、等增强可访问性和SEO。3.优化HTML代码可以提高网页加载速度和用户体验。

htmlisaspecifictypefodyfocusedonstructuringwebcontent,而“代码” badlyLyCludEslanguagesLikeLikejavascriptandPytyPythonForFunctionality.1)htmldefineswebpagertuctureduseTags.2)“代码”代码“ code” code code code codeSpassSesseseseseseseseAwiderRangeLangeLangeforLageforLogageforLogicIctInterract

HTML、CSS和JavaScript是Web开发的三大支柱。1.HTML定义网页结构,使用标签如、等。2.CSS控制网页样式,使用选择器和属性如color、font-size等。3.JavaScript实现动态效果和交互,通过事件监听和DOM操作。

HTML定义网页结构,CSS负责样式和布局,JavaScript赋予动态交互。三者在网页开发中各司其职,共同构建丰富多彩的网站。

HTML适合初学者学习,因为它简单易学且能快速看到成果。1)HTML的学习曲线平缓,易于上手。2)只需掌握基本标签即可开始创建网页。3)灵活性高,可与CSS和JavaScript结合使用。4)丰富的学习资源和现代工具支持学习过程。


热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

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

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

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

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器