5种主流浏览器及内核

IE  trident

Chrome webkit/blink

Firefox  gecko

Opera presto 3%-5%

Safari webkit

css引入三种方式

行间样式

页面级

外部css文件

同步:顺序进行。一件事做完做另一件事。

异步:同时进行。两件不同的事同时做。

CSS权重( 进制256进制)

!Important   infinity

行间样式     1000

Id            100

Class|属性|伪类 10

标签|伪元素   1

通配符        0

常用复杂选择器

div span {}      div下的所有span标签样式

div  >  span {}   div下的所有子标签span标签样式

div.demo{}        并列选择器,通过多种条件查询一个元素,(没有逗号)

em,span,div{}     分组选择器,共用代码块

* 浏览器遍历父子结构标签向左的顺序。

font-weight:100-900 加粗字体效果

Normal:400    bold:700   bolder:特粗体   lighter:细体

文字水平垂直居中

文本高度=容器高度  line-height=height

首行缩进2个字符

text-indent:2em     //开头缩进两个字符。

em: 相对单位,  em=1*font-size.

文字行高是1.2倍行高:line-height=1.2em;

行级元素:span strong em a del  内容决定大小,css不可修改宽高

块级元素:div p ul li ol form adress  独占一行,css可修改宽高

行级块元素:img   内容决定大小,css可修改宽高

盒模型

border:10px solid black;  //盒子大小不变,外边加变宽10px边框

Padding:10px  //盒子四周全都增加10px;

Margin:10px;  //距离外部10px;

Padding:100px 100px 100px 100px;

     上     右       下      左

Padding:100px   100px     100px

    上      左,右     下

Padding:  100px   100px

上下        左右

Padding:  100px

上下左右

body天生具有margin:8px;

定位

Left:100px;      盒子左边线距左侧100px;

层模型:

Position:absolute:  脱离原来位置定位,每个定位的盒子在不同层,比如楼房上下层用户。

Position:relative:  保留原来位置定位,本来的位置不许其他盒子占用。

absolute定位相当于最近的有定位的父级进行定位;如果没有,那么相对于文档定位。

relative定位相当于自己原来位置进行定位。

fix定位,(广告定位)相当于屏幕定位,在屏幕某个位置始终不变。

一般用法:父级用relative定位(保留原来位置,不影响后序标签位置),盒子用absolute定位。

广告定位:始终在屏幕中心;

五环居中,随窗口改变而改变

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>五环居中</title>

<style>

.wrapper{

width:400px;

height:180px;

position: fixed;

left: 50%;

top: 50%;

margin-left: -200px;

margin-top: -90px;

}

.circle1,

.circle2,

.circle3,

.circle4,

.circle5{

width: 100px;

height: 100px;

border: 10px solid blue;

border-radius: 50%;

position: absolute;

}

.circle2{

left: 140px;

border-color: #000;

z-index: 3;

}

.circle3{

left: 280px;

border-color: red;

z-index: 5;

}

.circle4{

left: 70px;

top:60px;

border-color: yellow;

}

.circle5{

left: 210px;

top:60px;

border-color: green;

z-index: 4;

}

</style>

</head>

<body>

<div class="wrapper">

<div class="circle1"></div>

<div class="circle2"></div>

<div class="circle3"></div>

<div class="circle4"></div>

<div class="circle5"></div>

</div>

</body>

</html>

margin 塌陷bug

父子结构盒子,垂直方向上,父级margin-top与子级margin-top取最大值。

如果父级margin-top较大,子级margin-top将失去效果。

如果父级margin-top较小,子级将和父级一起使用margin-top最大值

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>Document</title>

<style type="text/css">

.wrapper{

width: 100px;

height: 100px;

margin-top: 100px;

/*

解决方案3种;

1、overflow: hidden;

2、position: absolute;

3、display: inline-block; */

}

.content{

width: 50px;

height: 50px;

margin-top: 170px;

background-color: blue;

}

</style>

</head>

<body>

<div class="wrapper">

<div class="content"></div>

</div>

</body>

</html>

弥补方案:

1、给父级加上overflow: hidden;

2、给父级加上position: absolute;

3、给父级加上display: inline-block;

margin 合并bug

兄弟盒子,margin-top不能实现累加。

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>Document</title>

<style type="text/css">

.demo1{

background: red;

height: 10px;

margin-bottom: 100px;

}

.demo2{

background: green;

height: 10px;

margin-top: 100px;

}

.wrapper{

overflow: hidden;

}

</style>

</head>

<body>

<!-- 解决方案:加一层包裹

<div class="wrapper">

<div class="demo1"></div>

</div>

<div class="wrapper">

<div class="demo2"></div>

</div> -->

<div class="demo1"></div>

<div class="demo2"></div>

</body>

</html>

解决方案:加一层wrapper.(开发中一般不解决。)

浮动:

只有块级元素看不到浮动元素。当块级元素变成bfc元素时,可以看到浮动元素。

块级元素变成bfc元素三种方式:

1、overflow: hidden;

2、position: absolute;

3、display: inline-block;

如何清除浮动流。

1、父级元素变成bfc元素

2、父级使用伪元素::after{content: "";clear: both;display: block;}

*使用position 和 float 元素自动变成inline-block。

单行文本溢出部分打点显示

white-space: nowrap;

overflow: hidden;

text-overflow:ellipsis;

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>Document</title>

<style type="text/css">

p{

width: 200px;

border: 1px solid #000;

/* 三件套 */

white-space: nowrap;

overflow: hidden;

text-overflow:ellipsis;

}

