CSS超全笔记(适合新手入门)

CSScss

CSS初识

CSS(Cascading Style Sheets) 美化样式html

CSS一般称为CSS样式表或层叠样式表(级联样式表),主要用于设置HTML页面中的文本内容(字体、大小、对齐方式等)、图片的外形(宽高、边框样式、边距等)以及版面的布局等外观显示样式。前端

CSS以HTML为基础,提供了丰富的功能,如字体、颜色、背景的控制及总体排版等,并且还能够针对不一样的浏览器设置不一样的样式。html5

引入CSS样式表(书写位置)

CSS能够写到那个位置? 是否是必定写到html文件里面呢?git

内部样式表

内嵌式是将CSS代码集中写在HTML文档的head头部标签中,而且用style标签订义,其基本语法格式以下:github

<head>
<style type="text/CSS">
    选择器 {属性1:属性值1; 属性2:属性值2; 属性3:属性值3;}
</style>
</head>算法

语法中,style标签通常位于head标签中title标签以后,也能够把他放在HTML文档的任何地方。chrome

type="text/CSS" 在html5中能够省略, 写上也比较符合规范, 因此这个地方能够写也能够省略。json

行内式(内联样式)

内联样式,又有人称行内样式、行间样式、内嵌样式。是经过标签的style属性来设置元素的样式,其基本语法格式以下:浏览器

<标签名 style="属性1:属性值1; 属性2:属性值2; 属性3:属性值3;"> 内容 </标签名>

 

 

语法中style是标签的属性,实际上任何HTML标签都拥有style属性,用来设置行内式。其中属性和值的书写规范与CSS样式规则相同,行内式只对其所在的标签及嵌套在其中的子标签起做用。

外部样式表(外链式)

链入式是将全部的样式放在一个或多个以.CSS为扩展名的外部样式表文件中,经过link标签将外部样式表文件连接到HTML文档中,其基本语法格式以下:

<head>
  <link href="CSS文件的路径"  rel="stylesheet" />
</head>

注意: link 是个单标签哦!!!

该语法中,link标签须要放在的三个属性head头部标签中,而且必须指定link标签,具体以下:

href:定义所连接外部样式表文件的URL,能够是相对路径,也能够是绝对路径。
type:定义所连接文档的类型,在这里须要指定为“text/CSS”,表示连接的外部文件为CSS样式表。
rel:定义当前文档与被连接文档之间的关系,在这里须要指定为“stylesheet”,表示被连接的文档是一个样式表文件。

三种样式表总结(位置)

CSS样式规则

使用HTML时,须要听从必定的规范。CSS亦如此,要想熟练地使用CSS对网页进行修饰,首先须要了解CSS样式规则,具体格式以下:

在上面的样式规则中:

1.选择器用于指定CSS样式做用的HTML对象,花括号内是对该对象设置的具体样式。

2.属性和属性值以“键值对”的形式出现。

3.属性是对指定的对象设置的样式属性,例如字体大小、文本颜色等。

4.属性和属性值之间用英文“:”链接。

5.多个“键值对”之间用英文“;”进行区分。

能够用段落 表格的对齐的演示。

CSS基础选择器

标签选择器(元素选择器)

标签选择器是指用HTML标签名称做为选择器,按标签名称分类,为页面中某一类标签指定统一的CSS样式。其基本语法格式以下:

标签名{属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }  或者
元素名{属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }

标签选择器最大的优势是能快速为页面中同类型的标签统同样式,同时这也是他的缺点,不能设计差别化样式。

标签选择器 能够把某一类标签所有选择出来 div span

 

 

类选择器

类选择器使用“.”(英文点号)进行标识,后面紧跟类名,其基本语

法格式以下:

.类名{属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }

标签调用的时候用 class=“类名”  便可。

类选择器最大的优点是能够为元素对象定义单独或相同的样式。 能够选择一个或者多个标签

小技巧:

1.长名称或词组可使用中横线来为选择器命名。
2.不建议使用“_”下划线来命名CSS选择器。

输入的时候少按一个shift键; 浏览器兼容问题 (好比使用_tips的选择器命名,在IE6是无效的) 能良好区分JavaScript变量命名(JS变量命名是用“_”)

3.不要纯数字、中文等命名, 尽可能使用英文字母来表示。

命名规范 见附件(Web前端开发规范手册.doc)

命名是咱们通俗约定的,可是没有规定必须用这些经常使用的命名。

多类名选择器

咱们能够给标签指定多个类名,从而达到更多的选择目的。

注意:

1. 样式显示效果跟HTML元素中的类名前后顺序没有关系,受CSS样式书写的上下顺序有关。
2. 各个类名中间用空格隔开。

多类名选择器在后期布局比较复杂的状况下,仍是较多使用的。

<div class="pink fontWeight font20">亚瑟</div>
<div class="font20">刘备</div>
<div class="font14 pink">安其拉</div>
<div class="font14">貂蝉</div>

id选择器

id选择器使用“#”进行标识,后面紧跟id名,其基本语法格式以下:


#id名{属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }

该语法中,id名即为HTML元素的id属性值,大多数HTML元素均可以定义id属性,元素的id值是惟一的,只能对应于文档中某一个具体的元素。

用法基本和类选择器相同。

id选择器和类选择器区别

W3C标准规定,在同一个页面内,不容许有相同名字的id对象出现,可是容许相同名字的class。

类选择器(class) 比如人的名字, 是能够屡次重复使用的, 好比 张伟 王伟 李伟 李娜

id选择器 比如人的身份证号码, 全中国是惟一的, 不得重复。 只能使用一次。

id选择器和类选择器最大的不一样在于 使用次数上。

通配符选择器

通配符选择器用“*”号表示,他是全部选择器中做用范围最广的,能匹配页面中全部的元素。其基本语法格式以下:

 

 

 

* { 属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }

例以下面的代码,使用通配符选择器定义CSS样式,清除全部HTML标记的默认边距。

* {
  margin: 0;                    /* 定义外边距*/
  padding: 0;                   /* 定义内边距*/
}

注意:

个通配符选择器,就像咱们的电影明星中的梦中情人, 想一想它就行了,可是它不会和你过日子。

CSS字体样式属性

font-size:字号大小

font-size属性用于设置字号,该属性的值可使用相对长度单位,也可使用绝对长度单位。其中,相对长度单位比较经常使用,推荐使用像素单位px,绝对长度单位使用较少。具体以下:

font-family:字体

font-family属性用于设置字体。网页中经常使用的字体有宋体、微软雅黑、黑体等,

 

 

例如将网页中全部段落文本的字体设置为微软雅黑,可使用以下CSS样式代码:

p{ font-family:"微软雅黑";}

能够同时指定多个字体,中间以逗号隔开,表示若是浏览器不支持第一个字体,则会尝试下一个,直到找到合适的字体。

