CSS揭秘读书笔记 (一)
CSS揭秘读书笔记 (一)
一、半透明边框
- 要想实现半透明边框可以使用border:
border: 10px solid hsla(0,0%,100%,.5);
background:white;
background-clip:padding-box;
① hsla:h是色调,取值范围是0-360。s是饱和度,取值范围是0%-100%。l是亮度,取值范围是0%-100%。a是透明度,取值范围是0-1。
② background-clip:用于调整背景图的显示区域,有3个值,border-box:背景图延伸在边框后面。padding-box:背景图不出现在内边距区域,不出现在边框后面。content-box:背景图只出现在内容后面,不出现在内边距和边框后面。

二、多重边框
- 使用box-shadow(支持IE9),即多重投影:
background:yellow;
box-shadow: 0 0 0 10px #655,
0 0 0 15px deeppink,
0 2px 5px 15px rgba(0, 0, 0, .6);

2. 使用outline(支持IE8):
outline:与border类似但是不占空间,即不会被算入元素的高宽中。但这种解决方案只适用于双层边框,而且边框不一定会贴合border-radius属性产生的圆角
background-color: greenyellow;
border: 10px solid #655;
outline: 5px solid deeppink;

三、灵活的背景定位
我们可以通过指定背景图片对任意角的偏移量来灵活的展现背景,背景下载图片地址:http://csssecrets.io/images/code-pirate.svg
1. 以下代码使得背景图片永远处于内容的最右下角,而不是背景颜色的最下角,位置可以随padding的改变而改变。
padding: 30px;
background: url(../img/code-pirate.svg) no-repeat right bottom #58a;
background-origin: content-box; // 使用内容宽度

2. 使用calc()方案,部分支持IE。
以下代码会使图片定位在距离背景颜色的右边20px,距离底部10px。记住在calc函数中运算符号两边必须有空格,否则会错误。
padding: 30px;
background: url(../img/code-pirate.svg) no-repeat #58a;
background-position: calc(100% - 20px) calc(100% - 10px);

四、边框内圆角
- 使用两个元素达成效果
<div class="something-meaningful ">
<div>
我有一些很好看的内部圆边,外部直边不是吗?
</div>
</div>
.something-meaningful {
width: 15rem;
height: 5rem;
background-color: #655;
padding: .8rem;
}
.something-meaningful>div {
background: tan;
border-radius: .8rem;
padding: 1rem;
}

2. 使用1个元素达成效果,同时使用outline和box-shadow来达成效果,其中描边的取值至少是border-radius值的(√2 – 1),因为(√2 – 1) < 0.5 ,所以可以直接取一半,以下面代码为例,box-shadow和-outline的值至少要是0.4rem,我取了0.6rem。
<div class="something-meaningful">
我有一些很好看的内部圆边,外部直边不是吗?
</div>
.something-meaningful {
width: 15rem;
height: 5rem;
background-color: #655;
background: tan;
border-radius: .8rem;
padding: 1rem;
outline: .6rem solid #655;
box-shadow: 0 0 0 .6em #655;
}

