[读书笔记] 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.超链接: 举例:
随机推荐
- 剑指offer-替换空格02
题目描述 请实现一个函数,将一个字符串中的每个空格替换成“%20”.例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy. class Solution: ...
- mysql安装目录、配置文件存放位置
linux系统下,如何知道mysql使用的配置文件到底是哪个呢?linux自带的mysql的安装目录又是什么呢?数据存放在什么目录下? 1.linux系统自带的mysql,其安装目录及数据目录查看方法 ...
- android配置开发环境
1.下载Java SE并安装. 下载地址:http://www.oracle.com/technetwork/java/javase/downloads/index.html 配置环境变量 我的电脑- ...
- sql优化(转)
explain +sql分析sql语句执行效率 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中使用! ...
- 【Luogu】P3760异或和(权值树状数组)
题目链接 再次声明以后我见到位运算一定第一时间想把它拆成每一位算 本题就是有个前缀和sum[],然后让你求每一位有多少对i,j满足sum[i]-sum[j]在那一位上是1 考虑怎样才能减出1来 如果s ...
- mplab xIde 编译成功,但不能生成Hex文件
设置不对 如果还不行,在设置下面
- Tomcat学习笔记(一)
Tomcat目录结构的认识 tomcat是Apache旗下的一个开源Servlet的容器,实现了对Servlet和JSP技术支持. 通过http://tomcat.apache.org/ 下载tomc ...
- hibernate中Configuration类的作用
问题:我们在获得一个SessionFactory对象的时候经常是写下面这行代码: SessionFactory sessionFactory = new Configuration().configu ...
- 一元多项式的表示及相加(抽象数据类型Polynomial的实现)
// c2-6.h 抽象数据类型Polynomial的实现(见图2.45) typedef struct // 项的表示,多项式的项作为LinkList的数据元素 { float coef; // 系 ...
- async-http
android-async-http开源框架可以是我们轻松的获取网络数据或者向服务器发送数据,使用起来也很简单,下面做简单介绍,具体详细使用看官网:https://github.com/loopj/a ...