标签:背景 ora 堆叠 单位 linear anim webkit 动画 没有
我们知道,这几年来智能手机的高速发展使得人们使用移动端上网的时间和人数已经超过了PC端。例如在2015年,就中国电商而言,各电商平台在移动端持续发力,移动端购物占比不断攀升,双11期间,天猫交易额突破912亿元,其中移动端交易额占比68%,京东移动端下单量占比达到74%,其余各大电商平台移动端的支付比例也在60%-80%之间。即移动端在2015年超越PC端,成为网购市场的主流选择。这也使得网页设计师需要更加注重移动端的网页制作,而移动端对于HMTL5和CSS3目前已经支持的非常好了,所以学习HTML5和CSS3已经是大势所趋,因此,这里会主要探讨基本的CSS3知识。
我们知道css即cascading style sheet,中文是层叠样式表的意思。它用来控制网页的样式和布局,而css3正是最新的css标准,但是主流的浏览器对css3已经支持的很好了,不!除了IE!!因为css3中的很多属性都不能被IE9以下的浏览器支持,然而国内目前还有很多的IE8浏览器,甚至还有IE6!所以,一般在PC端我们不能完全使用CSS3,而在移动端,几乎所有的浏览器都是支持css3的。(注意:实际上目前css3仍在开发中...)
css3中有以下几种重要的模块,如 选择器、盒模型、背景和边框、文字特效、2D/3D转换、动画、多列布局和用户界面。
这部分内容将会介绍三个重要的属性:border-radius、box-shadow、border-image。
1.border-radius
我们知道在css2中添加圆角是很棘手的,我们必须在每个角落使用不同的图像,或者是使用PS来解决这个问题。因此,当我知道存在border-radius属性时,我还是十分开心的,终于可以轻松的创建圆角了。如下所示:
效果图如下:
这样一个半径为5px的圆角。当然,它还有更为强大的功能--画圆!
代码如下所示:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>圆角</title> <style> .circle{width: 30px;height: 30px;background: red;border-radius: 15px;} </style> </head> <body> <div class="circle"></div> </body> </html>
效果图如下所示:
实际上,它的四个角还可以分别设置即:border-radius:5px 10px 15px 20px;分别表示左上角、右上角、右下角、左下角的半径。html代码同上,css如下代码:
.circle{ width: 30px;height: 30px;background: red; border-radius: 5px 10px 15px 20px; }
我们可以得到效果如下:
另外,如果对border-radius指定两个值,那么第一个值为左上角和右下角,第二个值为右上角和左下角。如果指定三个值,那么第一个值为左上角,第二个值为右上角和左下角,第三个值为右下角。这里例子看这里。
2.box-shadow
这个属性可以用来添加阴影。
如box-shadow:10px 10px 5px blue;表示水平阴影的位置向右偏移10px;竖直阴影的位置向下偏移10px;阴影模糊的距离为5px; 阴影的颜色为蓝色。(注意:对于水平阴影的位置和竖直阴影的位置使用的坐标是:向右为X的正半轴、向下为Y的正半轴)
css代码如下:
div{width: 30px;height: 30px;background: red; box-shadow:10px 20px 15px blue;}
效果图如下:
3.border-image
使用该属性,我们可以使用图片创建一个边框,即它允许我们指定一个图片作为边框作为创建边框的原始图像。这个属性暂时不介绍。
1.background-image属性
该属性可以来添加多张背景图片,不同的背景图像用逗号隔开即可。同时可以使用background-position和background-repeat来设置不同不同图片的值,用逗号隔开,举例如下:
代码如下:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>image</title> <style> #example1 { background-image: url(img_flwr.gif), url(paper.gif); background-position: right bottom, left top; background-repeat: no-repeat, repeat; padding: 15px; } </style> </head> <body> <div id="example1"> <h1>Lorem Ipsum Dolor</h1> <p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.</p> <p>Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat.</p> </div> </body> </html>
效果图如下:
2.background-size属性
如果不使用css3,那么我们想要改变背景图片的大小就只能修改其真实大小,而使用了css3,我们就可以使用background-size来改变大小了。举例如下:
对于一个div,css代码如下(注意:一定要设定div的宽度和高度,否则背景图片不可能显示):
div{ width: 505px; height: 505px; background-image: url(shenme.jpg); /*background-size: 50px 100px;*/ background-repeat: no-repeat; }
效果图如下:
如果加上background-size:50px 100px;即宽为50px; 高为100px; 那么效果如下:
另外,我们也可以使用百分比大小,它是相对与父元素的宽度和高度的百分比的大小。
如background-size:50% 50%;效果图如下:
即宽度和高度就成了父元素(div)的一半了。
3.backgrond-origin属性。
这个属性指定了背景图像的位置区域。即背景图片能放在哪里,这个属性默认是padding-box。
举例如下:
代码如下,此时为默认值,即padding-box:
width: 505px; height: 505px; border:80px solid gray; padding: 50px; background-image: url(shenme.jpg); background-size: 50% 50%; background-repeat: no-repeat; background-origin:padding-box;
效果如下:
当我们把background-origin设置位border-box效果如下:
我们发现背景图实际上是从border的最外层开始的。(实际上这里把border的样式设置位dotted会更容易观察,大家可以自行尝试)
当我们把background-origin设置为content-box,效果如下:
4.background-clip属性
该属性可以裁剪指定位置的背景,同样可以设置属性值为content-box,padding-box和border-box。具体例子看这里。
css3渐变(gradients)可以让你在两个或者多个指定的颜色之间显示平稳的过度。如下图所示:
即通过css3我们可以做出上述“彩虹”。下面就让我们一起来学习吧。
css3中规定了两种方式的渐变:
1.css3线性渐变
这种渐变你必须定义至少两种颜色,也就是说可以更多种甚至不限制数量。
语法如下:
background: linear-gradient(direction, color-stop1, color-stop2, ...);
第一个参数为方向,如果我们不指定,那么默认为从上到下。第一个颜色参数即为开始的第一个颜色,注意:由于不同的浏览器支持程度不同,所以我们需要多写几句。如下:
值得注意的是对于标准的语法,必须放在最后一句。(这一部分以及更多规范可以看我的博文《如何写出优雅的css代码?》)
效果如下所示:
如果需要从左到右,可以添加第一个参数,对于标准而言,第一个参数是to right,如下:
效果如下所示:
当然,我们还可以使用任何我们想要的角度,语法如下:
background:linear-gradient(angle,color1,color2,....);
注意,角度如下所示:
如下列代码:
div{ width: 500px;height: 500px; background: -webkit-linear-gradient(50deg, red , blue); /* Safari 5.1 - 6.0 */ background: -o-linear-gradient(50deg, red, blue); /* Opera 11.1 - 12.0 */ background: -moz-linear-gradient(50deg, red, blue); /* Firefox 3.6 - 15 */ background: linear-gradient(50deg, red , blue); /* 标准的语法 */ }
效果如下所示:
2.使用透明度(Transparency)
在css3中也支持透明度,可以用于创建减弱变淡的效果。方法很简单,只需要把颜色使用rgba()来表达即可,rgba的最后一个值表示不透明度:0表示完全透明,1表示完全不透明。
代码如下:
width: 500px;height: 500px; background: -webkit-linear-gradient(50deg, rgba(255,0,0,0.7) , rgba(0,0,255,0.3)); /* Safari 5.1 - 6.0 */ background: -o-linear-gradient(50deg, rgba(255,0,0,0.7) , rgba(0,0,255,0.3)); /* Opera 11.1 - 12.0 */ background: -moz-linear-gradient(50deg, rgba(255,0,0,0.7) , rgba(0,0,255,0.3)); /* Firefox 3.6 - 15 */ background: linear-gradient(50deg, rgba(255,0,0,0.7) , rgba(0,0,255,0.3)); /* 标准的语法 */
效果如下:
3.css3还支持重复的线性渐变即repeating-linear-gradient()。
4.径向渐变。
为了创建一个径向渐变,我们至少定义两种颜色结点。同时也可以指定渐变的中心、形状(圆形或椭圆形)、大小。默认情况下,渐变的中心是center,形状是ellipse,渐变的大小是fasthest-corner(表示最远的角落)。其中形状还可以是circle(圆形)、大小还可以是choset-side和closest-corner和farthest-side。
语法:background: radial-gradient(center, shape size, start-color, ..., last-color);
举例如下:
在css3中包含了下面几个新的文本特征:text-shadow、box-shadow、text-overflow、word-wrap、word-break。
1.text-shadow。
显然这个属性即为给文本添加阴影。值包括水平阴影、垂直阴影、模糊的举例以及阴影的颜色,和我们之前讲过的box-shadow的方法是相同的。举例如下:
效果如下:
效果还是挺不错的!
2.box-shadow
这个属性在前面是讲过的。它接受四个值,第一个是水平移动距离、第二个是竖直移动距离、第三个是模糊的距离、第四个是阴影的颜色。如下所示:
效果如下:
这样,我们不需要美工就可以达到自己想要的效果了。
实际上,我们还可以给box添加多个阴影,如下所示:
得到的结果如下所示:
也就是说,我们不仅可以添加多个阴影,还可以对阴影的颜色使用透明度。
3.white-space
其属性值有normal(默认)、pre、nowrap、pre-wrap、pre-line、inherit。
这个属性指定元素内的空白如何处理。其默认值是normal,即空白会被浏览器忽略。
在浏览器的显示效果如下:
我们发现它只是把最前面的空格都去掉了,中间的空格压缩,但没有完全去除。
而white-space的属性值为pre时,他会保留所有的空格:
它在保留了所有空格的情况下且在浏览器上这段文字永远不会换行。
而white-space的属性值是nowrap时,它没有保留空格,但是不会换行(除非遇到br标签):(nowrap即不包裹,即不会换行)
当white-space的属性值是pre-wrap时,会保留空白符序列,但是可以正常的换行。如下:(pre只不会忽略空格、wrap只要包裹,即换行)效果如下:
当white-space的属性值为pre-line时,合并空白符序列,但是保留换行符。
即合并了空白符,但是可以换行。
4.text-overflow
这个属性表示当文本溢出时指定向用户如何显示内容。其属性值有ellipsis(省略)、clip(裁剪)。注意:这个属性的使用要配合包含内容的元素的overflow:hidden;属性。
得到的效果图如下:
我们发现第一段是有省略号表示有文字被遮挡了,而第二段则直接切(clip)掉了。
5.word-wrap
这个属性允许单词在很长的时候换行,word-wrap:break-word;
举例如下:
效果如下所示:
即我们发现第一段中那个长单词自动换行了,而没有设置word-wrap:break-word的第二个段落会在同一行中把这个单词显示完全。
6.word-break
这个属性和上面的属性作用是相同的,若属性值为keep-all则所有的单词都是完整的,而属性值是break-all时,所有超出边界的单词都会被break。
效果如下:
除了这些之外,css3中还有一些属性,但是因为这些属性大多没有被浏览器很好的支持,这里不做介绍。
之前,我们不得不使用用户计算机上已经安装的字体,但是有了css3,我们就可以使用任何我们喜欢的字体。使用@font-face即可实现。
如:
@font-face { font-family:myFont; src:url(sansation.woff); font-weight:bold; }
更多介绍请看我的另外一篇博文《css3之自定义字体》。
这一部分请看我的博文《css3之2D转换》,那里对此做了详尽的介绍。
1.rotateX()方法
该方法可以使得沿着x轴做空间的旋转。语法如下:rotateX(80deg);即旋转80度,可是这个80度是沿着什么方向呢?下面我们一探究竟。
效果如下:
因此若向右为X轴的正方向,那么我们向正方向看去,旋转是逆时针绕着x正方向进行的。
2.rotateY()方法,该方法允许我们沿着Y轴进行空间旋转。
得到的效果如下所示:
也就是说,如果我们认为向上为Y轴的正方向,那么rotateY()是当我们从Y轴正方向看过去时延着逆时针旋转的。
3.在3D变换中,既然有x和y方向的旋转,自然就少不了z方向的旋转了。举例如下
效果图如下所示:
也就是说,如果垂直与屏幕朝向我们的方向为Z轴的正方向,那么旋转同样是当我们看向正方向时逆时针旋转。
综上所述,我们可以知道XYZ的正方向如下所示,旋转是看向正方向,沿着逆时针(角度为正的情况下)旋转。
在css3中,我们可以轻松的实现从某种效果到另一种效果,而不再需要使用Flash或者是JavaScript。这个属性非常有意思!!!
一般情况下,该属性即transition必须规定2项内容
注意:该属性必须结合伪类:hover来使用。
下面举例:
注意:这里我没有考虑到兼容性的问题,如果在实际开发中,还要考虑不同浏览器的兼容。效果如下:
注意到:这里必须配合hover里存在的各种属性使用transition属性。
另外我们还可以使用transition-delay属性,即hover之后,这个过渡的过程在多久之后触发。
使用css3我们可以创建动画,它可以取代许多网页动画图像,比如Flash动画和JavaScript。
而要创建css3动画,我们就不得不使用@keyframes规则。使用该规则即创建动画,它规定了一个css样式和动画将逐步从目前的样式更新为新的样式。
使用了@keyframes之后,我们必须把它绑定到animation选择器,否则动画是没有任何效果的,这个animation选择器包含至少两个属性:
下面列举两个简单的例子。
例1:
比如一个div的css如下:
效果如下:
在这个例子中,我在@keyframes中使用的是from(最开始的状态)和to(最终状态)。
实际上还可以使用百分数来表示:比如0%为刚开始,等同于上面的from,100%为结束,相当于上面的to,当然我们还可以设置20%,35%等等各种你想要设置的数字。下面举例如下:
例2:
这里考虑了兼容性,所以代码显得较多。
效果如下:
css3可以将文本内容设计成像报纸一样的多列布局。
多列中主要有这样几个属性:
下面通过两个例子来应用这几个属性。
例1:
于是可以得到下面的效果:
于是我们可以看到标题h2跨越了所有行,content分为3列,其中gap为20px;
例2: 基于上面的例子,我们把column-span:all;去掉,即为默认的column-span:1;并且不使用column-count,而是使用column-width:150px;(这样会随着浏览器的宽度自动分类,仅保持宽度不变)效果如下:
这样,标题部分处于第一列。并根据浏览器的宽度自适应为4列。
在css3中新增了一些新的用户界面特性来调整元素尺寸(由用户调整!),框尺寸和外边框。
1.resize属性可以指定一个元素是否应该由用户来调整大小。
即resize:both;但是该属性必须配合overflow:hidden;才能正常使用。代码如下:
效果如下所示:
(说明:软件的问题导致显示错误,鼠标应当拖住右下角)
2.box-sizing
该属性可以是我们以确切的方式定义适应某个区域的具体内容。
3.outline-offset
该属性可以对轮廓进行偏移,并在超出边框边缘的位置绘制轮廓。
我们可以给一张img来添加border-radius属性,可以添加border属性,可以添加padding属性(注意:img是行内元素,但是也可以添加padding属性)。我们还可以制作响应式图片。并且可以在图片上添加文本。以及图片滤镜。和响应式图片相册。图片模态也是新增的内容。
1.这一部分我会给出一个例子来使用到border-radius属性、border属性、padding属性以及box-shadow属性。例子的代码如下:
具体效果如下:
2.响应式图片
什么是响应式图片呢?实际上很简单,就是它可以自动适配各种尺寸的屏幕。主要用到的代码就是max-width:100%;height:auto;其中max-width:100%;是指图片的宽度为父元素的100%;而height:auto;是为了让其高度随着宽度的改变而改变,这样可以保证其等比例放大或缩小。下面我们通过一个例子来理解。
代码如下所示:
最终的效果图如下所示:
于是我们可以看到,当浏览器的宽度在改变是,图片的宽度会始终保持和浏览器相同的宽度,同时,高度也在不断地改变,使得图片的比例协调。这就是所谓的响应式图片。
3.图片滤镜
之前我们可能用过filter:opacity(70%);但是,其实在css3中还有更多的滤镜效果。 (补充:opacity:0.5;这种形式是用来是IE生效的。因为IE不支持如此强大的filter)
下面举例如下:
效果如下所示:
4.图片模态(Modal)
首先我们需要使用css来创建modal窗口(对话框),默认是隐藏的。
然后,我们使用JavaScript来显示模态窗口,当我们点击图片时,图片会在弹出的窗口中显示。
制作按钮的方式很多,可以通过button创建按钮,可以通过a创建一个链接按钮,可以通过input的type=“button”创建一个表单按钮等等。下面举例来说明:
代码如下:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>制作按钮</title> <style> .button { background-color: #4CAF50; border: none; color: white; padding: 15px 32px; text-align: center; text-decoration: none; display: inline-block; font-size: 16px; margin: 4px 2px; cursor: pointer; } </style> </head> <body> <h2>CSS 按钮</h2> <button>默认按钮</button> <a href="#" class="button">链接按钮</a> <button class="button">按钮</button> <input type="button" class="button" value="输入框按钮"> </body> </html>
效果图如下所示:
这里通过css中的一个类就设置了同样的几个按钮,这里我们注意到:
重要:除此之外,我们可以在按钮被划过时设置opacity:0.5;这样的透明度属性,看起来会更舒服。
鼠标悬停按钮:
我们可以使用:hover选择器来修改鼠标悬停在按钮上的样式。
我们可以使用transition-duration属性来设置hover效果的速度。
比如下面的例子:
效果如下所示:
对于按钮 ,我们还可以通过:hover之后设置其box-shadow,这样的效果会更好一些。
禁用按钮 这个功能很特别,下面举例说明:
效果图如下:
即在禁用按钮上,我添加了一个cursor:not-allowed;并设置了一个透明度。
css3中的box-sizing属性可以设置width和height属性中包含了padding和border。
不使用css3 box-sizing属性时,默认情况下,元素的宽度和高度计算方式如下:
width+padding+border=元素实际宽度
height+padding+border=元素实际高度
这意味着对于两个width和height相同的元素,如果padding和border的大小不同时,得到的两个元素的大小也是不同的。如下:
效果图如下所示:
但是如果使用了css3中的box-sizing属性,那么这个属性中的width和height就包含了padding和margin。看下面的例子。
效果图如下所示:
即我们发现虽然第二个div设置了padding,但是两者的大小还是一样的,这便是border-box的好处了。
补充:box-sizing有三个值,content-box即为标准的我们一直使用的盒模型。border-box即为width和height包括了padding和margin的盒模型(IE盒模型就是如此)。
实际上我们推荐所有元素都使用box-sizing的:即*{box-sizing:border-box;}
将属性display:flex;设置在弹性容器中,那么这个容器就是一个弹性盒子了,其内部的元素就会根据情况排列(默认情况下是从左到右紧挨着排列)。
我们可以设置flex-direction来对弹性盒子内部的弹性子元素的排列顺序进行设置。如:
我们还可以设置justify-content属性设置水平方向的对齐方式:
我们还可以设置align-items属性来设置竖直方向的对齐方式。
***flex-wrap属性
该属性可以指定弹性子元素的换行方式
***align-content属性
该属性用于修改flex-wrap属性的行为,类似于align-items,但是它不是设置弹性子元素的对其,而是设置各个行的对其。
***order
该属性与上述属性不同,这个属性应当设置在子元素的css中,其数值为一个数字,数字越大,则排列顺序越靠后;数字越小,则排列顺序越靠前。
***margin:auto;实现完美的居中
使用弹性盒子,居中变得很简单,只要在子元素(子元素在弹性容器中应当是唯一的)中设置margin:auto;即可。 这样就可以水平和竖直居中了。
***align-self
该属性可以设置弹性子元素自身在侧轴(纵轴)方向上的对其方式。
下面看这样一个例子:
<style> .flex-container { display: -webkit-flex; display: flex; width: 400px; height: 250px; background-color: lightgrey; } .flex-item { background-color: cornflowerblue; width: 60px; min-height: 100px; margin: 10px; } .item1 { -webkit-align-self: flex-start; align-self: flex-start; } .item2 { -webkit-align-self: flex-end; align-self: flex-end; } .item3 { -webkit-align-self: center; align-self: center; } .item4 { -webkit-align-self: baseline; align-self: baseline; } .item5 { -webkit-align-self: stretch; align-self: stretch; } </style> </head> <body> <div class="flex-container"> <div class="flex-item item1">flex-start</div> <div class="flex-item item2">flex-end</div> <div class="flex-item item3">center</div> <div class="flex-item item4">baseline</div> <div class="flex-item item5">stretch</div>
效果如下:
***flex
该元素指定了弹性子元素如何分配空间
如:
.flex-container { display: -webkit-flex; display: flex; width: 400px; height: 250px; background-color: lightgrey; } .flex-item { background-color: cornflowerblue; margin: 10px; } .item1 { -webkit-flex: 2; flex: 2; } .item2 { -webkit-flex: 1; flex: 1; } .item3 { -webkit-flex: 1; flex: 1; } </style> </head> <body> <div class="flex-container"> <div class="flex-item item1">flex item 1</div> <div class="flex-item item2">flex item 2</div> <div class="flex-item item3">flex item 3</div> </div>
于是效果如下所示:
媒体查询可以做很多事情,例如:
目前很多针对苹果手机、android手机、平板都会用到媒体查询。
媒体查询可以包含一个或者多个表达式,表达式根据条件是否成立返回true或false
如果指定的多媒体类型匹配设备类型则查询结构返回true,文档会在匹配的设备上显示指定样式效果。 除非你使用了not或者only操作符,否则所有的样式都会适应在所有设备上显示效果。
css3多媒体类型有以下几种
下面是一个媒体查询的实例。
效果如下:
静下心来,不要浮躁,什么事情都不是一蹴而就的。
标签:背景 ora 堆叠 单位 linear anim webkit 动画 没有
原文地址:http://www.cnblogs.com/zhuzhenwei918/p/6120294.html