经常使用技巧:

1. 如今网页中广泛使用14px+。
2. 尽可能使用偶数的数字字号。ie6等老式浏览器支持奇数会有bug。
3. 各类字体之间必须使用英文状态下的逗号隔开。
4. 中文字体须要加英文状态下的引号,英文字体通常不须要加引号。当须要设置英文字体时,英文字体名必须位于中文字体名以前。
5. 若是字体名中包含空格、#、$等符号,则该字体必须加英文状态下的单引号或双引号,例如font-family: "Times New Roman";。
6. 尽可能使用系统默认字体,保证在任何用户的浏览器中都能正确显示。

CSS Unicode字体

CSS 中设置字体名称,直接写中文是能够的。可是在文件编码(GB23十二、UTF-8 等)不匹配时会产生乱码的错误。xp 系统不支持 相似微软雅黑的中文。

方案一: 你可使用英文来替代。 好比 font-family:"Microsoft Yahei"。

方案二: CSS 直接使用 Unicode 编码来写字体名称能够避免这些错误。使用 Unicode 写中文字体名称,浏览器是能够正确的解析的。font-family: "\5FAE\8F6F\96C5\9ED1",表示设置字体为“微软雅黑”。能够经过escape() 来测试属于什么字体

为了照顾不一样电脑的字体安装问题,咱们尽可能只使用宋体和微软雅黑中文字体

font-weight:字体粗细

字体加粗除了用 b 和 strong 标签以外,可使用CSS 来实现,可是CSS 是没有语义的。

font-weight属性用于定义字体的粗细,其可用属性值:normal、bold、bolder、lighter、100~900(100的整数倍)。

小技巧:

数字 400 等价于 normal,而 700 等价于 bold  可是咱们更喜欢用数字来表示。  

font-style:字体风格

字体倾斜除了用 i 和 em 标签以外,可使用CSS 来实现,可是CSS 是没有语义的。

font-style属性用于定义字体风格,如设置斜体、倾斜或正常字体,其可用属性值以下:

normal:默认值,浏览器会显示标准的字体样式

italic:浏览器会显示斜体的字体样式。

oblique:浏览器会显示倾斜的字体样式。

小技巧:

平时咱们不多给文字加斜体,反而喜欢给斜体标签(em,i)改成普通模式。

font:综合设置字体样式 (重点)

font性用于对字体样式进行综合设置,其基本语法格式以下:

选择器{font: font-style  font-weight  font-size/line-height  font-family;}

使用font属性时,必须按上面语法格式中的顺序书写,不能更换顺序,各个属性以空格隔开。

注意:其中不须要设置的属性能够省略(取默认值),但必须保留font-size和

font-family属性,不然font属性将不起做用。

 

CSS外观属性

color:文本颜色

color属性用于定义文本的颜色,其取值方式有以下3种:

1.预约义的颜色值,如red,green,blue等。

2.十六进制,如#FF0000,#FF6600,#29D794等。实际工做中,十六进制是最经常使用的定义颜色的方式。

3.RGB代码,如红色能够表示为rgb(255,0,0)或rgb(100%,0%,0%)。

须要注意的是,若是使用RGB代码的百分比颜色值,取值为0时也不能省略百分号,必须写为0%。

line-height:行间距

ine-height属性用于设置行间距,就是行与行之间的距离,即字符的垂直间距,通常称为行高。line-height经常使用的属性值单位有三种,分别为像素px,相对值em和百分比%,实际工做中使用最多的是像素px

通常状况下,行距比字号大7.8像素左右就能够了。

text-align:水平对齐方式

text-align属性用于设置文本内容的水平对齐,至关于html中的align对齐属性。其可用属性值以下:

left:左对齐(默认值)

right:右对齐

center:居中对齐

text-indent:首行缩进

text-indent属性用于设置首行文本的缩进,其属性值可为不一样单位的数值、em字符宽度的倍数、或相对于浏览器窗口宽度的百分比%,容许使用负值, 建议使用em做为设置单位。

1em 就是一个字的宽度 若是是汉字的段落, 1em 就是一个汉字的宽度

 

text-decoration 文本的装饰

text-decoration 常咱们用于给连接修改装饰效果

 

开发者工具(chrome)

此工具是咱们的必备工具,之后代码出了问题,咱们首先第一反应就是:

“按F12”或者是 “shift+ctrl+i” 打开 开发者工具。

菜单: 右击网页空白出---查看

小技巧:

1ctrl+滚轮 能够 放大开发者工具代码大小。

二、左边是HTML元素结构 右边是CSS样式。

三、右边CSS样式能够改动数值和颜色查看更改后效果。

记忆技巧:

交集选择器 而且的意思。 ...又...的意思

好比:   p.one   选择的是: 类名为 .one  的 段落标签。  

用的相对来讲比较少,不太建议使用。

并集选择器

并集选择器(CSS选择器分组)是各个选择器经过<strong style="color:#f00">逗号</strong>链接而成的,任何形式的选择器(包括标签选择器、class类选择器id选择器等),均可以做为并集选择器的一部分。若是某些选择器定义的样式彻底相同,或部分相同,就能够利用并集选择器为它们定义相同的CSS样式。

 

 

CSS复合选择器

复合选择器是由两个或多个基础选择器,经过不一样的方式组合而成的,目的是为了能够选择更准确更精细的目标元素标签。

交集选择器

交集选择器由两个选择器构成,其中第一个为标签选择器,第二个为class选择器,两个选择器之间不能有空格,如h3.special。

记忆技巧:

并集选择器 的意思, 就是说,只要逗号隔开的,全部选择器都会执行后面样式。

好比  .one, p , #test {color: #F00;}  表示   .one 和 p  和 #test 这三个选择器都会执行颜色为红色。  一般用于集体声明。

后代选择器

后代选择器又称为包含选择器,用来选择元素或元素组的后代,其写法就是把外层标签写在前面,内层标签写在后面,中间用空格分隔。当标签发生嵌套时,内层标签就成为外层标签的后代。

子元素选择器

子元素选择器只能选择做为某元素子元素的元素。其写法就是把父级标签写在前面,子级标签写在后面,中间跟一个 进行链接,注意,符号左右两侧各保留一个空格。

伪类选择器

伪类选择器用于向某些选择器添加特殊的效果。好比给连接添加特殊效果, 好比能够选择 1个,第n个元素。

 

 

 

为了和咱们刚才学的类选择器相区别,  类选择器是一个点 好比 .demo {}   而咱们的伪类 用 2个点 就是 冒号  好比  :link{}

连接伪类选择器

 

:link /* 未访问的连接 */

:visited /* 已访问的连接 */

:hover /* 鼠标移动到连接上 */

:active /* 选定的连接 */

