HTML代码我爱编程

HTML+CSS摘要

2017-03-19  本文已影响374人  PYLON

本课来自http://www.imooc.com/learn/9
请不要用作商业用途。

HTML5

HTML介绍

HTML代码由标签组成,标签的语法是< XXX>.......</XXX>。

标签可以嵌套,而且一般为小写。

HTML有固定的格式:

<html> <head>...</head> <body>...</body> </html>

<head>标签

下面这些标签可用在 head 部分:
<head> <title>...</title> <meta> <link> <style>...</style> <script>...</script> </head>

HTML的注释

``

认识标签(第一部分)

添加段落——<p>

<p>段落文本</p> 注意一段文字要一个<p>标签

制作标题——<hx>

<hx>标题文本</hx> h1到h6字体逐渐变小

强调——<strong> <em>

<em>需要强调的文本</em> <em>默认用斜体表示
<strong>需要强调的文本</strong> <strong>默认用粗体表示

为文字设置单独的样式——<span>

<span>文本</span> <span>标签是没有语义的,它的作用就是为了设置单独的样式用的。

短文本引用——<q>

<q>引用文本</q>引用的文本不用加双引号,浏览器会对q标签自动添加双引号。

长文本引用——<blockquote>

<blockquote>引用文本</blockquote> 浏览器解析是缩进样式

换行——<br>

<br />是规范的写法,这是一个空标签,只有开始标签,没有结束标签

空格——&nbsp;

表示空格

添加水平线——<hr>

<hr/>是规范写法,这是一个空标签,只有开始标签,没有结束标签

为网页加入地址——<address>

<address>联系地址信息</address> 浏览器默认格式为斜体

加入代码——<code>

<code>代码语言</code>

加入大段代码——<pre>

<pre>语言代码段</pre> 在标签中文本可以保留空格和换行

认识标签(第二部分)

添加信息列表——<ul-li>

<ul> <li>信息<li> <ul>
ul-li是没有前后顺序的信息列表,ul-li在网页中显示的默认样式一般为:每项li前都自带一个圆点

添加有前后顺序的信息列表——<ol-li>

<ol> <li>信息<li> <ol>
网页中显示的默认样式一般为:每项<li>前都自带一个序号,序号默认从1开始

独立逻辑快划分——<div>

<div>…</div>
为div命名(命名必须唯一)的方法:
<div id="版块名称">…</div>

添加表格——<table>

创建表格的四个元素:table、tbody、tr、th、td

为表格添加摘要

<table summary="表格简介文本">

为表格添加标题——<caption>

<table> <caption>标题文本</caption> <tr> <td>…</td> <td>…</td> </tr> </table>

认识标签(第三部分)

链接到另一个页面——<a>

<a href="目标网址" title="鼠标滑过显示的文本">链接显示的文本</a>
若要在新的浏览器窗口打开页面:
<a href="目标网址" target="_blank">click here!</a>

在网页中链接Email地址——mailto

如果mailto后面同时有多个参数的话,第一个参数必须以“?”开头,后面的参数每一个都以“&”分隔。



example:

为网页插入图片——<img>

![](图片地址)

表单标签

与用户交互——表单标签

<form method="传送方式" action="服务器文件">

文本输入框,密码输入框

<form> <input type="text/password" name="名称" value="文本" /> </form>

多行文本输入

<textarea rows="行数" cols="列数">文本</textarea>

使用单选框和复选框

<input type="radio/checkbox" value="值" name="名称" checked="checked"/>

下拉列表框

重置表单信息

<input type="reset" value="重置">

标签<label>

<label for="控件id名称">
label标签不会向用户呈现任何特殊效果,它的作用是为鼠标用户改进了可用性。如果你在 label 标签内点击文本,就会触发此控件。就是说,当用户单击选中该label标签时,浏览器就会自动将焦点转到和标签相关的表单控件上(就自动选中和该label标签相关连的表单控件上)标签的 for 属性中的值应当与相关控件的 id 属性值一定要相同

CSS

CSS样式

认识CSS样式

CSS全称为“层叠样式表 (Cascading Style Sheets)”,它主要是用于定义HTML内容在浏览器内的显示样式,如文字大小、颜色、字体加粗等
p{ font-size:12px; color:red; font-weight:bold; }

CSS代码语法

CSS代码注释

和C++一样

CSS样式基本

内联式css样式,直接写在现有的HTML标签中

<p style="color:red;font-size:12px">这里文字是红色。</p>

嵌入式css样式,写在当前的文件中

实现把三个<span>标签中的文字设置为红色:
<style type="text/css"> span{ color:red; } </style>