</style>

</head>

<body>

<p>打电话带大客户的卡大号带画uu的哈互贷的</p>

</body>

</html>

多行文本溢出:只做截断不做打点。

文字对齐方式

当一个行级块元素后面加一段文字,文字与行级块元素底对齐。当行级块元素内部有文字时,外面文字与内部文字底对齐。

CSS进阶学习的更多相关文章

  1. Css 进阶学习

    以下样式,表示css对第一个li标签无效,第一个以后的样式有效. .nav-pills>li+li { margin-left: 2px } <ul class="nav-pil ...

  2. 【CSS进阶】伪元素的妙用2 - 多列均匀布局及title属性效果

    最近无论是工作还是自我学习提升都很忙,面对长篇大论的博文总是心有余而力不足,但又不断的接触学习到零碎的但是很有意义的知识点,很想分享给大家,所以本篇可能会很短. 本篇接我另一篇讲述 CSS 伪元素的文 ...

  3. CSS进阶之SASS入门指南

    CSS进阶之SASS入门指南         随着跟着公司学习项目的前端的推进,越来越对好奇了许久的SASS垂涎欲滴,哈哈,可能这个词使用不当,没有关系,就是对SASS有一股神秘的爱!好了,闲话不多说 ...

  4. webpack快速入门——CSS进阶:自动处理CSS3前缀

    为了浏览器的兼容性,有时候我们必须加入-webkit,-ms,-o,-moz这些前缀.目的就是让我们写的页面在每个浏览器中都可以顺利运行. 1.安装 cnpm i postcss-loader aut ...

  5. webpack快速入门——CSS进阶,Less文件的打包和分离

    1.要使用less,首先使用npm安装less服务 cnpm install less --save-dev 还需要安装Less-loader用来打包使用. cnpm install less-loa ...

  6. webpack快速入门——CSS进阶:SASS文件的打包和分离

    1.安裝:因为sass-loader依赖于node-sass,所以需要先安装node-sass cnpm install node-sass --save-dev cnpm install sass- ...

  7. webpack快速入门——CSS进阶:消除未使用的CSS

    使用PurifyCSS可以大大减少CSS冗余 1.安装 cnpm i purifycss-webpack purify-css --save-dev 2.引入glob,因为我们需要同步检查html模板 ...

  8. (6)《Head First HTML与CSS》学习笔记---结尾、《HTML5权威指南》读书笔记

    1.内联元素的外边距.内边距与块元素稍有不同. 如果一个内联元素四周都增加外边距,只能看到左边和右边会增加空间:你也可以对内联元素的上下增加内边距,不过这个内边距不会影响包围它的其他内联元素的间距—— ...

  9. CSS进阶之路

    下面主要引用http://www.cnblogs.com/wangfupeng1988/tag/css知多少/ CSS进阶笔记: 一.学习CSS的三个突破点 1.浏览器如何加载和解析CSS——CSS的 ...

随机推荐

  1. fixed固定时弹窗上的input被软键盘遮住的问题

    <div class="pwhCover"> <div class="pwhCon"> <div class="pwhT ...

  2. 20.logging模块

    # __________________________________________________ # 创建一个logger logger = logging.getLogger() logge ...

  3. Robot Framework中ride.py打不开的解决方法

    1.首先查看wxPython版本是否跟python的版本一致,一般都使用wxPython2.8-win64-unicode-2.8.12.1-py27.exe或者wxPython2.8-win32-u ...

  4. java8中规范的四大函数式接口

    java8中规范的四大函数式接口: 1.Consumer<T>   :消费型接口    void accept(T t); 2.Supplier<T>      :供给型接口  ...

  5. 悲观锁,乐观锁以及MVCC

    在上文中,我们探讨了MySQL不同存储引擎中的各类锁,在这篇文章中我们将要讨论的是MySQL是如何实现并发控制的.并发问题有三种,分别为: 读-读,不存在任何问题 读-写,有隔离性问题,可能遇到脏读( ...

  6. Hedera: Dynamic Flow Scheduling for Data Center Networks

    摘要: 当今的数据中心为成千上万台计算机的群集提供了巨大的聚合带宽, 但是即使在最高端的交换机中,端口密度也受到限制,因此数据中心拓扑通常由多根树组成,这些树在任何给定的主机对之间都具有许多等价路径. ...

  7. JAVA静态方法是否可以被继承

    结论:java中静态属性和静态方法可以被继承,但是没有被重写(overwrite)而是被隐藏.原因:1). 静态方法和属性是属于类的,调用的时候直接通过类名.方法名完成对,不需要继承机制及可以调用.如 ...

  8. Spring Boot教程(二十五)返回JSON格式

    在上述例子中,通过@ControllerAdvice统一定义不同Exception映射到不同错误处理页面.而当我们要实现RESTful API时,返回的错误是JSON格式的数据,而不是HTML页面,这 ...

  9. Vue CLi3入门

    摘自:https://www.jianshu.com/p/cf9b56efd3b8 Vue CLi3入门 12018.11.15 14:16:17字数 1222阅读 8895 地址 Vue CLi3 ...

  10. Vue一个案例引发的动态组件与全局事件绑定总结

    最近在自学 Vue 也了解了一些基本用法,也记录了一些笔记有兴趣的朋友可以去查看我的其他文章,技术这东西真的不能光靠看,看是没有的,你必须要动手实践,只有在实战项目中才能发现问题,才能发现我们没有掌握 ...