注意写的时候,他们的顺序尽可能不要颠倒 按照 lvha 的顺序。 love hate 爱上了讨厌 记忆法 或者 lv 包包 很是 hao

a {   /* a是标签选择器  全部的连接 */
            font-weight: 700;
            font-size: 16px;
            color: gray;
        }
a:hover {   /* :hover 是连接伪类选择器 鼠标通过 */
            color: red; /*  鼠标通过的时候,由原来的 灰色 变成了红色 */
}

 

CSS注释

CSS规则是使用     /*  须要注释的内容  */  进行注释的,即在须要注释的内容前使用 “/*” 标记开始注释,在内容的结尾使用 “*/”结束。

例如:

p {
  font-size: 14px;                 /* 全部的字体是14像素大小*/}

 

sublime快捷方式

sublime能够快速提升咱们代码的书写方式

生成标签 直接输入标签名 tab键便可 好比 div 而后tab 键, 就能够生成 <div></div>

若是想要生成多个相同标签 加上 * 就能够了 好比 div*3 就能够快速生成3个div

若是有父子级关系的标签,能够用 > 好比 ul > li就能够了

果有兄弟关系的标签,用 + 就能够了 好比 div+p

若是生成带有类名或者id名字的, 直接写 .demo 或者 #two tab 键就能够了

标签显示模式(display)

块级元素(block-level)

每一个块元素一般都会独自占据一整行或多整行,能够对其设置宽度、高度、对齐等属性,经常使用于网页布局和网页结构的搭建。

常见的块元素有<h1>~<h6>、<p>、<div>、<ul>、<ol>、<li>等,其中<div>标签是最典型的块元素。

块级元素的特色:

1)老是重新行开始

2)高度,行高、外边距以及内边距均可以控制。

3)宽度默认是容器的100%

4)能够容纳内联元素和其余块元素。

行内元素(inline-level)

行内元素(内联元素)不占有独立的区域,仅仅靠自身的字体大小和图像尺寸来支撑结构,通常不能够设置宽度、高度、对齐等属性,经常使用于控制页面中文本的样式。

常见的行内元素有<a>、<strong>、<b>、<em>、<i>、<del>、<s>、<ins>、<u>、<span>等,其中<span>标签最典型的行内元素。

 

 

行内元素的特色:

1)和相邻行内元素在一行上。

2)高、宽无效,但水平方向的padding和margin能够设置,垂直方向的无效。

3)默认宽度就是它自己内容的宽度。

4)行内元素只能容纳文本或则其余行内元素。(a特殊)

注意:

1只有 文字才 能组成段落 所以 p 里面不能放块级元素,同理还有这些标签h1,h2,h3,h4,h5,h6,dt,他们都是文字类块级标签,里面不能放其余块级元素。

2连接里面不能再放连接

块级元素和行内元素区别

块级元素的特色:

1)老是重新行开始

2)高度,行高、外边距以及内边距均可以控制。

3)宽度默认是容器的100%

4)能够容纳内联元素和其余块元素。


行内元素的特色:
1)和相邻行内元素在一行上。
2)高、宽无效,但水平方向的padding和margin能够设置,垂直方向的无效。
3)默认宽度就是它自己内容的宽度。
4)行内元素只能容纳文本或则其余行内元素。

标签显示模式转换 display

块转行内:display:inline;

行内转块:display:block;

块、行内元素转换为行内块: display: inline-block;

 

 

此阶段,咱们只需关心这三个,其余的是咱们后面的工做。

CSS书写规范

开始就造成良好的书写规范,是你专业化的开始。

空格规范

【强制】 选择器 { 之间必须包含空格。

示例: .selector { }

【强制】 性名 与以后的 : 之间不容许包含空格, : 与 属性值 之间必须包含空格。

示例:

font-size: 12px;

选择器规范

【强制】 当一个 rule 包含多个 selector 时,每一个选择器声明必须独占一行。

示例:

/* good */

.post,

.page,

.comment {

    line-height: 1.5;

}

/* bad */

.post, .page, .comment {

    line-height: 1.5;

}

 

 

【建议】 选择器的嵌套层级应不大于 3 级,位置靠后的限定条件应尽量精确。

示例:

/* good */

#username input {}

.comment .avatar {}

 

/* bad */

.page .header .login #username input {}

.comment div * {}

属性规范

【强制】 属性定义必须另起一行。

示例:

/* good */

.selector {

    margin: 0;

    padding: 0;

}

 

/* bad */

.selector { margin: 0; padding: 0; }

【强制】 属性定义后必须以分号结尾。

 

 

 

 

示例:

/* good */

.selector {

    margin: 0;

}

/* bad */

.selector {

    margin: 0

}

CSS 三大特性

层叠 继承 优先级 是咱们学习CSS 必须掌握的三个特性。

CSS层叠性

所谓层叠性是指多种CSS样式的叠加。

是浏览器处理冲突的一个能力,若是一个属性经过两个相同选择器设置到同一个元素上,那么这个时候一个属性就会将另外一个属性层叠掉

好比先给某个标签指定了内部文字颜色为红色,接着又指定了颜色为蓝色,此时出现一个标签指定了相一样式不一样值的状况,这就是样式冲突。

通常状况下,若是出现样式冲突,则会按照CSS书写的顺序,以最后的样式为准。

1样式冲突,遵循的原则是就近原则。 那个样式离着结构近,就执行那个样式。

2样式不冲突,不会层叠

CSS最后的执行口诀:  长江后浪推前浪,前浪死在沙滩上。

 

 

行内块元素(inline-block)

在行内元素中有几个特殊的标签——<img />、<input />、<td>,能够对它们设置宽高和对齐属性,有些资料可能会称它们为行内块元素。

行内块元素的特色:

1)和相邻行内元素(行内块)在一行上,可是之间会有空白缝隙。

2)默认宽度就是它自己内容的宽度。

3)高度,行高、外边距以及内边距均可以控制。

CSS继承性

谓继承性是指书写CSS样式表时,子标签会继承父标签的某些样式,如文本颜色和字号。想要设置一个可继承的属性,只需将它应用于父元素便可。

简单的理解就是: 子承父业。

CSS最后的执行口诀:  龙生龙,凤生凤,老鼠生的孩子会打洞。

注意:

恰当地使用继承能够简化代码,下降CSS样式的复杂性。子元素能够继承父元素的样式(text-,font-,line-这些元素开头的均可以继承,以及color属性)

CSS优先级

定义CSS样式时,常常出现两个或更多规则应用在同一元素上,这时就会出现优先级的问题。

在考虑权重时,初学者还须要注意一些特殊的状况,具体以下:

 

 

 

 

 

 

继承样式的权重为0。即在嵌套结构中,无论父元素样式的权重多大,被子元素继承时,他的权重都为0,也就是说子元素定义的样式会覆盖继承来的样式。

 

