css总结

css总结
  用于美化页面, 装饰页面的
 
  1, 选择器后面跟一个花括号, 选择器和花括号之间要有一个空格
 
  2, 花括号内有多个键值对, 每一对后面跟个分号
 
  3, 数值不用双引号, 字符串需要双引号
 
  font-size: 字号大小
 
  ? 单位:
 
  em: 相对于文本字体大小px:像素in: 英寸cm:厘米mm: 毫米pt:点
 
  font-family: 字体
 
  ? p{ font-family:“微软雅黑”;} 直接写中文xp系统不支持
 
  ? 方法一: 写对应的英文
 
  ? 方法二: 写对象的编码
 
  字体名称英文名称Unicode 编码宋体SimSun\5B8B\4F53新宋体NSimSun\65B0\5B8B\4F53黑体SimHei\9ED1\4F53微软雅黑Microsoft YaHei\5FAE\8F6F\96C5\9ED1楷体_GB2312KaiTi_GB2312\6977\4F53_GB2312隶书LiSu\96B6\4E66幼园YouYuan\5E7C\5706华文细黑STXihei\534E\6587\7EC6\9ED1细明体MingLiU\7EC6\660E\4F53新细明体PMingLiU\65B0\7EC6\660E\4F53
 
  font-weight: 字体粗细
 
  ? font-weight属性用于定义字体的粗细,其可用属性值:normal、bold、bolder、lighter、100——900(100的整数倍)。
 
  ? 数字 400 等价于 normal,而 700 等价于 bold。 但是我们更喜欢用数字来表示。
 
  font-style: 字体风格
 
  ? font-style属性用于定义字体风格,如设置斜体、倾斜或正常字体,其可用属性值如下:
 
  ? normal:默认值,浏览器会显示标准的字体样式。
 
  ? italic:浏览器会显示斜体的字体样式。
 
  ? oblique:浏览器会显示倾斜的字体样式。
 
  font综合设置
 
  ? 选择器{font: font-style font-weight font-size/line-height font-family;}
 
  ? 使用font属性时,必须按上面语法格式中的顺序书写,不能更换顺序,各个属性以空格隔开。
 
  ? 注意:其中不需要设置的属性可以省略(取默认值),但必须保留font-size和font-family属性,否则font属性将不起作用。
 
  标签选择器 (元素选择器)
 
  类选择器
 
  这个类名可以被多个标签使用, (多个标签起同一个类名)
 
  多类名选择器
 
  一个标签名, 有多个选择器名
 
  id选择器
 
  这个id名只能使用一次, (只能有一个标签使用)
 
  通配符选择器
 
  连接伪类选择器
 
  :link 未访问的连接
 
  visited 已访问的连接
 
  :hover 鼠标移动到连接上
 
  active 选定的连接
 
  结构(位置)伪类选择器
 
  :first-child 选取属于其父元素的首个子元素的指定选择器
 
  :last-child 选取属于其父元素的最后一个字元素的指定选择器
 
  :nth-child(N) 匹配属于父元素的第N个字元素, 不论元素类型
 
  :nth-last-child(N) 选取匹配属于其元素的第N个元素的每一个元素,不论元素类型, 从最后一个元素开始计数
 
  目标伪类选择器
 
  :target, 用于选取当前活动的目标元素
 
  交集选择器
 
  交集选择器由两个选择器构成, 期中第一个为标签选择器, 第二个为类选择器, 中间不能有空格
 
  含义: 交集为并且的意思, (选中的是P标签, 并且这个标签的类名叫noe)
 
  并集选择器
 
  由多个选择器 构成, 可以是标签选择器,类选择器id选择器。 中间由逗号隔开
 
  含义: 和的意思, (P, ,noe,#tow,三个都这个设置)
 
  后代选择器 (包含选择器)
 
  由多个选择器组成, 可以是标签,类名, id名, 中间由空格隔开
 
  含义: 层级选中 (选择爷元素下的, 子元素下的, 曾孙元素, 将该元素设置属性),
 
  注意: 可以隔代选择 ,只要是子孙(被包含的)都可以选择
 
  子元素选择器
 
  由多个选择器组成, 可以是标签,类名, id名, 中间由大于号隔开
 
  含义: 选择爷元素下的, 父元素下的, 子元素下的, 曾孙元素, 将该元素设置属性
 
  注意: 只能选择自己的子元素, 一层一层选择下去, 不能跳过子元素直接选中曾孙元素
 
  **选择器**示例**含义E[attr]****存在attr属性即可E[attr=val]****属性值完全等于valE[attr*=val]****属性值里包含val字符并且在“任意”位置E[attr^=val]****属性值里包含val字符并且在“开始”位置E[attr$=val]****属性值里包含val字符并且在“结束”位置
 
  <ul>
 
  <li\ type=‘fruit’ color=‘green’>西瓜</li>
 
  <li\ type=‘vegetable’ color=‘greenyellow’>西兰花</li>
 
  <li\ type=‘meat’>牛肉</li>
 
  <li\ type=‘meat hot’>猪肉</li>
 
  <li\ type=‘drink hot’>可乐</li>
 
  <li\ type=‘drink hot’>雪碧</li>
 
  <li\ price=‘very-cheap’>红酒</li>
 
  <li\ price=‘very’>白酒</li>
 
  </ul>
 
  E::first-letter文本的第一个单词或字(如中文、日文、韩文等)
 
  E::first-line 文本第一行;
 
  E::selection 可改变选中文本的样式;
 
  4、E::before和E::after
 
  在E元素内部的开始位置和结束位创建一个元素,该元素为行内元素,且必须要结合content属性使用。
 
  E:after、E:before 在旧版本里是伪元素,CSS3的规范里“:”用来表示伪类,“::”用来表示伪元素,但是在高版本浏览器下E:after、E:before会被自动识别为E::after、E::before,这样做的目的是用来做兼容处理。
 
  “:” 与 “::” 区别在于区分伪类和伪元素
 
  color: 文本颜色
 
  有三种取值
 
  1.预定义的颜色值,如red,green,blue等。
 
  2.十六进制,如#FF0000,#FF6600,#29D794等。实际工作中,十六进制是最常用的定义颜色的方式。
 
  3.RGB代码,如红色可以表示为rgb(255,0,0)或rgb(100%,0%,0%)。
 
  line-height: 行间距
 
  有三种单位
 
  ? px, em, %
 
  text-align: 水平对齐
 
  1, left: 左对齐(默认)
 
  2, right: 右对齐
 
  3, center: 居中
 
  text-index: 首行缩进
 
  ? 单位 em, 一个 em 就是一个字的宽
 
  letter-spacing: 字间距
 
  ? 字与字之间的距离, 单位可以是数值, 默认值为normal
 
  word-spacing: 单词间距
 
  ? 单词与单词之间的距离, 单位可以是数值, 默认值为normal
 
  颜色透明度
 
  ? color: rgba(r,g,b,a) a 是alpha 透明的意思 取值范围 0——1之间 color: rgba(0,0,0,0.3)
 
  text-shadow:文字阴影
 
  ? 给文字添加阴影
 
  ? text-shadow:水平位置 垂直位置 模糊距离 阴影颜色;
 
  ? h-shadow: 必写, 水平阴影, 允许负值
 
  ? v-shadow: 必写, 垂直阴影, 运行负值
 
  ? blur: 可选 模糊距离
 
  ? color: 可选
 
  ?
 
  行内样式 (内联样式)
 
  ? 将样式直接写的标签中
 
  内部样式(内嵌式)
 
  ? 在head内, 写style标签, 在style标签中写
 
  外部样式 (外链式)
 
  ? 1, 写一个css文件, 直接写在文件内
 
  ? 2, 在需要的页面, head中引入
 
  块级元素block-level
 
  行内元素inline-level
 
  块元素 和 行内元素的区别
 
  行内块元素inline-block
 
  background-image背景图片
 
  none: 无背景图(默认)
 
  url: 图片地址, 不要双号
 
  background-repeat背景平铺
 
  repeat :  背景图像在纵向和横向上平铺(默认的)
 
  no-repeat :  背景图像不平铺
 
  repeat-x :  背景图像在横向上平铺 (单横向平铺)
 
  repeat-y :  背景图像在纵向平铺 (单纵向平铺)
 
  background-position背景位置
 
  length :  百分数 | 由浮点数字和单位标识符组成的长度值
 
  position :  top | center | bottom | left | center | right
 
  1, 设置或检索对象的背景图像位置。必须先指定background-image属性。
 
  2, 默认值为:(0% 0%)。
 
  3, 如果只指定了一个值,该值将用于横坐标。纵坐标将默认为50%。第二个值将用于纵坐标。
 
  background-attachement背景附着
 
  scroll :  背景图像是随对象内容滚动
 
  fixed :  背景图像固定
 
  说明: 设置或检索背景图像是随对象内容滚动还是固定的。
 
  背景简写
 
  background:背景颜色 背景图片地址 背景平铺 背景滚动 背景位置
 
  rgba(0,0,0,0.3)背景透明(CSS3)
 
  CSS3支持背景半透明的写法语法格式是:
 
  最后一个参数是alpha 透明度 取值范围 0——1之间
 
  注意: 背景半透明是指盒子背景半透明, 盒子里面的内容不收影响。
 
  同样, 可以给 文字和边框透明 都是 rgba 的格式来写。
 
  ###### background-size背景缩放(CSS3)
 
  a) 可以设置长度单位(px)或百分比(设置百分比时,参照盒子的宽高)
 
  b) 设置为cover时,会自动调整缩放比例,保证图片始终填充满背景区域,如有溢出部分则会被隐藏。
 
  c) 设置为contain会自动调整缩放比例,保证图片始终完整显示在背景区域。
 
  多背景(CSS3)
 
  以逗号分隔可以设置多背景,可用于自适应布局
 
  层叠 继承 优先级
 
  css层叠
 
  是指css的样式重复, 当浏览器发现两个选择器设置同一个元素时, 会将另一个的选择器样式覆盖掉,
 
  css基础
 
  有两个元素是嵌套关系(父子元素), 给父元素设置样式, 子元素也会基础到父元素的样式
 
  继承样式的权重为0。即在嵌套结构中,不管父元素样式的权重多大,被子元素继承时,他的权重都为0,也就是说子元素定义的样式会覆盖继承来的样式。
 
  css优先级
 
  ? 默认样式 < 基础样式 < 通配符 < 标签名 < class < id < 行内样式
 
  ? 设置!important该样式优先级最大
 
  css的特殊性
 
  关于CSS权重,我们需要一套计算公式来去计算,这个就是 CSS Specificity,我们称为CSS 特性或称非凡性,它是一个衡量CSS值优先级的一个标准 具体规范入如下:
 
  specificity用一个四位的数 字串(CSS2是三位)来表示,更像四个级别,值从左到右,左面的最大,一级大于一级,数位之间没有进制,级别之间不可超越。
 
  继承或者* 的贡献值0,0,0,0每个元素(标签)贡献值为0,0,0,1每个类,伪类贡献值为0,0,1,0每个ID贡献值为0,1,0,0每个行内样式贡献值1,0,0,0每个!important贡献值∞ 无穷大
 
  例如:
 
  注意: 数位之间没有进制 比如说: 0,0,0,5 + 0,0,0,5 =0,0,0,10 而不是 0,0, 1, 0, 所以不会存在10个div能赶上一个类选择器的情况。
 
  CSS就三个大模块: 盒子模型 、 浮动 、 定位
 
  盒子边框border
 
  边框属性—设置边框样式(border-style)
 
  边框样式用于定义页面中边框的风格,常用属性值如下:
 
  设置单边样式
 
  设置内容样式属性常用属性值上边框border-top-style:样式; border-top-width:宽度;border-top-color:颜色;border-top:宽度 样式 颜色;下边框border-bottom-style:样式;border- bottom-width:宽度;border- bottom-color:颜色;border-bottom:宽度 样式 颜色;左边框border-left-style:样式; border-left-width:宽度;border-left-color:颜色;border-left:宽度 样式 颜色;右边框border-right-style:样式;border-right-width:宽度;border-right-color:颜色;border-right:宽度 样式 颜色;样式综合设置border-style:上边 [右边 下边 左边];none无(默认)、solid单实线、dashed虚线、dotted点线、double双实线宽度综合设置border-width:上边 [右边 下边 左边];像素值颜色综合设置border-color:上边 [右边 下边 左边];颜色值、#十六进制、rgb(r,g,b)、rgb(r%,g%,b%)边框综合设置border:四边宽度 四边样式 四边颜色;
 
  圆角边框
 
  内边距padding
 
  padding-top:上内边距
 
  padding-right:右内边距
 
  padding-bottom:下内边距
 
  padding-left:左内边距
 
  当关键字后面跟的数值不一样时, 表达的意思也不一样
 
  值的个数表达意思1个值padding:上下左右边距 比如padding: 3px; 表示上下左右都是3像素2个值padding: 上下边距 左右边距 比如 padding: 3px 5px; 表示 上下3像素 左右 5像素3个值padding:上边距 左右边距 下边距 比如 padding: 3px 5px 10px; 表示 上是3像素 左右是5像素 下是10像素4个值padding:上内边距 右内边距 下内边距 左内边距 比如: padding: 3px 5px 10px 15px; 表示 上3px 右是5px 下 10px 左15px 顺时针
 
  外边距marign
 
  margin属性用于设置外边距。 设置外边距会在元素之间创建“空白”, 这段空白通常不能放置其他内容。
 
  margin-top:上外边距
 
  margin-right:右外边距
 
  margin-bottom:下外边距
 
  margin-left:上外边距
 
  margin:上外边距 右外边距 下外边距 左外边
 
  取值顺序跟内边距相同。
 
  清除元素的默认内外边距
 
  元素之间是有默认内外边距的
 
  边距合并
 
  盒子的大小
 
  注意:
 
  ? 1、宽度属性width和高度属性height仅适用于块级元素,对行内元素无效( img 标签和 input除外)。
 
  ? 2、计算盒子模型的总高度时,还应考虑上下两个盒子垂直外边距合并的情况
 
  盒子模型布局稳定性
 
  按照 优先使用 宽度 (width) 其次 使用内边距(padding) 再次 外边距(margin)。
 
  原因:
 
  margin 会有外边距合并 还有 ie6下面margin 加倍的bug 所以最后使用。
 
  padding 会影响盒子大小, 需要进行加减计算(麻烦) 其次使用。
 
  width 没有问题
 
  盒子阴影
 
  标准流:
 
  ? 又叫, 普通流, 文档流。
 
  ? 当一个页面元素的排版从上到下, 从左到右依次排序, 快元素会独占一行, 行内元素会在一行, 的时候就叫普通流
 
  元素的浮动是指设置了浮动属性的元素会脱离标准流, 移动到其父元素的中指定的位置
 
  浮动的特性
 
  浮动的元素总是找理它最近的父级元素对齐。但是不会超出内边距的范围。
 
  当两个块元素浮动时, 会并排显示, 加了浮动的元素,不占位置, 位置将会留出来给标准流的元素
 
  元素浮动后具有行内块元素的特性
 
  清除浮动
 
  ? 有两个元素是嵌套关系, 父元素没有高度, 子元素浮动了, 父元素的高度会显示0
 
  方法一
 
  方法二
 
  是W3C推荐的做法是通过在浮动元素末尾添加一个空的标签例如
 
  ,或则其他标签br等亦可。
 
  优点: 通俗易懂,书写方便
 
  缺点: 添加许多无意义的标签,结构化较差。 我只能说,w3c你推荐的方法我不接受,你不值得拥有……
 
  方法三: overflow
 
  优点: 代码简洁
 
  缺点: 内容增多时候容易造成不会自动换行导致内容被隐藏掉,无法显示需要溢出的元素。
 
  方法四: 使用after伪元素清除浮动
 
  优点: 符合闭合浮动思想 结构语义化正确
 
  缺点: 由于IE6-7不支持:after,使用 zoom:1触发 hasLayout。
 
  方法五: 使用before和after双伪元素清除浮动
 
  使用方法:
 
  优点: 代码更简洁
 
  缺点: 由于IE6-7不支持:after,使用 zoom:1触发 hasLayout。
 
  将元素定在某个位置就是定位
 
  元素的定位属性主要包括定位模式和边偏移两部分。
 
  1、边偏移
 
  边偏移属性描述top顶端偏移量,定义元素相对于其父元素上边线的距离bottom底部偏移量,定义元素相对于其父元素下边线的距离left左侧偏移量,定义元素相对于其父元素左边线的距离right右侧偏移量,定义元素相对于其父元素右边线的距离
 
  也就说,以后定位要和这边偏移搭配使用了, 比如 top: 100px; left: 30px; 等等
 
  2、定位模式
 
  在CSS中,position属性用于定义元素的定位模式,其基本语法格式如下:
 
  position属性的常用值
 
  值描述static自动定位(默认定位方式)relative相对定位,相对于其原文档流的位置进行定位absolute绝对定位,相对于其上一个已经定位的父元素进行定位fixed固定定位,相对于浏览器窗口进行定位
 
  静态定位static
 
  ? 恢复标准流, left,right等都不能使用, 是默认值
 
  相对定位relative
 
  ? 配置后在标准流的位置还在, 元素相对于该位置定位
 
  绝对定位absolute
 
  ? 配置后不会保留原先的位置, 元素会根据父元素定位, 如果父元素没有定位, 会根据浏览器定位, 浏览器滑动, 定位元素也会跟着滑动, 一直保持这个距离
 
  固定定位fixed
 
  ? 固定定位的元素跟父亲没有任何关系,只认浏览器。
 
  ? 固定定位完全脱标,不占有位置,不随着滚动条滚动。
 
  多个元素定位时, 可能会层叠覆盖掉其他的元素,
 
  z-index的默认属性值是0,取值越大,定位元素在层叠元素中越居上。
 
  如果取值相同,则根据书写顺序,后来居上。
 
  后面数字一定不能加单位。
 
  只有相对定位,绝对定位,固定定位有此属性,其余标准流,浮动,静态定位都无此属性,亦不可指定此属性。
 
  定位模式是否脱标占有位置是否可以使用边偏移移动位置基准静态static不脱标,正常模式不可以正常模式相对定位relative不脱标,占有位置可以相对自身位置移动绝对定位absolute完全脱标,不占有位置可以相对于定位父级移动位置固定定位fixed完全脱标,不占有位置可以相对于浏览器移动位置
 
  跟 浮动一样, 元素添加了 绝对定位和固定定位之后, 元素模式也会发生转换, 都转换为 行内块模式,
 
  display 显示
 
  display 设置或检索对象是否及如何显示。
 
  display : none 隐藏对象 与它相反的是 display:block 除了转换为块级元素之外,同时还有显示元素的意思。
 
  特点: 隐藏之后,不再保留位置。
 
  visibility 可见性
 
  设置或检索是否显示对象。
 
  visible :  对象可视
 
  hidden :  对象隐藏
 
  特点: 隐藏之后,继续保留原有位置。(停职留薪)
 
  overflow 溢出
 
  检索或设置当对象的内容超过其指定高度及宽度时如何管理内容。
 
  visible :  不剪切内容也不添加滚动条。
 
  auto :   超出自动显示滚动条,不超出不显示滚动条
 
  hidden :  不显示超过对象尺寸的内容,超出的部分隐藏掉
 
  scroll :  不管超出内容否,总是显示滚动条
 
  鼠标样式cursor
 
  设置鼠标样子
 
  轮廓 outline
 
  是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的作用。
 
  防止拖拽文本域resize
 
  resize:none 这个单词可以防止 火狐 谷歌等浏览器随意的拖动 文本域
 
  vertical-align 不影响块级元素中的内容对齐,它只针对于 行内元素或者行内块元素,特别是行内块元素, 通常用来控制图片和表单等。
 
  baseline: 文字和图片基线对齐
 
  middle: 文字和图片中间对齐
 
  top: 文字和图片头部对齐
 
  去除图片底侧空白缝隙
 
  如果一个元素没有基线,比如图片或者表单等行内块元素,则他的底线会和父级盒子的基线对齐。 这样会造成一个问题,就是图片底侧会有一个空白缝隙。
 
  解决方法:
 
  ? 1, 给img vertical-align:middle | top等等。 让图片不要和基线对齐。
 
  ? 2, 给img 添加 display:block; 转换为块级元素就不会存在问题了。
 
  CSS精灵是一种处理网页背景图像的方式。它将一个页面涉及到的所有零星背景图像都集中到一张大图中去,然后将大图应用于网页,这样,当用户访问该页面时,只需向服务发送一次请求,网页中的背景图像即可全部展示出来
 
  将图标生成兼容性字体文件包
 
  推荐网站:
 
  阿里巴巴矢量图库
 
  fontello
 
  在线定制你自己的icon font字体图标字库,也可以直接从GitHub下载整个图标集,该项目也是开源的。
 
  Font-Awesome
 
  字库 目前已经有369个图标了。
 
  Glyphicon Halflings
 
  这个字体图标可以在Bootstrap下免费使用。自带了200多个图标。
 
  Icons8
 
  提供PNG免费下载,像素大能到500PX
 
  输入阿里矢量图库地址
 
  搜索自己需要的的图标
 
  点击放入购物车
 
  3.点击购物车
 
  ? 4.下载代码
 
  ?
 
  ? 5.解压文件包, 将括号中的文件复制到需要的项目中
 
  ? 6.打开index.html文件
 
  ? 7.查看使用教程
 
  设置文本背景时, 文本长度不一样, 背景需要更改, 不想更改的情况下使用该技术
 
  核心技术就是利用CSS精灵(主要是背景位置)和盒子padding撑开宽度, 以便能适应不同字数的导航栏。
 
  一般的经典布局都是这样的:
 
  CSS3在布局方面做了非常大的改进,使得我们对块级元素的布局排列变得十分灵活,适应性非常强,其强大的伸缩性,在响应式开中可以发挥极大的作用。
 
  主轴:Flex容器的主轴主要用来配置Flex项目,默认是水平方向
 
  侧轴:与主轴垂直的轴称作侧轴,默认是垂直方向的
 
  方向:默认主轴从左向右,侧轴默认从上到下
 
  主轴和侧轴并不是固定不变的,通过flex-direction可以互换。
 
  Flex布局的语法规范经过几年发生了很大的变化,也给Flexbox的使用带来一定的局限性,因为语法规范版本众多,浏览器支持不一致,致使Flexbox布局使用不多
 
  2、各属性详解****
 
  a、flex-direction调整主轴方向(默认为水平方向)
 
  b、justify-content调整主轴对齐
 
  c、align-items调整侧轴对齐
 
  d、flex-wrap控制是否换行
 
  e、align-content堆栈(由flex-wrap产生的独立行)对齐
 
  f、flex-flow是flex-direction、flex-wrap的简写形式
 
  g、flex子项目在主轴的缩放比例,不指定flex属性,则不参与伸缩分配
 
  h、order控制子项目的排列顺序,正序方式排序,从小到大
 
  此知识点重在理解,要明确找出主轴、侧轴、方向,各属性对应的属性值
 
  过渡(transition)是CSS3中具有颠覆性的特征之一,我们可以在不使用 Flash 动画或 JavaScript 的情况下,当元素从一种样式变换为另一种样式时为元素添加效果。
 
  在CSS3里使用transition可以实现补间动画(过渡效果),并且当前元素只要有“属性”发生变化时即存在两种状态(我们用A和B代指),就可以实现平滑的过渡,为了方便演示采用hover切换两种状态,但是并不仅仅局限于hover状态来实现过渡。
 
  语法格式:
 
  属性描述CSStransition简写属性,用于在一个属性中设置四个过渡属性。3transition-property规定应用过渡的 CSS 属性的名称。3transition-duration定义过渡效果花费的时间。默认是 0。3transition-timing-function规定过渡效果的时间曲线。默认是 “ease”。3transition-delay规定过渡效果何时开始。默认是 0。3
 
  运动曲线示意图:
 
  转换是CSS3中具有颠覆性的特征之一,可以实现元素的位移、旋转、变形、缩放,甚至支持矩阵方式,配合过渡和即将学习的动画知识,可以取代大量之前只能靠Flash才可以实现的效果。
 
  变形转换 transform
 
  移动 translate(x, y)
 
  使用translate方法来将文字或图像在水平方向和垂直方向上分别垂直移动50像素。
 
  可以改变元素的位置,x、y可为负值;
 
  缩放 scale(x, y)
 
  可以对元素进行水平和垂直方向的缩放。该语句使用scale方法使该元素在水平方向上缩小了20%,垂直方向上不缩放。
 
  scale()的取值默认的值为1,当值设置为0.01到0.99之间的任何值,作用使一个元素缩小;而任何大于或等于1.01的值,作用是让元素放大
 
  旋转 rotate(deg)
 
  可以对元素进行旋转,正值为顺时针,负值为逆时针;
 
  当元素旋转以后,坐标轴也跟着发生的转变调整顺序可以解决,把旋转放到最后注意单位是 deg 度数
 
  倾斜 skew(deg, deg)
 
  该实例通过skew方法把元素水平方向上倾斜30度,处置方向保持不变。
 
  可以使元素按一定的角度进行倾斜,可为负值,第二个参数不写默认为0。
 
  transform-origin可以调整元素转换的原点
 
  rotateX() 就是沿着 x 立体旋转。(翻转)
 
  rotateY()沿着y轴进行旋转(翻转)
 
  rotateZ()沿着z轴进行旋转(翻转)
 
  电脑显示屏是一个2D平面,图像之所以具有立体感(3D效果),其实只是一种视觉呈现,通过透视可以实现此目的。
 
  透视可以将一个2D平面,在转换的过程当中,呈现3D效果。
 
  注:并非任何情况下需要透视效果,根据开发需要进行设置。
 
  perspective有两种写法
 
  作为一个属性,设置给父元素,作用于所有3D转换的子元素作为transform属性的一个值,做用于元素自身
 
  理解透视距离原理:
 
  translateX(x)
 
  仅水平方向移动**(X轴移动)
 
  主要目的实现移动效果
 
  translateY(y)
 
  仅垂直方向移动(Y轴移动)
 
  translateZ(z)
 
  transformZ的直观表现形式就是大小变化,实质是XY平面相对于视点的远近变化(说远近就一定会说到离什么参照物远或近,在这里参照物就是perspective属性)。比如设置了perspective为200px;那么transformZ的值越接近200,就是离的越近,看上去也就越大,超过200就看不到了,因为相当于跑到后脑勺去了,我相信你正常情况下,是看不到自己的后脑勺的。
 
  3D呈现(transform-style)
 
  设置内嵌的元素在 3D 空间如何呈现,这些子元素必须为转换原素。
 
  flat:所有子元素在 2D 平面呈现
 
  preserve-3d:保留3D空间
 
  3D元素构建是指某个图形是由多个元素构成的,可以给这些元素的父元素设置transform-style: preserve-3d来使其变成一个真正的3D图形。
 
  一般而言,该声明应用在3D变换的兄弟元素们的父元素上。
 
  翻转盒子案例(百度钱包)
 
  动画是CSS3中具有颠覆性的特征之一,可通过设置多个节点来精确控制一个或一组动画,常用来实现复杂的动画效果。

推荐阅读