咳咳,一篇笔记,还是不要超过800行的好,太长了,也看不赢,书写的工具也折腾不起所以,学习css,就这样持续到了第四章
第三章里面,我们主要学了伪类、伪元素、导航栏、下拉菜单、提示工具、图像透明度。
接下来要讲属性选择器、边框、背景、渐变、文本效果、过渡。
友情提示:我的博客页面右下方的汉堡图标,点击后会有目录大纲出来哦!让你看文更高效!😋
让我为你点一首歌吧!♪一直陪着你ヾ(·▽·ヾ)
开始静静享受歌曲吧!
<%- toc(_page.content) %>
\/\
<%- toc(\_page.content) %>
%->
属性选择器
具有特定属性的HTML元素样式
具有特定属性的HTML元素样式不仅仅是class和id。
注意:IE7和IE8需声明!DOCTYPE才支持属性选择器!IE6和更低的版本不支持属性选择器。
属性选择器
下面的例子是把包含标题(title)的所有元素变为蓝色:1
2
3
4[title]
{
color:blue;
}
属性和值选择器
下面的实例改变了标题title=’runoob’元素的边框样式:1
2
3
4[title=runoob]
{
border:5px solid green;
}
属性和值的选择器:多值
下面是包含指定值的title属性的元素样式的例子,使用(~)分隔属性和值:1
[title~=hello] { color:blue; }
下面是包含指定值的lang属性的元素样式的例子,使用(|)分隔属性和值:1
[lang|=en] { color:blue; }
表单样式
属性选择器样式无需使用class或id的形式:1
2
3
4
5
6
7
8
9
10
11
12
13input[type="text"]
{
width:150px;
display:block;
margin-bottom:10px;
background-color:yellow;
}
input[type="button"]
{
width:120px;
margin-left:35px;
display:block;
}
边框
用 CSS3,你可以创建圆角边框,添加阴影框,并作为边界的形象而不使用设计程序,如 Photoshop。
在本章中,您将了解以下的边框属性:
border-radius
box-shadow
border-image
属性 | 说明 |
---|---|
border-image | 设置所有边框图像的速记属性。 |
border-radius | 一个用于设置所有四个边框- -半径属性的速记属性 |
box-shadow | 附加一个或多个下拉框的阴影 |
border-radius圆角
在 CSS2 中添加圆角棘手。我们不得不在每个角落使用不同的图像。
在 CSS3 中,很容易创建圆角。
在 CSS3 中 border-radius 属性被用于创建圆角:
这是圆角边框!1
2
3
4
5
6
7在div中添加圆角元素:
div
{
border:2px solid;
border-radius:25px;
}
box-shadow盒阴影
CSS3 中的 box-shadow 属性被用来添加阴影:
在div中添加box-shadow属性1
2
3
4div
{
box-shadow: 10px 10px 5px #888888;
}
border-image边界图片
有了 CSS3 的 border-image 属性,你可以使用图像创建一个边框:
border-image 属性允许你指定一个图片作为边框! 用于创建上文边框的原始图像:
在 div 中使用图片创建边框:1
2
3
4
5
6div
{
border-image:url(border.png) 30 30 round;
-webkit-border-image:url(border.png) 30 30 round; /* Safari 5 and older */
-o-border-image:url(border.png) 30 30 round; /* Opera */
}
border-image属性
默认值: none 100% 1 0 stretch
语法border-image: source slice width outset repeat|initial|inherit;
值 |描述
:-:|:-:
border-image-source |用于指定要用于绘制边框的图像的位置border-image-source: none(没有图像被使用)|image(边框使用图像的路径);
border-image-slice |图像边界向内偏移
border-image-width |图像边界的宽度
border-image-outset |用于指定在边框外部绘制 border-image-area 的量
border-image-repeat |用于设置图像边界是否应重复(repeat)、拉伸(stretch)或铺满(round)。
border-image-slice指定图像的边界向内偏移
语法border-image-slice: number|%|fill;
指定图像的边界向内偏移:1
2
3
4
5div
{
border-image-source: url(border.png);
border-image-slice: 50% 50%;
}
注意: 此属性指定==顶部,右,底部,左边缘==的图像向内偏移,分为九个区域:四个角,四边和中间。
图像中间部分将被丢弃(完全透明的处理),除非填写关键字。
如果省略第四个数字/百分比,它和第二个相同的。
如果也省略了第三个,它和第一个是相同的。
如果也省略了第二个,它和第一个是相同的。
border-image-outset在边框外部绘制
语法border-image-outset: length(设置边框图像与边框(border-image)的距离,默认为0。)|number(代表相应的 border-width 的倍数);
border-image-outset用于指定在边框外部绘制 border-image-area
的量,包括上下部和左右部分。
如果第四个值被省略,它和第二个是相同的。
如果也省略了第三个,它和第一个是相同的。
如果也省略了第二个,它和第一个是相同的。
不允许border-im-outset拥有负值。
设置border-img-outset属性:
1 | div |
border-image-repeat重复图像的方式
设置重复图像的方式:1
2
3
4div {
border-image-source: url(border.png);
border-image-repeat: repeat;
}
border-image-repeat 属性用于图像边界是否应重复(repeated)、拉伸(stretched)或铺满(rounded)。
语法:border-image-repeat: stretch(默认值。拉伸图像来填充区域)|repeat(平铺(repeated)图像来填充区域。)|round(类似 repeat 值。如果无法完整平铺所有图像,则对图像进行缩放以适应区域。)|space(类似 repeat 值。如果无法完整平铺所有图像,扩展空间会分布在图像周围)|initial|inherit;
背景
CSS3中包含几个新的背景属性,提供更大背景元素控制。
在本章您将了解以下背景属性:
background-image
background-size
background-origin
background-clip
background-image添加背景图片
CSS3中可以通过background-image属性添加背景图片。
不同的背景图像和图像用逗号隔开,所有的图片中显示在最顶端的为第一张。1
2
3
4
5#example1 {
background-image: url(img_flwr.gif), url(paper.gif);
background-position: right bottom, left top;
background-repeat: no-repeat, repeat;
}
可以给不同的图片设置多个不同的属性1
2
3#example1 {
background: url(img_flwr.gif) right bottom no-repeat, url(paper.gif) left top repeat;
}
background-size背景图像的大小
background-size指定背景图像的大小。CSS3以前,背景图像大小由图像的实际大小决定。
CSS3中可以指定背景图片,让我们重新在不同的环境中指定背景图片的大小。您可以指定像素或百分比大小。
你指定的大小是相对于父元素的宽度和高度的百分比的大小。1
2
3
4
5
6div
{
background:url(img_flwr.gif);
background-size:80px 60px;
background-repeat:no-repeat;
}
伸展背景图像完全填充内容区域:1
2
3
4
5
6div
{
background:url(img_flwr.gif);
background-size:100% 100%;
background-repeat:no-repeat;
}
background-Origin背景图像的位置区域
background-Origin属性指定了背景图像的位置区域。
content-box, padding-box,和 border-box区域内可以放置背景图像。1
2
3
4
5
6
7
8
9在 content-box 中定位背景图片:
div
{
background:url(img_flwr.gif);
background-repeat:no-repeat;
background-size:100% 100%;
background-origin:content-box;
}
多个背景图像
CSS3 允许你在元素上添加多个背景图像。
在 body 元素中设置两个背景图像:1
2
3
4body
{
background-image:url(img_flwr.gif),url(img_tree.gif);
}
background-clip背景剪裁
CSS3中background-clip背景剪裁属性是从指定位置开始绘制1
2
3
4
5
6#example1 {
border: 10px dotted black;
padding: 35px;
background: yellow;
background-clip: content-box;
}
语法background-clip: border-box(默认值。背景绘制在边框方框内(剪切成边框方框)。)|padding-box(背景绘制在衬距方框内(剪切成衬距方框)。)|content-box(背景绘制在内容方框内(剪切成内容方框)。);
渐变(Gradients)
CSS3 渐变(gradients)可以让你在两个或多个指定的颜色之间显示平稳的过渡。
以前,你必须使用图像来实现这些效果。但是,通过使用 CSS3 渐变(gradients),你可以减少下载的时间和宽带的使用。此外,渐变效果的元素在放大时看起来效果更好,因为渐变(gradient)是由浏览器生成的。
CSS3 定义了两种类型的渐变(gradients):
- 线性渐变(Linear Gradients)- 向下/向上/向左/向右/对角方向
- 径向渐变(Radial Gradients)- 由它们的中心定义
linear-gradient线性渐变
为了创建一个线性渐变,你必须至少定义两种颜色结点。颜色结点即你想要呈现平稳过渡的颜色。同时,你也可以设置一个起点和一个方向(或一个角度)。
语法background: linear-gradient(direction, color-stop1, color-stop2, ...);
线性渐变-从上到下(默认情况下)
从顶部开始的线性渐变。起点是红色,慢慢过渡到蓝色:
从上到下的线性渐变:1
2
3#grad {
background: linear-gradient(red, blue); /* 标准的语法 */
}
线性渐变-从左到右to right
下面的实例演示了从左边开始的线性渐变。起点是红色,慢慢过渡到蓝色:从左到右的线性渐变:1
2
3#grad {
background: linear-gradient(to right, red , blue); /* 标准的语法 */
}
线性渐变-对角to bottom right
你可以通过指定水平和垂直的起始位置来制作一个对角渐变。
从左上角开始(到右下角)的线性渐变。起点是红色,慢慢过渡到蓝色:从左上角到右下角的线性渐变:
1 | #grad { |
xxdeg
使用角度
如果你想要在渐变的方向上做更多的控制,你可以定义一个角度,而不用预定义方向(to bottom、to top、to right、to left、to bottom right,等等)。
语法background: linear-gradient(angle, color-stop1, color-stop2);
角度是指水平线和渐变线之间的角度,逆时针方向计算。
换句话说,0deg
将创建一个从下到上
的渐变,90deg
将创建一个从左到右
的渐变。
xx%
使用多个颜色结点
下面的实例演示了如何设置多个颜色结点:
带有多个颜色结点的从上到下的线性渐变:1
2
3#grad {
background: linear-gradient(red, green, blue); /* 标准的语法 */
}
创建一个带有彩虹颜色和文本的线性渐变:1
2
3
4
5
6
7
8
9
10
11
12
13<style>
#grad1 {
height: 55px;
background: linear-gradient(to right, red, orange, yellow, green, blue, indigo, violet); /* 标准的语法(必须放在最后) */
}
</style>
<body>
<div id="grad1" style="text-align:center;margin:auto;color:#888888;font-size:40px;font-weight:bold">
渐变背景
</div>
<p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>
rgba()使用透明度(transparent)
CSS3 渐变也支持透明度(transparent),可用于创建减弱变淡的效果。
为了添加透明度,我们使用rgba()
函数来定义颜色结点。
rgba() 函数中的最后一个参数可以是从 0 到 1 的值,它定义了颜色的透明度:0 表示完全透明,1 表示完全不透明。
下面的实例演示了从左边开始的线性渐变。起点是完全透明,慢慢过渡到完全不透明的红色:1
2
3
4
5
6
7
8
9
10
11
12
13
14<style>
#grad1 {
height: 200px;
background: linear-gradient(to right, rgba(255,0,0,0), rgba(255,0,0,1)); /* 标准的语法(必须放在最后) */
}
</style>
<body>
<h3>线性渐变 - 透明度</h3>
<p>为了添加透明度,我们使用 rgba() 函数来定义颜色结点。rgba() 函数中的最后一个参数可以是从 0 到 1 的值,它定义了颜色的透明度:0 表示完全透明,1 表示完全不透明。</p>
<div id="grad1"></div>
<p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>
repeating-linear-gradient()重复的线性渐变
repeating-linear-gradient() 函数用于重复线性渐变:1
2
3#grad {
background: repeating-linear-gradient(red, yellow 10%, green 20%);
}
radial-gradient径向渐变
径向渐变由它的中心定义。
为了创建一个径向渐变,你也必须至少定义两种颜色结点。颜色结点即你想要呈现平稳过渡的颜色。同时,你也可以指定渐变的中心、形状(圆形或椭圆形)、大小。
默认情况下:
- 渐变的中心是 center(表示在中心点),
- 渐变的形状是 ellipse(表示椭圆形),
- 渐变的大小是 farthest-corner(表示到最远的角落)。
语法background: radial-gradient(center, shape size, start-color, ..., last-color);
径向渐变 - 颜色结点均匀分布(默认情况下)1
2
3#grad {
background: radial-gradient(red, green, blue); /* 标准的语法 */
}
颜色结点不均匀分布的径向渐变:1
2
3#grad {
background: radial-gradient(red 5%, green 15%, blue 60%); /* 标准的语法 */
}
shape设置形状
shape 参数定义了形状。它可以是值 circle 或 ellipse。其中,circle 表示圆形,ellipse 表示椭圆形。默认值是 ellipse。
size不同尺寸大小关键字的使用
size 参数定义了渐变的大小。它可以是以下四个值:
closest-side
farthest-side
closest-corner
farthest-corner
repeating-radial-gradient()重复的径向渐变
repeating-radial-gradient() 函数用于重复径向渐变
文本效果
CSS3中包含几个新的文本特征。
在本章中您将了解以下文本属性:
text-shadow
box-shadow
text-overflow
word-wrap
word-break
过渡
CSS3中,我们为了添加某种效果可以从一种样式转变到另一个的时候,无需使用Flash动画或JavaScript。
CSS3 过渡是元素从一种样式逐渐改变为另一种的效果。
要实现这一点,必须规定两项内容:
指定要添加效果的CSS属性
指定效果的持续时间。
应用于宽度属性的过渡效果,时长为 2 秒:1
2
3
4
5div
{
transition: width 2s;
-webkit-transition: width 2s; /* Safari */
}
如果未指定的期限,transition将没有任何效果,因为默认值是0。
指定的CSS属性的值更改时效果会发生变化。一个典型CSS属性的变化是用户鼠标放在一个元素上时:
规定当鼠标指针悬浮(:hover)于 <div>
元素上时:1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18div
{
width:100px;
height:100px;
background:red;
transition:width 2s;
-webkit-transition:width 2s; /* Safari */
}
div:hover
{
width:300px;
}
</style>
</head>
<body>
<p><b>注意:</b>该实例无法在 Internet Explorer 9 及更早 IE 版本上工作。</p>
注意: 当鼠标光标移动到该元素时,它逐渐改变它原有样式
多项改变
要添加多个样式的变换效果,添加的属性由逗号分隔:
添加了宽度,高度和转换效果:
1 | div |
过渡属性
下表列出了所有的过渡属性:
属性 | 描述 |
---|---|
transition | 简写属性,用于在一个属性中设置四个过渡属性。 |
transition-property | 规定应用过渡的 CSS 属性的名称。 |
transition-duration | 定义过渡效果花费的时间。默认是 0。 |
transition-timing-function | 规定过渡效果的时间曲线。默认是 “ease”。 |
transition-delay | 规定过渡效果何时开始。默认是 0。 |
1 | <style> |
与上面的例子相同的过渡效果,但是使用了简写的 transition 属性:1
2
3
4div
{
transition: width 1s linear 2s;
}