行内样式优先。应用style属性的元素,其行内样式的权重很是高,能够理解为远大于100。总之,他拥有比上面提升的选择器都大的优先级。

 

权重相同时,CSS遵循就近原则。也就是说靠近元素的样式具备最大的优先级,或者说排在最后的样式优先级最大。

 

CSS定义了一个!important命令,该命令被赋予最大的优先级。也就是说无论权重如何以及样式位置的远近,!important都具备最大优先级。

CSS特殊性(Specificity)

关于CSS权重,咱们须要一套计算公式来去计算,这个就是 CSS Specificity,咱们称为CSS 特性或称非凡性,它是一个衡量CSS值优先级的一个标准 具体规范入以下:

specificity用一个四位的数 字串(CSS2是三位)来表示,更像四个级别,值从左到右,左面的最大,一级大于一级,数位之间没有进制,级别之间不可超越。 

权重是能够叠加的

好比的例子:

 

注意:

1.数位之间没有进制 好比说: 0,0,0,5 + 0,0,0,5 =0,0,0,10 而不是 0,0, 1, 0, 因此不会存在10个div能遇上一个类选择器的状况。

继承的 权重是 0

总结优先级:

1使用了 !important声明的规则。

2内嵌在 HTML 元素的 style属性里面的声明。

3使用了 ID 选择器的规则。

4使用了类选择器、属性选择器、伪元素和伪类选择器的规则。

5使用了元素选择器的规则。

6只包含一个通用选择器的规则。

7同一类选择器则遵循就近原则。

总结:权重是优先级的算法,层叠是优先级的表现

CSS 背景(background)

CSS 能够添加背景颜色和背景图片,以及来进行图片设置。

背景图片(image)

语法: 

background-image : none | url (url)

参数:

none :  无背景图(默认的)url :  使用绝对或相对地址指定背景图像

background-image 性容许指定一个图片展现在背景中(只有CSS3才能够多背景)能够和 background-color 连用。 若是图片不重复地话,图片覆盖不到地地方都会被背景色填充。 若是有背景图片平铺,则会覆盖背景颜色。

小技巧: 咱们提倡 背景图片后面的地址,url不要加引号。

背景平铺(repeat)

语法: 

background-repeat : repeat | no-repeat | repeat-x | repeat-y 

参数: 

repeat :  背景图像在纵向和横向上平铺(默认的)

no-repeat :  背景图像不平铺

repeat-x :  背景图像在横向上平铺

repeat-y :  背景图像在纵向平铺

 

 

设置背景图片时,默认把图片在水平和垂直方向平铺以铺满整个元素。

repeat-x :  背景图像在横向上平铺

repeat-y :  背景图像在纵向平铺

背景位置(position)

语法:


background-position : length || length

background-position : position || position 

参数: 

length :  百分数 | 由浮点数字和单位标识符组成的长度值。请参阅长度单位 position :  top | center | bottom | left | center | right

说明: 

设置或检索对象的背景图像位置。必须先指定background-image属性。默认值为:(0% 0%)。若是只指定了一个值,该值将用于横坐标。纵坐标将默认为50%。第二个值将用于纵坐标。

注意:

1position 后面是x坐标和y坐标。 可使用方位名词或者 精确单位。

2若是和精确单位和方位名字混合使用,则必须是x坐标在前,y坐标后面。好比 background-position: 15px top; 则 15px 必定是 x坐标 top是 y坐标。

3实际工做用的最多的,就是背景图片居中对齐了

背景附着

语法: 

background-attachment : scroll | fixed 

参数:

 

 

scroll :  背景图像是随对象内容滚动fixed :  背景图像固定

说明: 

设置或检索背景图像是随对象内容滚动仍是固定的。

背景简写

background属性的值的书写顺序官方并无强制标准的。为了可读性,建议你们以下写:

background:背景颜色 背景图片地址 背景平铺 背景滚动 背景位置

background: transparent url(image.jpg) repeat-y  scroll 50% 0 ;

背景透明(CSS3)

CSS3支持背景半透明的写法语法格式是:

background: rgba(0,0,0,0.3);

最后一个参数是alpha 透明度 取值范围 0~1之间

注意: 背景半透明是指盒子背景半透明, 盒子里面的内容不收影响。

导航栏案例

使用技巧一行内的盒子内,咱们设定行高等于盒子的高度,就可使文字垂直居中。

<head>
        <meta charset="utf-8">
        <style>
        body {
            
        }
        a {
            width: 200px;
            height: 50px;
            /* background-color: orange; */
            display: inline-block;  /* 把a 行内元素转换为行内块元素 */
            text-align: center;  /* 文字水平居中 */
            line-height: 50px;  /* 咱们设定行高等于盒子的高度,就可使文字垂直居中 */
            color: #fff;
            font-size: 22px;
            text-decoration: none;  /* 取消下划线 文本装饰 */
        }
        a:hover {  /* 鼠标通过 给咱们的连接添加背景图片*/
            background: url(images/h.png) no-repeat;
        }
        </style>
    </head>
    <body>
    <a href="#">专区说明</a>
    <a href="#">申请资格</a>
    <a href="#">兑换奖励</a>
    <a href="#">下载游戏</a>
    </body>

盒子模型(CSS重点)

其实,CSS就三个大模块: 盒子模型 、 浮动 、 定位,其他的都是细节。要求这三部分,不管如何也要学的很是精通。

所谓盒子模型就是把HTML页面中的元素看做是一个矩形的盒子,也就是一个盛装内容的容器。每一个矩形都由元素的内容、内边距(padding)、边框(border)和外边距(margin)组成。

看透网页布局的本质

网页布局中,咱们是如何把里面的文字,图片,按照美工给咱们的效果图排列的整齐有序呢?

盒子边框(border)

边框就是那层皮。 橘子皮。。柚子皮。。橙子皮。。。

语法: 

border : border-width || border-style || border-color 

边框属性—设置边框样式(border-style)

边框样式用于定义页面中边框的风格,经常使用属性值以下:

 

 

 

none:没有边框即忽略全部边框的宽度(默认值)

 

solid:边框为单实线(最为经常使用的)

 

dashed:边框为虚线  

 

dotted:边框为点线

 

double:边框为双实线

盒子边框写法总结表

表格的细线边框

之前学过的html表格边框很粗,这里只须要CSS一句话就能够美观起来。 让咱们真的相信,CSS就是咱们的白马王子(白雪公主)。

table{ border-collapse:collapse; } collapse 单词是合并的意思

border-collapse:collapse; 表示边框合并在一块儿。

圆角边框(CSS3)

今后之后,咱们的世界不仅有矩形。radius 半径(距离)

语法格式:

border-radius: 左上角  右上角  右下角  左下角;

内边距(padding)

padding属性用于设置内边距。 是指 边框与内容之间的距离。