五、条纹背景
1. 横向条纹:
.linear-gra {
background: linear-gradient(#fb3 30%,#58a 30%,#58a 60%,greenyellow 0);
}
可以使用0来减少重复输入,因为如果某个色标的位置值比整个列表中在他之前的色标位置值都小,则该色标的位置会被设置为他前面所有色标位置值的最大值。

2. 垂直条纹:加一个90deg
.linear-gra {
background: linear-gradient(90deg, #fb3 30%, #58a 30%,#58a 60%,greenyellow 0);
}

3. 60度间隔条纹背景:
.linear-gra {
background: repeating-linear-gradient(60deg,#fb3,#fb3 15px,#58a 0,#58a 30px);
}
可以使用repeating-linear-gradient 来进行重复,色标是无限循环的

4. 30度同色系条纹背景:
.linear-gra {
background: #58a;
background-image: repeating-linear-gradient(30deg, hsla(0, 0%, 100%, .1),hsla(0, 0%, 100%, .1) 15px,transparent 0, transparent 30px);
}
同色系的条纹可以使用hsla来进行简化

CSS揭秘读书笔记 (一)的更多相关文章
- css 揭秘-读书笔记
css 揭秘 [希]Lea verou 著 css 魔法 译 该书涵盖7大主题,47个css技巧,是css进阶必备书籍,开阔思路,探寻更优雅的解决方案.这本书完全用css渲染出的html写成的(布局. ...
- css揭秘读书笔记
currentColor属性让hr和段落相同的颜色: div { color: red; } hr { background: currentColor; /* 一定要设置高度*/ height: 0 ...
- 《CSS揭秘》笔记(一)
前言 我们在现代 CSS 中所面临的挑战已经不在于如何绕过这些转瞬即逝的浏览器 bug.如今的挑战是,在保证 DRY ① .可维护.灵活性.轻量级并且尽可能符合标准的前提下,把我们手中的这些CSS特性 ...
- Spring揭秘 读书笔记 三 bean的scope与FactoryBean
本书可作为王富强所著<<Spring揭秘>>一书的读书笔记 第四章 BeanFactory的xml之旅 bean的scope scope有时被翻译为"作用域&quo ...
- spring揭秘 读书笔记 二 BeanFactory的对象注册与依赖绑定
本文是王福强所著<<spring揭秘>>一书的读书笔记 我们前面就说过,Spring的IoC容器时一个IoC Service Provider,而且IoC Service Pr ...
- spring揭秘 读书笔记 一 IoC初探
本文是王福强所著<<spring揭秘>>一书的读书笔记 ioc的基本概念 一个例子 我们看下面这个类,getAndPersistNews方法干了四件事 1 通过newsList ...
- 《精通CSS》读书笔记(一)
最近新添16本书,目前开始看陈剑瓯翻译的<精通CSS——高级Web标准解决方案>(Andy Budd, CSS Mastery -- Advanced Web Standards Solu ...
- spring揭秘 读书笔记 二 BeanFactory的对象注冊与依赖绑定
本文是王福强所著<<spring揭秘>>一书的读书笔记 我们前面就说过,Spring的IoC容器时一个IoC Service Provider,并且IoC Service Pr ...
- 《Two Days DIV + CSS》读书笔记——CSS选择器
1.1.2 CSS选择器 CSS 选择器最基本的有四种:标签选择器.ID 选择器.类选择器.通用选择器. [标签选择器] 一个完整的 HTML 页面由很多不同的标签组成,而标签选择器,则是决定哪些标签 ...
随机推荐
- 《CSS3秘籍》(第三版)-读书笔记
第3章 选择器:明确设置哪些样式 每个样式(或者规则)由两个主要部分组成:选择器是告诉浏览器要格式化什么内容:声明块则列出浏览器用来给选择器定义样式的格式化指令. 1.标签选择器:整体控制 标签选择器 ...
- 关于Beam Search
Wiki定义:In computer science, beam search is a heuristic search algorithm that explores a graph by exp ...
- thymeleaf 中文乱码问题
使用thymeleaf后,即使使用org.springframework.web.filter.CharacterEncodingFilter也不能解决中文乱码问题了, 后来发现在org.thymel ...
- Mysql导入数据库的方法
mysql导入数据库的方法 | 浏览:41023 | 更新:2012-11-01 19:45 1 2 3 4 5 6 7 分步阅读 MySQL是一个中.小型关系型数据库管理系统,由瑞典MySQL AB ...
- ue4 SNew补遗
上一篇分析了SNew背后的实现,但是有一个关键问题遗漏了,那就是: #define SNew( WidgetType, ... ) \ MakeTDecl<WidgetType>( #Wi ...
- iOS多线程编程指南(二)线程管理
当应用程序生成一个新的线程的时候,该线程变成应用程序进程空间内的一个实体.每个线程都拥有它自己的执行堆栈,由内核调度独立的运行时间片.一个线程可以和其他线程或其他进程通信,执行I/O操作,甚至执行任何 ...
- JDBC常用接口详解
JDBC中常用接口详解 ***DriverManager 第一.注册驱动 第一种方式:DriverManager.registerDriver(new com.mysql.jdbc.Driver()) ...
- mysql中的高级查询
以前学习的查询语法: select 字段名 from 表名 where 条件 其实,查询的语法变化很多: 1. select 可以查询表达式, 表达式就是 运算符+操作数. 比如 1 + 1 2 * ...
- nodejs: 理解Buffer
学习nodejs中buffer这一章,有一段写到buffer的拼接,其中一段源码非常优美,特拿来与大家共享. var chunks = []; var size = 0; res.on('data', ...
- 怎么定义 logger
随便打开一个 spring 的 源文件,比如 PathMatchingResourcePatternResolver.class 里面是这样定义logger 的 import org.apache. ...