Css3新特性应用之视觉效果
目录
一、单侧阴影
- box-shadow属性的应用,格式:h-shadow v-shadow blur spread color inset属性取值介绍
- h-sahdow:水平阴影的位置,允许负值
- v-shadow:垂直阴影的位置,允许负值
- blur:模糊距离
- spread:阴影的尺寸,扩张距离,可以为负数
- color:阴影的颜色
- inset/outset:内部或者外部阴影
- 阴影的扩张距离对四边都有效,不能单独应用于单边。
- box-shadow支持多组值同时生效的设置
- 示例代码:
.wrap{
width: 200px;
height: 120px;
background: yellowgreen;
box-shadow: 2px 0px 4px -2px black,
-2px 0px 4px -2px black;
}
二 、不规则投影
- 利用border-radius生成的形状,用投影很好,但是如果加入了伪元素和半透明的装饰,阴影表现就很不好了,如下情况都会有问题。
- 半透明图像、背景图像、或者border-image
- 元素设置了点状、虚线或半透明的边框,但没有背景(或者background-clip不是border-box时)
- 元素内部有小角是用伪元素生成
- 通过clip-path生成的形状
- 解决办法:利用svg的drop-shadow来实现
- 示例代码:
.wrap{
width: 200px;
height: 120px;
border: 6px dotted yellowgreen;
--box-shadow: 0px 0px 4px 0px black;
-webkit-filter: drop-shadow(2px 0px 2px rgba(0,0,0,1))
}
三、染色体效果
- 基于滤镜实现,应用filter属性的相关值,调整图片的饱合度、亮度等值
- 基于min-blend-mode实现,作用:实现元素内容与背景以及下面的元素发生“混合”
- 基本background-blend-mode实现,作用:实现背景颜色与背景图片、背景图片与图片的混合
- 三种情况的示例代码:
.wrap1{
width: 200px;
height: 120px;
overflow: hidden;
}
.wrap1 > img{
max-height: 100%;
max-width: 100%;
-webkit-filter: sepia(1) saturate(4) hue-rotate(150deg);
}
.wrap2{
width: 200px;
height: 120px;
background: hsl(335, 100%, 50%);
overflow: hidden;
}
.wrap2 > img{
height: 100%;
width: 100%;
mix-blend-mode: luminosity;
}
.wrap3{
width: 200px;
height: 120px;
background-size: cover;
background-color: hsl(335, 100%, 50%);
background-image: url("../img/cat.png");
background-blend-mode: luminosity;
}
四、毛玻璃效果
主要实现原理:内容伪元素背景与底层背景相同的图片;并加上filter:blur模糊滤镜即可。注意blur不能应用在底层背景,也不能应用在元素的背景上(这样会地元素本身应用blur模糊,会导致文本看不见),只能就用在伪元素上。
代码如下:
body{
background: url("../img/cat.png") no-repeat;
background-size: cover;
}
.wrap{
position: relative;
width: 500px;
margin: 0px auto;
padding: 10px;
line-height: 1.5;
background: hsla(0, 0%, 100%, .3);
overflow: hidden;
}
.wrap::before{
content: '';
background: url("../img/cat.png") 0/cover fixed;
position: absolute;
top:; right:; bottom:; left:;
filter: blur(20px);
z-index: -1;
margin: -30px;
}
代码说明:
- body与wrap伪元素都应用相同的背景图片
- wrap的background-attachment设置为fixed,让背景图不要跟随滚动一起动
- wrap伪元素设置为绝对定位,且z-index层级只高于背景
- 利用blur设定wrap伪元素的模糊尺寸
- 用margin负值增加宽度,父元素用overflow:hidden隐藏溢出,让模糊背景更加真实。
五、折角效果
实现步骤
- 首先利用linear-gradient实现切角效果
- 然后再利用linear-gradinet生成一个三角形,并设置他的位置与宽高
- 代码如下:
.wrap{
background: linear-gradient(to left bottom, transparent 50%, rgba(0, 0, 0, .4) 0) no-repeat 100% 0/2em 2em,
linear-gradient(-135deg, transparent 1.4em, #58a 0);
width: 200px;
height: 120px;
}
注意
- 100% 0/2em 2em在定位背景元素的位置与宽高,尤其是2em的宽与高都是背景元素正常的宽度。
- 而第二个linear-gradient中的1.4em是沿着渐变轴进行度量的,也就是渐变轴到元素顶边的距离,本例是渐变轴到右上边顶的距离
- to left bottom是表示渐变从左下角开始
Css3新特性应用之视觉效果的更多相关文章
- 新特性AAtitti css3 新特性attilax总结titti css
Atitti css3 新特性attilax总结 图片发光效果2 透明渐变效果2 文字描边2 背景拉伸2 CSS3 选择器(Selector)4 @Font-face 特性7 Word-wrap &a ...
- Atitti css3 新特性attilax总结
Atitti css3 新特性attilax总结 图片发光效果2 透明渐变效果2 文字描边2 背景拉伸2 CSS3 选择器(Selector)4 @Font-face 特性7 Word-wrap &a ...
- CSS3新特性(阴影、动画、渐变、变形、伪元素等)
CSS3与页面布局学习总结(六)--CSS3新特性(阴影.动画.渐变.变形.伪元素等) 目录 一.阴影 1.1.文字阴影 1.2.盒子阴影 二.背景 2.1.背景图像尺寸 2.2.背景图像显示的原 ...
- 深入了解css3新特性
深入了解css3新特性:http://www.ibm.com/developerworks/cn/web/1202_zhouxiang_css3/
- H5 和 CSS3 新特性
博客地址:https://ainyi.com/52 H5 新特性 语义化标签:header.footer.section.nav.aside.article 增强型表单:input 的多个 type ...
- css3新特性总结
一.什么是css3 css用于控制网页的样式和布局,css3是css的升级版本,受浏览器限制,跨浏览器开发有点复杂.css3完全向后兼容 二.css3新特性 1.边框 css3的边框有如下属性: (1 ...
- 01-移动端开发教程-CSS3新特性
1. 移动端开发课程概述 移动互联网的兴起,让移动端的开发迅速蹿红.对于前端开发者来说,移动端的开发已经占据了他们大部分工作时间.接下来老马带大家一起学习移动端开发的相关前端开发技术. 这边课程内容包 ...
- css css3新特性
css css3新特性 一.css3是什么? 我不喜欢把已有的概念从一个地方抄到另一个地方,还是喜欢如下方式. 参考百度百科: http://baike.baidu.com/link?url=z2V ...
- [转]深入了解 CSS3 新特性
简介 CSS 即层叠样式表(Cascading Stylesheet).Web 开发中采用 CSS 技术,可以有效地控制页面的布局.字体.颜色.背景和其它效果.只需要一些简单的修改,就可以改变网页的外 ...
随机推荐
- Android Socket连接PC出错问题及解决
最近测试问题:Android 通过Socket链接电脑,ip和端口都是正确的,也在同一网段,可android端就是报异常如下: 解决办法:测试电脑的防火墙可能开着,在控制面板把防火墙打开即可.
- Linux基础介绍【第七篇】
linux用户分类 超级用户:UID=0,root 普通用户:UID 500起,由超级用户或具有超级用户权限的用户创建的用户. 虚拟用户:UID 1-499,为了满足文件或服务启动的需要而存在,一般都 ...
- Linux.NET实战手记—自己动手改泥鳅(上)
各位读者大家好,不知各位读者有否阅读在下的前一个系列<Linux.NET 学习手记>,在前一个系列中,我们从Linux中Mono的编译安装开始,到Jexus服务器的介绍,以及如何在Linu ...
- 使用Masstransit开发基于消息传递的分布式应用
Masstransit作为.Net平台下的一款优秀的开源产品却没有得到应有的关注,这段时间有机会阅读了Masstransit的源码,我觉得我有必要普及一下这个框架的使用. 值得一提的是Masstran ...
- 细说websocket - php篇
下面我画了一个图演示 client 和 server 之间建立 websocket 连接时握手部分,这个部分在 node 中可以十分轻松的完成,因为 node 提供的 net 模块已经对 socket ...
- ABP(现代ASP.NET样板开发框架)系列之2、ABP入门教程
点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之2.ABP入门教程 ABP是“ASP.NET Boilerplate Project (ASP.NET样板项目)” ...
- Entity Framework 6 Recipes 2nd Edition(12-5)译 -> 自动删除相关联实体
12-5. 自动删除相关联实体 问题 当一个实体被删除时,你想自动删除它相关联的实体 解决方案 假设你有一个表结构由一个course (科目), course 的classes (课程),以及enro ...
- python property理解
一般情况下我这样使用property: @property def foo(self): return self._foo # 下面的两个decrator由@property创建 @foo.sette ...
- 【.net 深呼吸】使用二进制格式来压缩XML文档
在相当多的情况下,咱们写入XML文件默认是使用文本格式来写入的,如果XML内容是通过网络传输,或者希望节省空间,特别是对于XML文档较大的情况,是得考虑尽可能地压缩XML文件的大小. XmlDicti ...
- Linux平台oracle 11g单实例 安装部署配置 快速参考
1.重建主机的Oracle用户 组 统一规范 uid gid 以保证共享存储挂接或其他需求的权限规范 userdel -r oracle groupadd -g 7 oinstall groupadd ...