padding-top:上内边距

padding-right:右内边距

padding-bottom:下内边距

padding-left:左内边距

注意: 后面跟几个数值表示的意思是不同的。

外边距(margin)

margin属性用于设置外边距。 设置外边距会在元素之间建立“空白”, 这段空白一般不能放置其余内容。

margin-top:上外边距

margin-right:右外边距

margin-bottom:下外边距

margin-left:上外边距

margin:上外边距 右外边距 下外边距 左外边

取值顺序跟内边距相同。

外边距实现盒子居中

可让一个盒子实现水平居中,须要知足一下两个条件:

必须是块级元素。

盒子必须指定了宽度(width

 

而后就给左右的外边距都设置为auto,就可以使块级元素水平居中。

实际工做中经常使用这种方式进行网页布局,示例代码以下:

.header{ width:960px; margin:0 auto;}

文字盒子居中图片和背景区别

一、文字水平居中是 text-align: center

二、盒子水平居中 左右margin 改成 auto

text-align: center; /*  文字居中水平 */
margin: 10px auto;  /* 盒子水平居中  左右margin 改成 auto 就阔以了 */

 

 

插入图片 咱们用的最多 好比产品展现类

背景图片咱们通常用于小图标背景 或者 超大背景图片

section img {  
        width: 200px;/* 插入图片更改大小 width 和 height */
        height: 210px;
        margin-top: 30px;  /* 插入图片更改位置 能够用margin 或padding  盒模型 */
        margin-left: 50px; /* 插入当图片也是一个盒子 */
    }

aside {
        width: 400px;
        height: 400px;
        border: 1px solid purple;
        background: #fff url(images/sun.jpg) no-repeat;
    
        background-size: 200px 210px; /*  背景图片更改大小只能用 background-size */
        background-position: 30px 50px; /* 背景图片更该位置 我用 background-position */
    }

清除元素的默认内外边距

为了更方便地控制网页中的元素,制做网页时,可以使用以下代码清除元素的默认内外边距:

* {
   padding:0;         /* 清除内边距 */
   margin:0;          /* 清除外边距 */
}

注意: 行内元素是只有左右外边距的,是没有上下外边距的。 内边距,在ie6等低版本浏览器也会有问题。

咱们尽可能不要给行内元素指定上下的内外边距就行了。

外边距合并

使用margin定义块元素的垂直外边距时,可能会出现外边距的合并。

 

相邻块元素垂直外边距的合并

当上下相邻的两个块元素相遇时,若是上面的元素有下外边距margin-bottom,下面的元素有上外边距margin-top,则他们之间的垂直间距不是margin-bottom与margin-top之和,而是二者中的较大者。这种现象被称为相邻块元素垂直外边距的合并(也称外边距塌陷)。

嵌套块元素垂直外边距的合并

对于两个嵌套关系的块元素,若是父元素没有上内边距及边框,则父元素的上外边距会与子元素的上外边距发生合并,合并后的外边距为二者中的较大者,即便父元素的上外边距为0,也会发生合并。

解决方案:

一、能够为父元素定义1像素的上边框或上内边距。

二、能够为父元素添加overflow:hidden。

content宽度和高度

使用宽度属性width和高度属性height能够对盒子的大小进行控制。

width和height的属性值能够为不一样单位的数值或相对于父元素的百分比%,实际工做中最经常使用的是像素值。

大多数浏览器,如Firefox、IE6及以上版本都采用了W3C规范,符合CSS规范的盒子模型的总宽度和总高度的计算原则是:

/*外盒尺寸计算(元素空间尺寸)*/
  Element空间高度 = content height + padding + border + margin
  Element 空间宽度 = content width + padding + border + margin
  /*内盒尺寸计算(元素实际大小)*/
  Element Height = content height + padding + border (Height为内容高度)
  Element Width = content width + padding + border (Width为内容宽度)

注意:

一、宽度属性width和高度属性height仅适用于块级元素,对行内元素无效( img 标签和 input除外)。

二、计算盒子模型的总高度时,还应考虑上下两个盒子垂直外边距合并的状况。

三、若是一个盒子没有给定宽度/高度或者继承父亲的宽度/高度,则padding 不会影响本盒子大小。

盒子模型布局稳定性

开始学习盒子模型,同窗们最大的困惑就是, 分不清内外边距的使用,什么状况下使用内边距,什么状况下使用外边距?

答案是: 其实他们大部分状况下是能够混用的。 就是说,你用内边距也能够,用外边距也能够。 你以为哪一个方便,就用哪一个。

可是,总有一个最好用的吧,咱们根据稳定性来分,建议以下:

按照 优先使用 宽度 width) 其次 使用内边距(padding) 再次 外边距(margin)。

 

 

 

  width >  padding  >   margin   

缘由:

margin 会有外边距合并 还有 ie6margin 加倍的bug(讨厌)因此最后使用

padding 会影响盒子大小, 须要进行加减计算(麻烦) 其次使用。

width 没有问题(嗨皮)咱们常用宽度剩余法 高度剩余法来作。

盒子阴影

语法格式:

box-shadow:水平阴影 垂直阴影 模糊距离 阴影尺寸 阴影颜色  内/外阴影;

1前两个属性是必须写的。其他的能够省略。

2外阴影 (outset) 可是不能写 默认 想要内阴影 inset

 

 

 

 

 

div {
            width: 200px;
            height: 200px;
            border: 10px solid red;
            /* box-shadow: 5px 5px 3px 4px rgba(0, 0, 0, .4);  */
            /* box-shadow:水平位置 垂直位置 模糊距离 阴影尺寸(影子大小) 阴影颜色  内/外阴影; */
            box-shadow: 0 15px 30px  rgba(0, 0, 0, .4);
            
}

浮动(float)

普通流(normal flow)

这个单词不少人翻译为 文档流 字面翻译 普通流 或者标准流均可以。

前面咱们说过,网页布局的核心,就是用CSS来摆放盒子位置。如何把盒子摆放到合适的位置?

CSS的定位机制有3种:普通流(标准流)、浮动和定位。

html语言当中另一个至关重要的概念----------标准流!或者普通流。普通流实际上就是一个网页内标签元素正常从上到下,从左到右排列顺序的意思,好比块级元素会独占一行,行内元素会按顺序依次先后排列;按照这种大前提的布局排列之下绝对不会出现例外的状况叫作普通流布局。

浮动(float)

浮动最先是用来控制图片,以便达到其余元素(特别是文字)实现“环绕”图片的效果。

后来,咱们发现浮动有个颇有意思的事情:就是让任何盒子能够一行排列,所以咱们就慢慢的偏离主题,用浮动的特性来布局了。(CSS3已经咱们真正意义上的网页布局,具体CSS3咱们会详细解释)

什么是浮动?

