CSS3知识点总结

CSS选择器

1.基本选择器

2.属性选择器

3.伪类选择器

1.

<1>通配符选择器

* 通配符——通配符选择器是用来选择所有元素,也可以选择某个元素下的所有元素

<2>元素选择器

元素选择器就是文档的元素,如html,body,p,div等等

<3>类选择器

<4>id选择器

<5>后代选择器(E F)

<6>子元素选择器 (E>F)

<7>相邻兄弟元素选择器 (E+F)

<8>通用兄弟选择器 (E~F)

相邻兄弟元素选择器  E+F

2.

<1>只使用属性名,没有任何属性值  p[class]

<2>指定了属性值  p[class=value]

<3>可以有多个属性,只要属性值中有一个value相匹配就可以选中该元素p[class~=value]

<4>属性值以“value”开头的或者等于value的所有元素p[class^=value]

<5>属性值是以value结尾的p[class$=value]

<6>属性值只要含有value无论在开头还是结尾,中间 p[class*=value]

3.

<1>动态伪类

a:link  a:visited  a:hover  a:actived

<2>UI状态伪类

:enabled  :disabled  :checked

<3>nth选择器

:first-child 每一组中的第一个子元素

:last-child

:nth-child(n)  n>=1  even(偶数)  odd(奇数)

:nth-last-child(n) 倒数第n个

:only-child  只有一个子元素

////////////////////////////////////

不需要考虑父元素

:nth-of-type   :nth-last-of-type   :first-of-type和:last-of-type:only-of-type

:empty     p:empty {display: none;}

<4>否定选择器 :not([])

<5>伪元素

无论content里面是否有内容,都得写出该项。

content:内容;    content:;

::first-letter第一个字母

::first-line第一行

::before

::after

::selection  改变网页被选中文本的样式

4.样式及属性

<1>透明度

opacity:0~1

表达方式:

eg:opacity:0.1

filter:alpha (opacity=10)  两个都写

<2>文本阴影

text-shadow:h-shadow  v-shadow blur color;

h-shadow:水平阴影,负:阴影左移  正:阴影右移(必写)

v-shadow:垂直阴影, 负:阴影上移  正:阴影下移(必写)

blur: 模糊距离(可选)

<3>文字相关样式@font-face规则

@font-face{

font-family: myFirstFont(自己起的名字);

src: url('字体样式文件的路径'),

}

div{

font-family:myFirstFont;

font-size:;

Font-color:;

}

<4>边框样式

(1)圆角边框(border)

border-radius:   length/% ;

border-radius:   一个值;         //四个角都一样

最大值等于宽,高里最小值的一半;

eg:  width:200px;height:100px;

则border-radius=50px(最大)

border-radius:   值1 值2;      //值1表示左上角、右下角;值2表示右上角、左下角

border-radius:    值1  值2  值3; //值1表示左上角;值2表示右上角、左下角;值3表示右下角

border-radius:   值1   值2   值3   值4;//左上角、右上角、右下角、左下角

(2)边框阴影

box-shadow:  X轴偏移量  Y轴偏移量   [阴影模糊半径]    [阴影扩展半径]   [阴影颜色]  [投影方式];

X轴偏移量:必写,水平阴影的位置;

Y轴偏移量:必写,垂直阴影的位置;

阴影模糊半径:可选,模糊距离;

阴影扩展半径:可选,阴影的尺寸;

阴影颜色:可选,省略默认为黑色;

投影方式:可选,设置为inset时为内部阴影方式,省略为外阴影方式。

(3)边框图片

先规定border,如:border:1px solid #f00;

然后写图片地址: border-image-source:url();

图片切片:border-image-slice:数值(不带单位) 取值个数(1~4个) fill

border-image-repeat:strench(默认)  repeat(从边框的每边的中心向两边的角平铺,可能出现半个图片)  round:完整平铺

border-image-outset:(x,y)图片外凸

(4)多重背景

background-image:url(),url();

(5)背景渐变

<1>线行渐变

background: linear-gradient(angle,颜色  0%,颜色  50% ,颜色 100%)

eg:background: linear-gradient(to bottom right,red green,blue);   或(45deg,red 0%,green 50%,blue 80%);

重复渐变:repeating-linear-gradient

为了实现各个浏览器的兼容,加:

-webkit-height:chorme safari浏览器

-moz-height: firefox浏览器

-ms-height: IE浏览器

-o-height:  欧朋浏览器

height:  ;

<2>径向渐变

background: radial-gradient(颜色  0%,颜色  50% 颜色 100%)

Shape有:circle,ellipse;

Eg:background: repeating-radial-gradient(circle at center,#fff,#000);

(6)变换

<1>移动

transform:translate();

默认,相当于transform:translateX();

transform:translateX(数值);数值为正,向右移动;为负,向左移动;

transform:translateY(); 为正,向下;为负,向上;

transform:translateZ();

<2>旋转

transform:rotate(角度,如:45deg);

默认:相当于transform:rotateZ(角度);

transform:rotateX(角度,如:45deg);

transform:rotateY(角度,如:45deg);

transform:rotateZ(角度,如:45deg);

<3>缩放

Transform:scale(倍数,倍数)

Transform:scaleX(倍数)   Transform:scaleY(倍数)

<4>扭曲

Transform:skew(角度)  默认:skewX()

Transform:skewX(角度)   Transform:skewY(角度)

<5>改变元素基点

transform-origin:X,Y

(7)过渡

transition-property:要改变的属性,可以是宽,高等属性。

transition-duration:5s;过渡时间

transition-timing-function:速度,默认ease(逐渐变慢)

ease-in:加速  ease-out:减速  ease-in-out:先快后慢

linear:匀速     贝塞尔曲线

transition-delay:延迟时间

综合写法 transition:过渡属性 过渡时间 速度 延迟时间

<8>动画

animation:”mypic”20s ease-in-out 2s infinite alternate

animation-name:”mypic”动画名字

animation-duration:20s  动画持续时间

animation-timing-function:ease-in-out  速度

animation-delay:2s 延迟时间

animation-iteration-count:infinite  次数

animation-direction:alternate  来回运动  方向

animation-direction

动画运行的方向

值:

normal  (默认) 从开始到结束

alternate  来回运动

reverse    从结束到开始(反向单趟)

alternate-reverse  反向来回运动

animation-fill-mode:none  不改变

forwards 当动画完成后,保持结束的位置样式。

backwards:停在刚开始停的位置上。

both:停在结束位置

animation-play-state:控制元素动画的播放状态。

值 :running 默认

paused:暂停

<9>定义关键帧格式:

@keyframes 动画名称{

from{ }

to{ }

}

@keyframes 动画名称{

0%{ }

50%{ }

100%{ }

}

你可能感兴趣的:(CSS3知识点总结)