外部式css样式,写在单独的一个文件中

外部式css样式(也可称为外联式)就是把css代码写一个单独的外部文件中,这个css样式文件以“.css”为扩展名,在<head>内(不是在<style>标签内)使用<link>标签将css样式文件链接到HTML文件内,如下面代码:
<link href="base.css" rel="stylesheet" type="text/css" />

三种方法的优先级

在相同权值的情况下,就是--就近原则(离被设置元素越近优先级别越高)

CSS选择器

什么是CSS选择器?

每一条css样式声明(定义)由两部分组成,形式如下:
选择器{ 样式; }
在{}之前的部分就是“选择器”,“选择器”指明了{}中的“样式”的作用对象,也就是“样式”作用于网页中的哪些元素

类选择器

.类选器名称{css样式代码;}

ID选择器

ID选择器和类选择器的异同
相同点:

可以应用于任何元素

不同点:

子选择器

子选择器,即大于符号(>),用于选择指定标签元素的第一代子元素
.food>li{border:1px solid red;}
这行代码会使class名为food下的子元素li(水果、蔬菜)加入红色实线边框

包含(后代)选择器

包含选择器,即加入空格,用于选择指定标签元素下的后辈元素。如右侧代码编辑器中的代码:
.first span{color:red;}
这行代码会使第一段文字内容中的“胆小如鼠”字体颜色变为红色。
请注意这个选择器与子选择器的区别,子选择器(child selector)仅是指它的直接后代,或者你可以理解为作用于子元素的第一代后代。而后代选择器是作用于所有子后代元素。后代选择器通过空格来进行选择,而子选择器是通过“>”进行选择。
总结:>作用于元素的第一代后代,空格作用于元素的所有后代

通用选择器

通用选择器是功能最强大的选择器,它使用一个(*)号指定,它的作用是匹配html中所有标签元素,如下使用下面代码使用html中任意标签元素字体颜色全部设置为红色:
* {color:red;}

伪类选择符

更有趣的是伪类选择符,为什么叫做伪类选择符,它允许给html不存在的标签(标签的某种状态)设置样式,比如说我们给html中一个标签元素的鼠标滑过的状态来设置字体颜色:
a:hover{color:red;}
上面一行代码就是为 a 标签鼠标滑过的状态设置字体颜色变红。
现在比较常用的是 a:hover 的组合

分组选择符

当你想为html中多个标签元素设置同一个样式时,可以使用分组选择符(,),如下代码为右侧代码编辑器中的h1、span标签同时设置字体颜色为红色:
h1,span{color:red;}

CSS的继承、层叠和特殊性

继承

CSS的某些样式是具有继承性的,那么什么是继承呢?继承是一种规则,它允许样式不仅应用于某个特定html标签元素,而且应用于其后代。比如下面代码:
p{color:red;} <p>三年级时,我还是一个<span>胆小如鼠</span>的小女孩。</p>

特殊性

浏览器是根据权值来判断使用哪种css样式的,权值高的就使用哪种css样式。

层叠

层叠就是在html文件中对于同一个元素可以有多个css样式存在,当有相同权重的样式存在时,会根据这些css样式的前后顺序来决定,处于最后面的css样式会被应用

重要性

我们可以使用!important来为某些样式设置具有最高权值
p{color:red!important;} p{color:green;} <p class="first">三年级时,我还是一个<span>胆小如鼠</span>的小女孩。</p>
注意:!important要写在分号的前面
浏览器默认的样式 < 网页制作者样式 < 用户自己设置的样式,但记住!important优先级样式是个例外,权值高于用户自己设置的样式

CSS格式化排版

字体

body{font-family:"Microsoft Yahei";}

字号、颜色