元素的浮动是指设置了浮动属性的元素会脱离标准普通流的控制,移动到其父元素中指定位置的过程。

CSS中,经过float属性来定义浮动,其基本语法格式以下:

元素的浮动是指设置了浮动属性的元素会脱离标准普通流的控制,移动到其父元素中指定位置的过程。

CSS中,经过float属性来定义浮动,其基本语法格式以下:

浮动详细内幕特性

浮动脱离标准流,不占位置,会影响标准流。浮动只有左右浮动。

浮动首先建立包含块的概念(包裹)。就是说, 浮动的元素老是找理它最近的父级元素对齐。可是不会超出内边距的范围。

浮动的元素排列位置,跟上一个元素(块级)有关系。若是上一个元素有浮动,则A元素顶部会和上一个元素的顶部对齐;若是上一个元素是标准流,则A元素的顶部会和上一个元素的底部对齐。

2能够推断出,一个父盒子里面的子盒子,若是其中一个子级有浮动的,则其余子级都须要浮动。这样才能一行对齐显示。

元素添加浮动后,元素会具备行内块元素的特性。元素的大小彻底取决于定义的大小或者默认的内容多少浮动根据元素书写的位置来显示相应的浮动。

 

 

 

 

 

总结 浮动 --->

浮动的目的就是为了让多个块级元素同一行上显示。

float 浮 漏 特 

浮: 加了浮动的元素盒子是浮起来的,漂浮在其余的标准流盒子上面。漏: 加了浮动的盒子,不占位置的,它浮起来了,它原来的位置漏 给了标准流的盒子。特: 特别注意,首先浮动的盒子须要和标准流的父级搭配使用, 其次 特别的注意浮动可使元素显示模式体现为行内块特性。

版心和布局流程

阅读报纸时容易发现,虽然报纸中的内容不少,可是通过合理地排版,版面依然清晰、易读。一样,在制做网页时,要想使页面结构清晰、有条理,也须要对网页进行“排版”。

“版心”(可视区) 是指网页中主体内容所在的区域。通常在浏览器窗口中水平居中显示,常见的宽度值为960px、980px、1000px、1200px等。

布局流程

为了提升网页制做的效率,布局时一般须要遵照必定的布局流程,具体以下:

一、肯定页面的版心(可视区)。

二、分析页面中的行模块,以及每一个行模块中的列模块。

三、制做HTML结构 。

四、CSS初始化,而后开始运用盒子模型的原理,经过DIV+CSS布局来控制网页的各个模块。

清除浮动

准确地说,并非清除浮动,而是清除浮动后形成的影响

 

清除浮动本质

清除浮动主要为了解决父级元素由于子级浮动引发内部高度为0 的问题。

 

清除浮动的方法

其实本质叫作闭合浮动更好一些, 记住,清除浮动就是把浮动的盒子圈到里面,让父盒子闭合出口和入口不让他们出来影响其余元素。

CSS中,clear属性用于清除浮动,其基本语法格式以下:

选择器{clear:属性值;}

额外标签法

W3C推荐的作法是经过在浮动元素末尾添加一个空的标签例如 <div style=”clear:both”></div>,或则其余标签br等亦可。

优势: 通俗易懂,书写方便

缺点: 添加许多无心义的标签,结构化较差。 我只能说,w3c你推荐的方法我不接受,你不值得拥有。。。

父级添加overflow属性方法

能够经过触发BFC的方式,能够实现清除浮动效果。(BFC后面讲解)

能够给父级添加: overflow hidden|auto|scroll  均可以实现。

优势: 代码简洁

缺点: 内容增多时候容易形成不会自动换行致使内容被隐藏掉,没法显示须要溢出的元素。

使用after伪元素清除浮动

:after 方式为空元素的升级版,好处是不用单独加标签了 

使用方法:

 .clearfix:after {  content: "."; display: block; height: 0; clear: both; visibility: hidden;  }  

 .clearfix {*zoom: 1;}   /* IE六、7 专有 */

优势: 符合闭合浮动思想 结构语义化正确

缺点: 因为IE6-7不支持:after,使用 zoom:1触发 hasLayout。

注意: content:"." 里面尽可能跟一个小点,或者其余,尽可能不要为空,不然再firefox 7.0前的版本会有生成空格。

 

 

 

 

 

 

使用before和after双伪元素清除浮动

使用方法:

.clearfix:before,.clearfix:after {
  content:"";
  display:table;  /* 这句话能够出发BFC BFC能够清除浮动,BFC咱们后面讲 */
}
.clearfix:after {
 clear:both;
}
.clearfix {
  *zoom:1;
}

优势: 码更简洁

缺点: 因为IE6-7不支持:after,使用 zoom:1触发 hasLayout。

定位(position)

元素的定位属性

素的定位属性主要包括定位模式和边偏移两部分

一、边偏移

边偏移属性

描述

top

顶端偏移量,定义元素相对于其父元素上边线的距离

bottom

底部偏移量,定义元素相对于其父元素下边线的距离

left

左侧偏移量,定义元素相对于其父元素左边线的距离

right

右侧偏移量,定义元素相对于其父元素右边线的距离

也就说,之后定位要和这边偏移搭配使用了, 好比 top: 100px; left: 30px; 等等

 

 

 

 

二、定位模式(定位的分类)

CSS中,position属性用于定义元素的定位模式,其基本语法格式以下:

选择器{position:属性值;}

position属性的经常使用值

描述

static

自动定位(默认定位方式)

relative

相对定位,相对于其原文档流的位置进行定位

absolute

绝对定位,相对于其上一个已经定位的父元素进行定位

fixed

固定定位,相对于浏览器窗口进行定位

静态定位(static)

静态定位是全部元素的默认定位方式,当position属性的取值为static时,能够将元素定位于静态位置。 所谓静态位置就是各个元素在HTML文档流中默认的位置。

上面的话翻译成白话: 就是网页中全部元素都默认的是静态定位哦! 其实就是标准流的特性。

在静态定位状态下,没法经过边偏移属性(top、bottom、left或right)来改变元素的位置。

PS: 静态定位其实没啥可说的。

相对定位relative(自恋型)

相对定位是将元素相对于它在标准流中的位置进行定位,当position属性的取值为relative时,能够将元素定位于相对位置。对元素设置相对定位后,能够经过边偏移属性改变元素的位置,可是它在文档流中的位置仍然保留。以下图所示,便是一个相对定位的效果展现:

注意:

一、相对定位最重要的一点是,它能够经过边偏移移动位置,可是原来的所占的位置,继续占有。

二、其次,每次移动的位置,是以本身的左上角为基点移动(相对于本身来移动位置)

就是说,相对定位的盒子仍在标准流中,它后面的盒子仍以标准流方式对待它。(相对定位不脱标)

