[读书笔记] CSS揭秘-背景与边框
半透明边框
默认情况下,背景会延伸到边框所在的区域下层。可以通过background-clip属性调整该默认行为。
border: 10px solid rgba(0,0,0,.2)
background: blue;
background-clip: padding-box;
多重边框
box-shadow
box-shadow支持逗号分隔语法,可以创建任意数量的投影。
background: yellowgreen;
box-shadow: 0 0 0 10px #655, 0 0 0 20px red;
需要注意:
- 只能实线框
- 不影响布局,不受box-sizing影响,可以通过margin或者padding来模拟边框所要占据的控件
- box-shadow模拟的边框在元素的外圈,不会响应事件。如果需要响应事件的话,可以通过padding+inset来搞定。
background: yellowgreen;
padding: 20px;
box-shadow: 0 0 0 10px #655, 0 0 0 20px red;
outline
background: yellowgreen;
border: 10px solid #655;
outline: 10px solid red;
可以实现虚线边框,并且可以通过outline-offset控制outline与border之间的距离。但是需要注意:
- 只能实现双层边框
- outline只支持直角,所以如果元素设置border-radius时,outline并不会贴合border-radiu圆角
灵活的背景定位
background-position的扩展语法
background: url(http://csssecrets.io/images/code-pirate.svg) no-repeat right bottom #58a; /* 在此添加 right bottom 作为回退方案 */
background-position: right 10px bottom 20px;
background-origin方案
如果需要偏移量与内边距一致,可以通过设置background-origin来实现。
padding: 20px;
background: url(http://csssecrets.io/images/code-pirate.svg) no-repeat right bottom #58a;
background-origin: content-box;
calc()方案
background: url(http://csssecrets.io/images/code-pirate.svg) no-repeat #58a;
background-position: calc(100% - 10px) calc(100% - 10px); /* calc()函数内容的 - 和 + 运算符两侧需要有一个空白符,否则会产生解析错误 */
边框内圆角
基于两个条件:
- outline不会跟着元素的圆角走
- box-shadow会跟着元素的圆角走(√2-1)r大。(r是border-radius)
限制:box-shadow的扩张半径需要比描边的宽度值小,但它同时要比
background: ten;
border-radius: .8em;
padding: 1em;
box-shadow: 0 0 0 .6em #655;
outline: .6em solid #655;
条纹背景
如果多个色标具有相同的位置,它们会产生一个无限小的过渡区域,过渡的起止色分别是第一个和最后一个指定值。从效果上看,颜色会在那个位置突然变化,而不是一个平滑的渐变过程。
background: linear-gradient(#fb3 50%, #58a 50%);
background-size: 100% 30px;
如果某个色标的位置值比整个列表中在它之前的色标的位置值都要小,则该色标的位置会被设置为它前面所有色标位置值的最大值。
background: linear-gradient(#fb3 50%, #58a 0);
background-size: 100% 30px;
background: linear-gradient(#fb3 33.33%, #58a 0, #58a 66.6%, yellowgreen 0);
background-size: 100% 30px;
垂直条纹
background: linear-gradient(to right, #fb3 50%, #58a 0);
background-size: 30px 100%;
斜向条纹
background: linear-gradient(45deg, #fb3 25%, #58a 0, #58a 50%, #fb3 0, #fb3 75%, #58a 0);
background-size: 43px 43px;
上述方法只适用于45°的斜向条纹。
linear-gradient()和radial-gradient()还各有一个循环式的加强版本:repeating-linear-gradient()和repeating-radial-gradient(),与前两者唯一的区别是:色标是无限循环重复的。
background: repeating-linear-gradient(45deg, #fb3, #fb3 15px, #58a 0, #58a 30px);
repeating-linear-gradient()可适用于任何角度
background: repeating-linear-gradient(60deg, #fb3, #fb3 15px, #58a 0, #58a 30px);
需要注意:不论角度如何,创建双色条时都需要四个色标。所以,最好用linear-gradient来创建水平、垂直条纹,用repeating-linear-gradient创建斜向条纹。
灵活的同色系条纹
可以将上最深的颜色作为背景色,同时将半透明白色的条纹叠加在背景色之上得到浅色条纹。
/* background: repeating-linear-gradient(30deg, #79b, #79b 15px, #58a 0, #58a 30px); */
background: #58a;
background-image: repeating-linear-gradient(30deg, rgba(255,255,255,.1), rgba(255,255,255,.1) 15px, transparent 0, transparent 30px);
复杂的背景图案
将多个渐变图案组合起来,让它们透过彼此的透明区域显示,就能创建复杂的背景图案。
网格
background: white;
background-image: linear-gradient(90deg, rgba(255,0,0,.5) 50%, transparent 0), linear-gradient(rgba(255,0,0,.5) 50%, transparent 0);
background-size: 30px 30px;
类似图纸辅助线的网格(网格中每个格子的大小可以调整,而网格线条的粗细保持固定)
background: #58a;
background-image: linear-gradient(white 1px, transparent 0), linear-gradient(90deg, white 1px, transparent 0);
background-size: 30px 30px;
将不同线宽、不同颜色的网格叠加起来
background: #58a;
background-image:
linear-gradient(white 2px, transparent 0),
linear-gradient(90deg, white 2px, transparent 0),
linear-gradient(rgba(255,255,255,.3) 1px, transparent 0),
linear-gradient(90deg, rgba(255,255,255,.3) 1px, transparent 0);
background-size: 75px 75px, 75px 75px, 15px 15px, 15px 15px;
波点
background: #655;
background-image: radial-gradient(tan 30%, transparent 0), radial-gradient(tan 30%, transparent 0);
background-size: 30px 30px;
background-position: 0 0, 15px 15px;
需要注意,第二层背景的偏移定位必须是tile宽高的一半。
棋盘
background: #eee;
background-image:
linear-gradient(45deg, #bbb 25%, transparent 0),
linear-gradient(45deg, transparent 75%, #bbb 0),
linear-gradient(45deg, #bbb 25%, transparent 0),
linear-gradient(45deg, transparent 75%, #bbb 0);
background-position: 0 0, 15px 15px, 15px 15px, 30px 30px;
background-size: 30px 30px;
background: #eee;
background-image:
linear-gradient(45deg, rgba(0,0,0,.25) 25%, transparent 0, transparent 75%, rgba(0,0,0,.25) 0),
linear-gradient(45deg, rgba(0,0,0,.25) 25%, transparent 0, transparent 75%, rgba(0,0,0,.25) 0);
background-position: 0 0, 15px 15px;
background-size: 30px 30px;
上述只是提供一种思路,实现棋盘背景图案,使用svg会是一种更好的选择。
background: #eee url('data:image/svg+xml, \
<svg xmlns="http://www.w3.org/2000/svg" width="100" height="100" fill-opacity=".25">\
<rect x="50" width="50" height="50" />\
<rect y="50" width="50" height="50" />\
</svg>');
background-size: 30px 30px;
更多CSS3图案库可以参考示例代码
伪随机背景
平铺的背景图案看起来有一些呆板,这是因为自然界中的事物都不是以无限平铺的方式存在的。
background: hsla(20, 40%, 90%);
background-image:
linear-gradient(90deg, #fb3 11px, transparent 0),
linear-gradient(90deg, #ab4 23px, transparent 0),
linear-gradient(90deg, #655 41px, transparent 0);
background-size: 41px 100%, 61px 100%, 83px 100%;
最顶层的贴片的重复规律最容易被察觉,所以尽量将平铺间距最大的贴片安排在最顶层。(上述例子中的 #fb3 )
为什么说是伪随机,是因为每隔一定距离就会重复一次,一个贴片的终点就是各层背景图案以不同间距重复数次后再次统一对齐的点,其实就是所有background-size的最小公倍数。所以,为了让最小公倍数最大化,这些数字最好是“相对质数”。同时为了增加随机性,甚至可以用质数来指定各组条纹的宽度。
所以说,想要模拟自然的随机效果,请使用质数作为循环单元。 (蝉原则)
请点击查看所有示例代码
[读书笔记] CSS揭秘-背景与边框的更多相关文章
- CSS揭秘之多重边框&连续的图像边框
1.多重边框 我们可以通过使用border-image来写一个多重边框,或使用多个元素来模拟多重边框,不过我们有更好的办法来制作一个多重边框,那就是使用box-shadow的第四个参数(称为扩张半径) ...
- [读书笔记] CSS权威指南2: 结构和层叠
层叠样式表中最基本的一个方面可能就是层叠——冲突的声明要通过这个层叠过程排序,并由此确定最终的文档表示.这个过程的核心是选择器及其相关声明的特殊性,以及继承机制. 特殊性 对于每个规则,用户代理会计算 ...
- HTML 学习笔记 CSS样式(外边框 外边框合并)
CSS外边距 围绕在元素边框的空白区域就是外边距 设置外边距会在元素外创建额外的空白 设置外边距的最简单的方法就是使用 margin 属性,这个属性接受任何长度单位.百分数值甚至负值. CSS ma ...
- 《Two Days DIV + CSS》读书笔记——CSS选择器
1.1.2 CSS选择器 CSS 选择器最基本的有四种:标签选择器.ID 选择器.类选择器.通用选择器. [标签选择器] 一个完整的 HTML 页面由很多不同的标签组成,而标签选择器,则是决定哪些标签 ...
- 《Two Days DIV + CSS》读书笔记——CSS控制页面方式
1.1 你必须知道的知识 (其中包括1.1.1 DIV + CSS的叫法解释:1.1.2 DIV + CSS 名字的误区:以及1.1.3 W3C简介.由于只是背景知识,跳过该章.) 1.2 你必须掌握 ...
- [读书笔记] CSS权威指南1: 选择器
通配选择器 可以与任何元素匹配,就像是一个通配符 /*每一个元素的字体都设置为红色*/ * { color: red; } 元素选择器 指示文档元素的选择器. /*为body的字体设置为红色*/ bo ...
- 《Web前端开发修炼之道》-读书笔记CSS部分
如何组织CSS-分层 应用 css 的能力分两部分:一部分是css的API,重点是如何用css控制页面内元素的样式:另一部分是css框架,重点是如何对 css 进行组织.如何组织 css 可以有多种角 ...
- 笔记-CSS空背景图片会导致页面被加载两次
如果页面样式的背景图片路径设置为'' 或 '#', 会导致页面被重复加载两次 (Chrome.56.0.2924.87 测试) 因为:空图片路径属性值,默认加载当前页面的URL作为图片路径 Safar ...
- 前端学习笔记--CSS样式--背景和超链接
1.背景 2.超链接: 举例:
随机推荐
- NodeJS05
商品分类模块 分类model const mongoose = require('mongoose') const schema = new mongoose.Schema({ name: { typ ...
- linux备忘录-档案与文件系统的压缩与打包
知识点 文件扩展名与压缩解压缩工具 .Z -> compress程序压缩的档案 .gz -> gzip程序压缩的档案 .bz2 -> bzip2程序压缩的档案 .tar -> ...
- OpenFlow-Enaling innvation in Campus Networks
OpenFlow-Enaling innvation in Campus Networks 出现问题 背景 Networks have become part of the critical infr ...
- Tomcat学习笔记(四)
Servlet容器部分 servlet容器用来处理请求servlet资源,并为web客服端填充response对象模块,在tomcat中,共有4种类型的容器,分别是:Engine.Host.Conte ...
- 学习Git的一点心得以及如何把本地修改、删除的代码上传到github中
一:学习Github的资料如下:https://git.oschina.net/progit/ 这是一个学习Git的中文网站,如果诸位能够静下心来阅读,不要求阅读太多,只需要阅读前三章,就可以掌握Gi ...
- 非常好的Linux教程,让你的linux之路更通畅
1 第1讲.Linux应用与发展(上) 2013-10-22 17:43 | 播放(46) | 评论(0) | 时长:51:38 2 第1讲.Linux应用与发展(下) 2013-10-22 17 ...
- Pandas之DataFrame——Part 3
''' [课程2.] 数值计算和统计基础 常用数学.统计方法 ''' # 基本参数:axis.skipna import numpy as np import pandas as pd df = pd ...
- [ZJOI2008]树的统计——树链剖分
本题是一个树链剖分裸题,由于比较菜,老是RE,后来发现是因为使用了全局变量. /************************************************************ ...
- Inline Hook
@author: dlive IAT Hook时如果要钩取的API不在IAT中(LoadLibrary后调用),则无法使用该技术.而Inline Hook不存在这个限制. 0x01 Inline Ho ...
- error C2440: 'static_cast' : cannot convert from 'UINT (__thiscall CStaticLink::* )(CPoint)' to 'LRESULT (__thiscall CWnd::* )(CPoint) (转)
原文转自 http://blog.csdn.net/yinxing408033943/article/details/7601698 解决方法: 找到 UNIT CStaticLink::OnNcH ...