body{font-size:12px;color:#666}

粗体

p span{font-weight:bold;}

斜体

p a{font-style:italic;}

下划线

p a{text-decoration:underline;}

删除线

.oldPrice{text-decoration:line-through;}

缩进

p{text-indent:2em;} <p>1922年的春天,一个想要成名名叫尼克卡拉威(托比?马奎尔Tobey Maguire 饰)的作家,离开了美国中西部,来到了纽约。那是一个道德感渐失,爵士乐流行,走私为王,股票飞涨的时代。为了追寻他的美国梦,他搬入纽约附近一海湾居住。</p>

2em的意思就是文字的2倍大小。

行间距(行高)

p{line-height:1.5em;}

中文字间距、字母间距

如果想在网页排版中设置文字间隔或者字母间隔就可以使用 letter-spacing 来实现,如下面代码:

h1{ letter-spacing:50px; } <h1>了不起的盖茨比</h1>
注意:这个样式使用在英文单词时,是设置字母与字母之间的间距。

单词间距设置:

h1{ word-spacing:50px; } <h1>welcome to imooc!</h1>

对齐

使用text-align样式代码,如下代码可实现文本居中显示
h1{ text-align:center; } <h1>了不起的盖茨比</h1>

CSS盒模型

元素分类

块状元素

<div>、<p>、<h1>...<h6>、<ol>、<ul>、<dl>、<table>、<address>、<blockquote> 、<form>

内联元素

<a>、<span>、<br>、<i>、<em>、<strong>、<label>、<q>、<var>、<cite>、<code>

内联块状元素

<img>、<input>

块级元素

设置display:block就是将元素显示为块级元素。如下代码就是将内联元素a转换为块状元素,从而使a元素具有块状元素特点。
a{display:block;}

内联元素

块状元素也可以通过代码display:inline将元素设置为内联元素,如下代码就是将块状元素div转换为内联元素,从而使 div 元素具有内联元素特点
div{ display:inline; }

内联块状元素

代码display:inline-block就是将元素设置为内联块状元素

盒模型

边框(一)

盒子模型的边框就是围绕着内容及补白的线,这条线你可以设置它的粗细、样式和颜色(边框三个属性)
div{ border-width:2px; border-style:solid; border-color:red; }

边框(二)

css 样式中允许只为一个方向的边框设置样式:
div{border-bottom:1px solid red;}

宽度和高度

css内定义的宽(width)和高(height),指的是填充以里的内容范围
因此一个元素实际宽度(盒子的宽度)=左边界+左边框+左填充+内容宽度+右填充+右边框+右边界


div{ width:200px; padding:20px; border:1px solid red; margin:10px; }
元素的实际长度为:10px+1px+20px+200px+20px+1px+10px=262px

填充

元素内容与边框之间是可以设置距离的,称之为“填充”。填充也可分为上、右、下、左(顺时针)。如下代码:
div{ padding-top:20px; padding-right:10px; padding-bottom:15px; padding-left:30px; }

边界

元素与其它元素之间的距离可以使用边界(margin)来设置。边界也是可分为上、右、下、左。如下代码:
div{ margin-top:20px; margin-right:10px; margin-bottom:15px; margin-left:30px; }

总结一下:padding和margin的区别,padding在边框里,margin在边框外。

CSS布局模型

css布局模型

CSS包含3种基本的布局模型,用英文概括为:Flow、Layer 和 Float。
在网页中,元素有三种布局模型:

流动模型

先来说一说流动模型,流动(Flow)是默认的网页布局模式。也就是说网页在默认状态下的 HTML 网页元素都是根据流动模型来分布网页内容的。

浮动模型

任何元素在默认情况下是不能浮动的,但可以用 CSS 定义为浮动,如 div、p、table、img 等元素都可以被定义为浮动。如下代码可以实现两个 div 元素一行显示。
div{ width:200px; height:200px; border:2px red solid; float:left; } <div id="div1"></div> <div id="div2"></div>


div{ width:200px; height:200px; border:2px red solid; float:right; }

div{ width:200px; height:200px; border:2px red solid; } #div1{float:left;} #div2{float:right;}

![](https://img.haomeiwen.com/i5276931/3c07575584561a7b.png?imageMogr2/auto-
orient/strip%7CimageView2/2/w/1240)

层模型

层模型有三种形式:

绝对定位(position: absolute)

如果想为元素设置层模型中的绝对定位,需要设置position:absolute(表示绝对定位),这条语句的作用将元素从文档流中拖出来,然后使用left、right、top、bottom属性相对于其最接近的一个具有定位属性的父包含块进行绝对定位。如果不存在这样的包含块,则相对于body元素,即相对于浏览器窗口。
如下面代码可以实现div元素相对于浏览器窗口向右移动100px,向下移动50px。
div{ width:200px; height:200px; border:2px red solid; position:absolute; left:100px; top:50px; } <div id="div1"></div>

相对定位(position: relative)

如果想为元素设置层模型中的相对定位,需要设置position:relative(表示相对定位),它通过left、right、top、bottom属性确定元素在正常文档流中的偏移位置。相对定位完成的过程是首先按static(float)方式生成一个元素(并且元素像层一样浮动了起来),然后相对于以前的位置移动,移动的方向和幅度由left、right、top、bottom属性确定,偏移前的位置保留不动。

如下代码实现相对于以前位置向下移动50px,向右移动100px;
#div1{ width:200px; height:200px; border:2px red solid; position:relative; left:100px; top:50px; } <div id="div1"></div>

固定定位(position: fixed)

fixed:表示固定定位,与absolute定位类型类似,但它的相对移动的坐标是视图(屏幕内的网页窗口)本身。由于视图本身是固定的,它不会随浏览器窗口的滚动条滚动而变化,除非你在屏幕中移动浏览器窗口的屏幕位置,或改变浏览器窗口的显示大小,因此固定定位的元素会始终位于浏览器窗口内视图的某个位置,不会受文档流动影响,这与background-attachment:fixed;属性功能相同。以下代码可以实现相对于浏览器视图向右移动100px,向下移动50px。并且拖动滚动条时位置固定不变。
#div1{ width:200px; height:200px; border:2px red solid; position:fixed; left:100px; top:50px; }<p>文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本。</p>

Relative与Absolute组合使用

相对于其它元素进行定位必须遵守下面规范:

CSS代码优化

盒模型代码优化

外边距(margin)、内边距(padding)和边框(border)设置上下左右四个方向的边距是按照顺时针方向设置的:上右下左。

颜色值缩写

关于颜色的css样式也是可以缩写的,当你设置的颜色是16进制的色彩值时,如果每两位的值相同,可以缩写一半。

字体缩写

body{ font-style:italic; font-variant:small-caps; font-weight:bold; font-size:12px; line-height:1.5em; font-family:"宋体",sans-serif; }
这么多行的代码其实可以缩写为一句:
body{ font:italic small-caps bold 12px/1.5em "宋体",sans-serif; }

单位和值

颜色值

长度值

注意
但当给 font-size 设置单位为 em 时,此时计算的标准以 p 的父元素的 font-size 为基础。如下代码:
html:
<p>以这个<span>例子</span>为例。</p>
css:
p{font-size:14px} span{font-size:0.8em;}
结果 span 中的字体“例子”字体大小就为 11.2px(14 * 0.8 = 11.2px)

css样式设置小技巧

水平居中设置-行内元素

行内元素进行水平居中
如果被设置元素为文本、图片等行内元素时,水平居中是通过给父元素设置 text-align:center 来实现的。(父元素和子元素:如下面的html代码中,div是“我想要在父容器中水平居中显示”这个文本的父元素。反之这个文本是div的子元素 )如下代码:
html代码:
<body> <div class="txtCenter">我想要在父容器中水平居中显示。</div> </body>
css代码:
<style> .txtCenter{ text-align:center; } </style>

水平居中设置-定宽块状元素

满足定宽和块状两个条件的元素是可以通过设置“左右margin”值为“auto”来实现居中的。我们来看个例子就是设置 div 这个块状元素水平居中:
<style> div{ border:1px solid red;/*为了显示居中效果明显为 div 设置了边框*/ width:200px;/*定宽*/ margin:20px auto;/* margin-left 与 margin-right 设置为 auto */ } </style>

也可写成:
margin-left:auto; margin-right:auto;

水平居中总结-不定宽块状元素方法(一)

不定宽度的块状元素有三种方法居中(这三种方法目前使用的都很多):

加入[table]标签

为什么选择方法一加入table标签? 是利用table标签的长度自适应性---即不定义其长度也不默认父元素body的长度(table其长度根据其内文本长度决定),因此可以看做一个定宽度块元素,然后再利用定宽度块状居中的margin的方法,使其水平居中。

 <table>
  <tbody>
    <tr><td>
    <ul>
        <li>我是第一行文本</li>
        <li>我是第二行文本</li>
        <li>我是第三行文本</li>
    </ul>
    </td></tr>
  </tbody>
 </table>
</div>```
css代码:
```<style>
  table{
    border:1px solid;
    margin:0 auto;
  }
 </style>```

#####改变元素的display类型为行内元素
改变块级元素的 display 为 inline 类型(设置为 [行内元素]显示),然后使用 text-align:center
 来实现居中效果。如下例子:
html代码:

<body>
<div class="container">
<ul>
<li><a href="#">1</a></li>
<li><a href="#">2</a></li>
<li><a href="#">3</a></li>
</ul>
</div>
</body>```
css代码:

<style>
.container{
    text-align:center;
}
/* margin:0;padding:0(消除文本与div边框之间的间隙)*/
.container ul{
    list-style:none;
    margin:0;
    padding:0;
    display:inline;
}
/* margin-right:8px(设置li文本之间的间隔)*/
.container li{
    margin-right:8px;
    display:inline;
}
</style>```
* 这种方法相比第一种方法的优势是不用增加无语义标签,但也存在着一些问题:它将块状元素的 display 类型改为 inline,变成了行内元素,所以少了一些功能,比如设定长度值。

#####设置浮动和相对定位来实现
通过给父元素设置[ float],然后给父元素设置 [position:relative] 和 left:50%,子元素设置 position:relative 和 left: -50% 来实现水平居中。

我们可以这样理解:假想ul层的父层(即下面例子中的div层)中间有条平分线将ul层的父层(div层)平均分为两份,ul层的css代码是将ul层的最左端与ul层的父层(div层)的平分线对齐;而li层的css代码则是将li层的平分线与ul层的最左端(也是div层的平分线)对齐,从而实现li层的居中。
 
代码如下:
```<body>
<div class="container">
    <ul>
        <li><a href="#">1</a></li>
        <li><a href="#">2</a></li>
        <li><a href="#">3</a></li>
    </ul>
</div>
</body>```
css代码:
<style>
```.container{
    float:left;
    position:relative;
    left:50%
}

.container ul{
    list-style:none;
    margin:0;
    padding:0;
    
    position:relative;
    left:-50%;
}
.container li{float:left;display:inline;margin-right:8px;}
</style>```

####垂直居中-父元素高度确定的单行文本
我们在实际工作中也会遇到需要设置垂直居中的场景,比如好多报纸的文章标题在左右一侧时,常常会设置为垂直居中,为了用户体验性好。
这里我们又得分两种情况:父元素高度确定的单行文本,以及父元素高度确定的多行文本。
本节我们先来看第一种父元素高度确定的单行文本, 怎么设置它为垂直居中呢?
**父元素高度确定的单行文本**的竖直居中的方法是通过设置父元素的 height 和[ line-height ]高度一致来实现的。(height: 该元素的高度,line-height: 顾名思义,行高(行间距),指在文本中,行与行之间的 基线间的距离 )。
line-height 与 font-size 的计算值之差,在 CSS 中成为“行间距”。分为两半,分别加到一个文本行内容的顶部和底部。

这种文字行高与块高一致带来了一个弊端:当文字内容的长度大于块的宽时,就有内容脱离了块。
```<div class="container">
    hi,imooc!
</div>```
css代码:
```<style>
.container{
    height:100px;
    line-height:100px;
    background:#999;
}
</style>```

#####使用插入 [table] (包括tbody、tr、td)标签,同时设置 vertical-align:middle。
css 中有一个用于竖直居中的属性 vertical-align,在父元素设置此样式时,会对inline-block类型的子元素都有用。下面看一下例子:
html代码:
```<body>
<table><tbody><tr><td class="wrap">
<div>
    <p>看我是否可以居中。</p>
</div>
</td></tr></tbody></table>
</body>```
css代码:
```table td{height:500px;background:#ccc}```
因为 td 标签默认情况下就默认设置了 vertical-align 为 middle,所以我们不需要显式地设置了。

#####设置块级元素的 display 
在 chrome、firefox 及 IE8 以上的浏览器下可以设置块级元素的 display 为 table-cell(设置为表格单元显示),激活 vertical-align 属性,但注意 IE6、7 并不支持这个样式, 兼容性比较差。
html代码:
```<div class="container">
    <div>
        <p>看我是否可以居中。</p>
        <p>看我是否可以居中。</p>
        <p>看我是否可以居中。</p>
    </div>
</div>```
css代码:
```<style>
.container{
    height:300px;
    background:#ccc;
    display:table-cell;/*IE8以上及Chrome、Firefox*/
    vertical-align:middle;/*IE8以上及Chrome、Firefox*/
}
</style>```
这种方法的好处是不用添加多余的无意义的标签,但缺点也很明显,它的兼容性不是很好,不兼容 IE6、7而且这样修改display的block变成了table-cell,破坏了原有的块状元素的性质。

####隐性改变display类型
有一个有趣的现象就是当为元素(不论之前是什么类型元素,display:none 除外)设置以下 2 个句之一:
 *  [position : absolute]
*  float : left 或 [float:right]
简单来说,只要html代码中出现以上两句之一,元素的display显示类型就会自动变为以 display:inline-block([块状元素])的方式显示,当然就可以设置元素的 width 和 height 了,且默认宽度不占满父元素。
如下面的代码,小伙伴们都知道 a 标签是 [行内元素] ,所以设置它的 width 是 没有效果的,但是设置为 position:absolute 以后,就可以了。
```<div class="container">
    <a href="#" title="">进入课程请单击这里</a>
</div>```

CSS代码:
```<style>
.container a{
    position:absolute;
    width:200px;
    background:#ccc;
}
</style>```
上一篇下一篇

猜你喜欢

热点阅读