若是说浮动的主要目的是 让多个块级元素一行显示,那么定位的主要价值就是 移动位置, 让盒子到咱们想要的位置上去。

绝对定位absolute (拼爹型)

注意:

相对定位最重要的一点是,它能够经过边偏移移动位置,可是原来的所占的位置,继续占有。

其次,每次移动的位置,是以本身的左上角为基点移动(相对于本身来移动位置)就是说,相对定位的盒子仍在标准流中,它后面的盒子仍以标准流方式对待它。(相对定位不脱标)

若是说浮动的主要目的是 让多个块级元素一行显示,那么定位的主要价值就是 移动位置, 让盒子到咱们想要的位置上去。

绝对定位absolute (拼爹型)

[注意] 若是文档可滚动,绝对定位元素会随着它滚动,由于元素最终会相对于正常流的某一部分定位。

position属性的取值为absolute时,能够将元素的定位模式设置为绝对定位。

注意: 绝对定位最重要的一点是,它能够经过边偏移移动位置,可是它彻底脱标,彻底不占位置。

父级没有定位

若全部父元素都没有定位,以浏览器为准对齐(document文档)。

父级有定位

绝对定位是将元素依据最近的已经定位(绝对、固定或相对定位)的父元素(祖先)进行定位

子绝父相

这个“子绝父相”过重要了,是咱们学习定位的口诀,时时刻刻记住的。

这句话的意思是 子级是绝对定位的话, 父级要用相对定位。

首先, 咱们说下, 绝对定位是将元素依据最近的已经定位绝对、固定或相对定位)的父元素(祖先)进行定位。就是说, 子级是绝对定位,父亲只要是定位便可(无论父亲是绝对定位仍是相对定位,甚至是固定定位均可以),就是说, 子绝父绝,子绝父相都是正确的。

因此,咱们能够得出以下结论:

由于子级是绝对定位,不会占有位置, 能够放到父盒子里面的任何一个地方。

父盒子布局时,须要占有位置,所以父亲只能是 相对定位.

这就是子绝父相的由来。

 

绝对定位的盒子水平/垂直居中

普通的盒子是左右margin 改成 auto就可 可是对于绝对定位就无效了

定位的盒子也能够水平或者垂直居中,有一个算法。

首先left 50% 父盒子的一半大小

而后走本身外边距负的一半值就能够了 margin-left。

固定定位fixed(认死理型)

固定定位是绝对定位的一种特殊形式,相似于 正方形是一个特殊的 矩形。它以浏览器窗口做为参照物来定义网页元素。当position属性的取值为fixed时,便可将元素的定位模式设置为固定定位。

当对元素设置固定定位后,它将脱离标准文档流的控制,始终依据浏览器窗口来定义本身的显示位置。无论浏览器滚动条如何滚动也无论浏览器窗口的大小如何变化,该元素都会始终显示在浏览器窗口的固定位置。

固定定位有两点:

固定定位的元素跟父亲没有任何关系,只认浏览器。

固定定位彻底脱标,不占有位置,不随着滚动条滚动。

ie6等低版本浏览器不支持固定定位。

叠放次序(z-index)

当对多个元素同时设置定位时,定位元素之间有可能会发生重叠。

CSS中,要想调整重叠定位元素的堆叠顺序,能够对定位元素应用z-index层叠等级属性,其取值可为正整数、负整数和0。

好比: z-index: 2;

注意:

一、z-index的默认属性值是0,取值越大,定位元素在层叠元素中越居上。

二、若是取值相同,则根据书写顺序,后来居上。

三、后面数字必定不能加单位。

四、只有相对定位,绝对定位,固定定位有此属性,其他标准流,浮动,静态定位都无此属性,亦不可指定此属性。

四种定位总结

定位模式

是否脱标占有位置

是否可使用边偏移

移动位置基准

静态static

不脱标,正常模式

不能够

正常模式

相对定位relative

不脱标,占有位置

能够

相对自身位置移动(自恋型)

绝对定位absolute

彻底脱标,不占有位置

能够

相对于定位父级移动位置(拼爹型)

固定定位fixed

彻底脱标,不占有位置

能够

相对于浏览器移动位置(认死理型)

定位模式转换

浮动同样, 元素添加了 绝对定位和固定定位以后, 元素模式也会发生转换, 都转换为 行内块模式,

** 所以 好比 行内元素 若是添加了 绝对定位或者 固定定位后 浮动后,能够不用转换模式,直接给高度和宽度就能够了。**

元素的显示与隐藏

 

 

CSS中有三个显示和隐藏的单词比较常见,咱们要区分开,他们分别是 display visibility 和 overflow。

他们的主要目的是让一个元素在页面中消失,可是不在文档源码中删除。 最多见的是网站广告,当咱们点击相似关闭不见了,可是咱们从新刷新页面,它们又会出现和你玩躲猫猫!!

display 显示

display 设置或检索对象是否及如何显示。

display : none 隐藏对象 与它相反的是 display:block 除了转换为块级元素以外,同时还有显示元素的意思。

特色: 隐藏以后,再也不保留位置。

visibility 可见性

设置或检索是否显示对象。

visible :  对象可视

hidden :  对象隐藏

特色: 隐藏以后,继续保留原有位置。(停职留薪)

overflow 溢出

检索或设置当对象的内容超过其指定高度及宽度时如何管理内容。

visible :  不剪切内容也不添加滚动条。

auto :   超出自动显示滚动条,不超出不显示滚动条

hidden :  显示超过对象尺寸的内容,超出的部分隐藏掉

scroll :  无论超出内容否,老是显示滚动条

CSS高级技巧

CSS用户界面样式

 

 

所谓的界面样式, 就是更改一些用户操做样式, 好比 更改用户的鼠标样式, 表单轮廓等。可是好比滚动条的样式改动受到了不少浏览器的抵制,所以咱们就放弃了。 防止表单域拖拽

鼠标样式cursor

设置或检索在对象上移动的鼠标指针采用何种系统预约义的光标形状。

cursor :  default  小白 | pointer  小手  | move  移动  |  text  文本

鼠标放我身上查看效果哦:

<ul>
  <li style="cursor:default">我是小白</li>
  <li style="cursor:pointer">我是小手</li>
  <li style="cursor:move">我是移动</li>
  <li style="cursor:text">我是文本</li>
</ul>

尽可能不要用hand 由于 火狐不支持 pointer ie6以上都支持的尽可能用

轮廓 outline

是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的做用。

 outline : outline-color ||outline-style || outline-width 

可是咱们都不关心能够设置多少,咱们平时都是去掉的。

最直接的写法是 outline: 0; 或者 outline: none;

 <input  type="text"  style="outline: 0;"/>

防止拖拽文本域resize

resize:none 这个单词能够防止 火狐 谷歌等浏览器随意的拖动 文本域。

右下角能够拖拽: 

<textarea></textarea>

 

 

右下角不能够拖拽:

<textarea  style="resize: none;"></textarea>

vertical-align 垂直对齐

之前咱们讲过让带有宽度的块级元素居中对齐,是margin: 0 auto;

之前咱们还讲过让文字居中对齐,是 text-align: center;

可是咱们历来没有讲过有垂直居中的属性, 咱们的妈妈一直很担忧咱们的垂直居中怎么作。

vertical-align 垂直对齐, 这个看上去很美好的一个属性, 实际有着不可捉摸的脾气,不然咱们也不会这么晚来说解。

vertical-align : baseline |top |middle |bottom 

设置或检索对象内容的垂直对其方式。

vertical-align 影响块级元素中的内容对齐,它只针对于 行内元素或者行内块元素,特别是行内块元素 一般用来控制图片/表单与文字的对齐

图片、表单和文字对齐

因此咱们知道,咱们能够经过vertical-align 控制图片和文字的垂直关系了。 默认的图片会和文字基线对齐。

去除图片底侧空白缝隙

有个很重要特性你要记住: 图片或者表单等行内块元素,他的底线会和父级盒子的基线对齐。这样会形成一个问题,就是图片底侧会有一个空白缝隙。

 

 

 

解决的方法就是:

一、img vertical-align:middle|top等等。让图片不要和基线对齐。

二、img 添加 display:block; 转换为块级元素就不会存在问题了。

溢出的文字隐藏

word-break:自动换行

normal 使用浏览器默认的换行规则。

break-all 容许在单词内换行。

keep-all 只能在半角空格或连字符处换行。

主要处理英文单词

white-space

white-space设置或检索对象内文本显示方式。一般咱们使用于强制一行显示内容

normal :  默认处理方式nowrap :  强制在同一行内显示全部文本,直到文本结束或者遭遇br标签对象才换行。

能够处理中文

text-overflow 文字溢出

text-overflow : clip | ellipsis

设置或检索是否使用一个省略标记(...)标示对象内文本的溢出

clip :  不显示省略标记(...),而是简单的裁切

ellipsis :  当对象内文本溢出时显示省略标记(...)

注意必定要首先强制一行内显示,再次和overflow属性 搭配使用

 

 

 

 

 

字体图标

图片是有诸多优势的,可是缺点很明显,好比图片不但增长了总文件的大小,还增长了不少额外的"http请求",这都会大大下降网页的性能的。更重要的是图片不能很好的进行“缩放”,由于图片放大和缩小会失真。 咱们后面会学习移动端响应式,不少状况下但愿咱们的图标是能够缩放的。此时,一个很是重要的技术出现了,额不是出现了,是之前就有,是被重新"宠幸"啦。。 这就是字体图标(iconfont).

字体图标优势

能够作出跟图片同样能够作的事情,改变透明度、旋转度,等..

可是本质实际上是文字,能够很随意的改变颜色、产生阴影、透明效果等等...

自己体积更小,但携带的信息并无削减。

几乎支持全部的浏览器

移动端设备必备良药...

字体图标使用流程

设计字体图标

假如图标是咱们公司单独设计,那就须要第一步了,这个属于UI设计人员的工做, 他们在 illustrator 或 Sketch 这类矢量图形软件里建立 icon图标, 好比下图:

以后保存为svg格式,而后给咱们前端人员就行了。

其实第一步,咱们不须要关心,只须要给咱们这些图标就能够了,若是图标是大众的,网上原本就有的,能够直接跳过第一步,进入第三步。

上传生成字体包

UI设计人员给咱们svg文件的时候,咱们须要转换成咱们页面能使用的字体文件, 并且须要生成的是兼容性的适合各个浏览器的。

​ 推荐网站 http://icomoon.io

icomoon字库

IcoMoon成立于2011年,推出的第一个自定义图标字体生成器,它容许用户选择他们所须要的图标,使它们成一字型。 内容种类繁多,很是全面,惟一的遗憾是国外服务器,打开网速较慢。

推荐网站: http://www.iconfont.cn/

阿里icon font字库

http://www.iconfont.cn/

这个是阿里妈妈M2UX的一个icon font字体图标字库,包含了淘宝图标库和阿里妈妈图标库。可使用AI制做图标上传生成。 一个字,免费,免费!!

fontello

http://fontello.com/

在线定制你本身的icon font字体图标字库,也能够直接从GitHub下载整个图标集,该项目也是开源的。

Font-Awesome

http://fortawesome.github.io/Font-Awesome/

这是我最喜欢的字库之一了,更新比较快。目前已经有369个图标了。

Glyphicon Halflings

http://glyphicons.com/

这个字体图标能够在Bootstrap下无偿使用。自带了200多个图标。

Icons8

https://icons8.com/

提供PNG免费下载,像素大能到500PX

 

下载兼容字体包

刚才上传完毕, 网站会给咱们把UI作的svg图片转换为咱们的字体格式, 而后下载下来就行了

固然,咱们不须要本身专门的图标,是想网上找几个图标使用,以上2步能够直接省略了, 直接到刚才的网站上找喜欢的下载使用吧。

字体引入到HTML

获得压缩包以后,最后一步,是最重要的一步了, 就是字体文件已经有了,咱们须要引入到咱们页面中。

首先把 如下4个文件放入到 fonts文件夹里面。 通俗的作法

第一步:在样式里面声明字体: 告诉别人咱们本身定义的字体

@font-face {
  font-family: 'icomoon';
  src:  url('fonts/icomoon.eot?7kkyc2');
  src:  url('fonts/icomoon.eot?7kkyc2#iefix') format('embedded-opentype'),
    url('fonts/icomoon.ttf?7kkyc2') format('truetype'),
    url('fonts/icomoon.woff?7kkyc2') format('woff'),
    url('fonts/icomoon.svg?7kkyc2#icomoon') format('svg');
  font-weight: normal;
  font-style: normal;
}

第二步:给盒子使用字体

span {
        font-family: "icomoon";
    }

 
 
 
 
第三步:盒子里面添加结构

span::before {
         content: "\e900";
    }或者  

<span></span>  

追加新图标到原来库里面

若是工做中,原来的字体图标不够用了,咱们须要添加新的字体图标,可是原来的不能删除,继续使用,此时咱们须要这样作

把压缩包里面的selection.json 重新上传,而后,选中本身想要新的图标,重新下载压缩包,替换原来文件便可。

CSS W3C 统一验证工具

CssStats 是一个在线的 CSS 代码分析工具

网址是:  http://www.cssstats.com/

若是你想要更全面的,这个神奇,你值得拥有:

W3C 统一验证工具: http://validator.w3.org/unicorn/ ☆☆☆☆☆

由于它能够检测本地文件哦!!

相关文章
相关标签/搜索