Maison > interface Web > js tutoriel > Combiner HTML avec CCS

Combiner HTML avec CCS

php中世界最好的语言
Libérer: 2018-03-19 10:04:13
original
6027 Les gens l'ont consulté

Cette fois, je vais vous présenter la combinaison de HTML et CCS. Quelles sont les précautions à prendre pour utiliser HTML et CCS ? Ce qui suit est un cas pratique, jetons un coup d'oeil.

1.1 Introduction au HTML

1.1.1 Nature des services Web

import socket
sk = socket.socket()
sk.bind(("127.0.0.1", 8080))
sk.listen(5) 
while True:
    conn, addr = sk.accept()
    data = conn.recv(8096)
    conn.send(b"HTTP/1.1 200 OK\r\n\r\n")
    conn.secd(b"<h1>Hello world!</h1>")
    conn.close()
Copier après la connexion

Le navigateur envoie une requête--> Protocole HTTP--> la requête-- > Le serveur renvoie une réponse --> Le serveur envoie le contenu du fichier HTML au navigateur --> Le navigateur restitue la page

1.1.2 Qu'est-ce que le HTML

Hypertext Markup Language (Hypertext Markup Language, HTML) est un langage de balisage utilisé pour créer des pages Web.

sont essentiellement des règles que le navigateur peut reconnaître. Nous écrivons des pages Web selon les règles, et le navigateur restitue nos pages Web selon les règles. La même balise peut être interprétée différemment par différents navigateurs. (Problème de compatibilité)

Extension de fichier de page web : .html ou .htm

HTML est un langage de balisage (markup language), ce n'est pas un langage de programmation. HTML utilise des balises pour décrire les pages Web.

1.2 Structure du document HTML

<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <title>css样式优先级</title>
</head>
<body>
 
</body>
</html>
Copier après la connexion
  • et sont les balises de début et de fin du document. Il s'agit de l'élément racine de la page HTML, et entre eux se trouvent l'en-tête et le corps du document.

  • ,

    définissent le début du document HTML. Le contenu entre eux ne sera pas affiché dans la fenêtre de document du navigateur. Contient les métadonnées du document.

  • et définissent le titre de la page Web et sont affichés dans la barre de titre du navigateur.

  • Le texte entre et est le contenu principal visible de la page Web.

Remarque : pour les pages Web en chinois, vous devez utiliser pour déclarer l'encodage, sinon des caractères tronqués apparaîtront. Certains navigateurs définiront GBK comme encodage par défaut, vous devez donc le définir sur .

1.2.1 Format des balises HTML

  • Les balises HTML sont des mots-clés entourés de crochets, tels que ,

    , etc.

  • Les balises HTML apparaissent généralement par paires, telles que :

    et

    , la première balise est le début et la deuxième balise est la fin. La balise de fermeture aura une barre oblique.

  • Il existe également certaines balises qui sont présentées séparément, telles que :
    ,


    , , etc. Les balises

  • peuvent avoir plusieurs attributs ou aucun attribut.

Syntaxe de la balise :

Partie du contenu< Nom de la balise>

Plusieurs attributs très importants :

id : définit l'ID unique de la balise, unique dans l'arborescence du document HTML

class : définit un ou plusieurs noms de classe (classname) (nom de classe de style CSS) pour les éléments html

style : Spécifie le style en ligne de l'élément (style CSS)

1.2.2 Commentaires HTML

<!--注释内容-->
Copier après la connexion

1.2.3 Balise > 1.3 Balises HTML courantes

<!DOCTYPE> 声明必须是 HTML 文档的第一行,位于 <html><!DOCTYPE>
Copier après la connexion
1.3.1 Balises communes dans l'en-tête

Figure 1-1

1.3.1.1 Balise méta

introduction de la balise méta :
  • L'élément peut fournir des informations originales sur la page (mata-information), le ciblage des moteurs de recherche et la fréquence de mise à jour. description et mots-clés. La balise
  • est située en tête du document et ne contient aucun contenu.
  • Les informations fournies sont invisibles pour l'utilisateur.
  • Composition de la balise méta : la balise méta a deux attributs, il s'agit de l'attribut http-equiv et de l'attribut name. Différents attributs ont des valeurs de paramètres différentes. Différentes fonctions de page Web sont implémentées. .
  • 1.http-equiv属性:相当于http的文件头作用,它可以向浏览器传回一些有用的信息,以帮助正确地显示网页内容,与之对应的属性值为content,content中的内容其实就是各个参数的变量值。

<meta http-equiv="refresh" content="2;URL=https://www.oldboyedu.com">
Copier après la connexion

<meta http-equiv="content-Type" charset=UTF8">
Copier après la connexion

<meta http-equiv="x-ua-compatible" content="IE=edge">
Copier après la connexion

2.name属性: 主要用于描述网页,与之对应的属性值为content,content中的内容主要是便于搜索引擎机器人查找信息和分类信息用的。

<meta name="keywords" content="meta总结,html meta,meta属性,meta跳转">
<meta name="description" content="老男孩教育Python学院">
Copier après la connexion

1.3.2 body内常用标签

1.3.2.1  基本标签(块级标签和内联标签)

<b>加粗</b>
<i>斜体</i>
<u>下划线</u>
<s>删除</s>
 
<p>段落标签</p>
 
<h1>标题1</h1>
<h2>标题2</h2>
<h3>标题3</h3>
<h4>标题4</h4>
<h5>标题5</h5>
<h6>标题6</h6>
 
<!--换行-->
<br>
 
<!--水平线--><hr>
Copier après la connexion

1.3.2.2  特殊字符

 

图1-2  

1.3.2.3  p标签和span标签

l  p标签用来定义一个块级元素,并无实际的意义。主要通过CSS样式为其赋予不同的表现。

l  span标签用来定义内联(行内)元素,并无实际的意义。主要通过CSS样式为其赋予不同的表现。

块级元素与行内元素的区别:

所谓块元素,是以另起一行开始渲染的元素,行内元素则不需另起一行。如果单独在网页中插入这两个元素,不会对页面产生任何的影响。

这两个元素是专门为定义CSS样式而生的。

注意:

关于标签嵌套:通常块级元素可以包含内联元素或某些块级元素,但内联元素不能包含块级元素,它只能包含其它内联元素。

注意:p标签不能包含块级标签。

1.3.2.4  img标签

<img src="图片的路径" alt="图片未加载成功时的提示" title="鼠标悬浮时提示信息" width="宽" height="高(宽高两个属性只用一个会自动等比缩放)">
Copier après la connexion

1.3.2.5  a标签

超链接标签

所谓的超链接是指从一个网页指向一个目标的连接关系,这个目标可以是另一个网页,也可以是相同网页上的不同位置,还可以是一个图片,一个电子邮件地址,一个文件,甚至是一个应用程序。

关于URL

URL是统一资源定位器(Uniform Resource Locator)的缩写,也被称为网页地址,是因特网上标准的资源的地址。
Copier après la connexion

URL地址由4部分组成

第1部分:为协议:http://、ftp://等

第2部分:为站点地址:可以是域名或IP地址

第3部分:为页面在站点中的目录:stu

第4部分:为页面名称,例如 index.html

各部分之间用“/”符号隔开。

<a href="http://www.oldboyedu.com" target="_blank" >点我</a>
Copier après la connexion

href属性指定目标网页地址。该地址可以有几种类型:

l  绝对URL - 指向另一个站点(比如 href="http://www.jd.com)

l  相对URL - 指当前站点中确切的路径(href="index.htm")

l  锚URL - 指向页面中的锚(href="#top")

target:

l  _blank表示在新标签页中打开目标网页

l  _self表示在当前标签页中打开目标网页

1.3.2.6  列表

无序列表

<ul type="disc">
  <li>第一项</li>
  <li>第二项</li>
</ul>
Copier après la connexion

type属性:

l  disc(实心圆点,默认值)

l  circle(空心圆圈)

l  square(实心方块)

l  none(无样式)

有序列表

<ol type="1" start="2">
  <li>第一项</li>
  <li>第二项</li>
</ol>
Copier après la connexion

type属性:

l  1 数字列表,默认值

l  A 大写字母

l  a 小写字母

l  Ⅰ大写罗马

l  ⅰ小写罗马

1.3.2.7  标题列表

<dl>
  <dt>标题1</dt>
  <dd>内容1</dd>
  <dt>标题2</dt>
  <dd>内容1</dd>
  <dd>内容2</dd>
</dl>
Copier après la connexion

1.3.2.8  表格

表格是一个二维数据空间,一个表格由若干行组成,一个行又有若干单元格组成,单元格里可以包含文字、列表、图案、表单、数字符号、预置文本和其它的表格等内容。

表格最重要的目的是显示表格类数据。表格类数据是指最适合组织为表格格式(即按行和列组织)的数据。

表格的基本结构:

<table>
  <thead>
  <tr>
    <th>序号</th>
    <th>姓名</th>
    <th>爱好</th>
  </tr>
  </thead>
  <tbody>
  <tr>
    <td>1</td>
    <td>Egon</td>
    <td>杠娘</td>
  </tr>
  <tr>
    <td>2</td>
    <td>Yuan</td>
    <td>日天</td>
  </tr>
  </tbody>
</table>
Copier après la connexion

属性:

l  border: 表格边框.

l  cellpadding: 内边距

l  cellspacing: 外边距.

l  width: 像素 百分比.(最好通过css来设置长宽)

l  rowspan: 单元格竖跨多少行

l  colspan: 单元格横跨多少列(即合并单元格)

1.3.2.9  form

功能:

表单用于向服务器传输数据,从而实现用户与Web服务器的交互

表单能够包含input系列标签,比如文本字段、复选框、单选框、提交按钮等等。

表单还可以包含textarea、select、fieldset和 label标签。

表单属性

图1-3  

表单元素

基本概念:

HTML表单是HTML元素中较为复杂的部分,表单往往和脚本、动态页面、数据处理等功能相结合,因此它是制作动态网站很重要的内容。

表单一般用来收集用户的输入信息

表单工作原理:

访问者在浏览有表单的网页时,可填写必需的信息,然后按某个按钮提交。这些信息通过Internet传送到服务器上。

服务器上专门的程序对这些数据进行处理,如果有错误会返回错误信息,并要求纠正错误。当数据完整无误后,服务器反馈一个输入完成的信息。

from django.conf.urls import url
from django.shortcuts import HttpResponse
 
 
def upload(request):
    print("request.GET:", request.GET)
    print("request.POST:", request.POST)
 
    if request.FILES:
        filename = request.FILES["file"].name
        with open(filename, 'wb') as f:
            for chunk in request.FILES['file'].chunks():
                f.write(chunk)
            return HttpResponse('上传成功')
    return HttpResponse("收到了!")
 
urlpatterns = [
    url(r'^upload/', upload),
]
Copier après la connexion

1.3.2.10  input

元素会根据不同的 type 属性,变化为多种形态。

图1-4  

属性说明:

l  name:表单提交时的“键”,注意和id的区别

l  value:表单提交时对应项的值

l  type="button", "reset", "submit"时,为按钮上显示的文本年内容

l  type="text","password","hidden"时,为输入框的初始值

l  type="checkbox", "radio", "file",为输入相关联的值

l  checked:radio和checkbox默认被选中的项

l  readonly:text和password设置只读

l  disabled:所有input均适用

1.3.2.11  select标签

<form action="" method="post">
  <select name="city" id="city">
    <option value="1">北京</option>
    <option selected="selected" value="2">上海</option>
    <option value="3">广州</option>
    <option value="4">深圳</option>
  </select>
</form>
Copier après la connexion

属性说明:

l  multiple:布尔属性,设置后为多选,否则默认单选

l  disabled:禁用

l  selected:默认选中该项

l  value:定义提交时的选项值

1.3.2.12  label标签

定义:

说明:

label 元素不会向用户呈现任何特殊效果。

<form action="">
  <label for="username">用户名</label>
  <input type="text" id="username" name="username">
</form>
Copier après la connexion

1.3.2.13  textarea多行文本

<textarea name="memo" id="memo" cols="30" rows="10">
  默认内容
</textarea>
Copier après la connexion

属性说明:

l  name:名称

l  rows:行数

l  cols:列数

l  disabled:禁用

1.4 CSS介绍

CSS(Cascading Style Sheet,层叠样式表)定义如何显示HTML元素。

当浏览器读到一个样式表,它就会按照这个样式表来对文档进行格式化(渲染)。

1.5 CSS语法

每个CSS样式由两个组成部分:选择器和声明。声明又包括属性和属性值。每个声明之后用分号结束。

图1-5  

1.6 CSS注释

/*这是注释*/
Copier après la connexion

1.7 CSS的几种引入方式

CSS的几种引入方式

1.7.1 行内样式

行内式是在标记的style属性中设定CSS样式。不推荐大规模使用。

<p style="color: red">Hello world.</p>
Copier après la connexion

1.7.2 内部样式

嵌入式是将CSS样式集中写在网页的

标签对的标签对中。格式如下:

<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        p{
            background-color: #2b99ff;
        }
    </style>
</head>
Copier après la connexion

1.7.3 外部样式

外部样式就是将css写在一个单独的文件中,然后在页面进行引入即可。推荐使用此方式。

<link href="mystyle.css" rel="stylesheet" type="text/css"/>
Copier après la connexion

1.8 CSS选择器

1.8.1 基本选择器

1.8.1.1  元素选择器

p {color: "red";}
Copier après la connexion

1.8.1.2  ID选择器

#i1 {
  background-color: red;
}
Copier après la connexion

1.8.1.3  类选择器

.c1 {
  font-size: 14px;
}
p.c1 {
  color: red;
}
Copier après la connexion

注意:

样式类名不要用数字开头(有的浏览器不认)。

标签中的class属性如果有多个,要用空格分隔。

1.8.1.4  通用选择器

* {
  color: white;
}
Copier après la connexion

1.8.2 组合选择器

1.8.2.1  后代选择器

/*li内部的a标签设置字体颜色*/

li a {
  color: green;
}
Copier après la connexion

1.8.2.2  儿子选择器

/*选择所有父级是

元素的

元素*/

p>p {
  font-family: "Arial Black", arial-black, cursive;
}
Copier après la connexion

1.8.2.3  毗邻选择器

/*选择所有紧接着

元素之后的

元素*/

p+p {
  margin: 5px;
}
Copier après la connexion

1.8.2.4  弟弟选择器

/*i1后面所有的兄弟p标签*/

#i1~p {
  border: 2px solid royalblue;
}
Copier après la connexion

1.8.3 属性选择器

1.8.3.1  常用的属性选择器

/*用于选取带有指定属性的元素。*/

p[title] {
  color: red;
}
Copier après la connexion

/*用于选取带有指定属性和值的元素。*/

p[title="213"] {
  color: green;
}
Copier après la connexion

1.8.3.2  不怎么常用的属性选择器

/*找到所有title属性以hello开头的元素*/

[title^="hello"] {
  color: red;
}
Copier après la connexion

/*找到所有title属性以hello结尾的元素*/

[title$="hello"] {
  color: yellow;
}
Copier après la connexion

/*找到所有title属性中包含(字符串包含)hello的元素*/

[title*=
Copier après la connexion

/*找到所有title属性(有多个值或值以空格分割)中有一个值为hello的元素:*/

[title~="hello"] {
  color: green;
}
Copier après la connexion

1.8.4 分组和嵌套

1.8.4.1  分组

当多个元素的样式相同的时候,我们没有必要重复地为每个元素都设置样式,我们可以通过在多个选择器之间使用逗号分隔的分组选择器来统一设置元素样式。

例如:

p, p {
  color: red;
}
Copier après la connexion

上面的代码为p标签和p标签统一设置字体为红色。

通常,我们会分两行来写,更清晰:

p,
p {
  color: red;
}
Copier après la connexion

1.8.4.2  嵌套

多种选择器可以混合起来使用,比如:.c1类内部所有p标签设置字体颜色为红色。

.c1 p {
  color: red;
}
Copier après la connexion

1.8.5 伪类选择器

/* 未访问的链接 */
a:link {
  color: #FF0000
}
 
/* 已访问的链接 */
a:visited {
  color: #00FF00
}
 
/* 鼠标移动到链接上 */
a:hover {
  color: #FF00FF
}
 
/* 选定的链接 */
a:active {
  color: #0000FF
}
 
/*input输入框获取焦点时样式*/
input:focus {
  outline: none;
  background-color: #eee;
}
Copier après la connexion

1.8.6 伪元素选择器

1.8.6.1  first-letter

常用的给首字母设置特殊样式:

p:first-letter {
  font-size: 48px;
  color: red;
}
Copier après la connexion

1.8.6.2  before

/*在每个

元素之前插入内容*/

p:before {
  content:"*";
  color:red;
}
Copier après la connexion

1.8.6.3  after

/*在每个

元素之后插入内容*/

p:after {
  content:"[?]";
  color:blue;
}
Copier après la connexion

before和after多用于清除浮动。

1.8.7 选择器的优先级

1.8.7.1  CSS继承

继承是CSS的一个主要特征,它是依赖于祖先-后代的关系的。继承是一种机制,它允许样式不仅可以应用于某个特定的元素,还可以应用于它的后代。例如一个body定义了的字体颜色值也会应用到段落的文本中。

body {
  color: red;
}
Copier après la connexion

此时页面上所有标签都会继承body的字体颜色。然而CSS继承性的权重是非常低的,是比普通元素的权重还要低的0。

我们只要给对应的标签设置字体颜色就可覆盖掉它继承的样式。

p {
  color: green;
}
Copier après la connexion

此外,继承是CSS重要的一部分,我们甚至不用去考虑它为什么能够这样,但CSS继承也是有限制的。有一些属性不能被继承,如:border, margin, padding, background等。

1.8.7.2  选择器的优先级

我们上面学了很多的选择器,也就是说在一个HTML页面中有很多种方式找到一个元素并且为其设置样式,那浏览器根据什么来决定应该应用哪个样式呢?

其实是按照不同选择器的权重来决定的,具体的选择器权重计算方式如下图:

图1-6  

除此之外还可以通过添加 !import方式来强制让样式生效,但并不推荐使用。因为如果过多的使用!import会使样式文件混乱不易维护。

注意:万不得已可以使用!import,尽量不用!

1.9 CSS属性相关

1.9.1 字体属性

1.9.1.1  文字字体

font-family可以把多个字体名称作为一个“回退”系统来保存。如果浏览器不支持第一个字体,则会尝试下一个。浏览器会使用它可识别的第一个值。

简单实例:

body {
  font-family: "Microsoft Yahei", "微软雅黑", "Arial", sans-serif
}
Copier après la connexion

1.9.1.2  字体大小

p {
  font-size: 14px;
}
Copier après la connexion
Copier après la connexion

如果设置成inherit表示继承父元素的字体大小值。

1.9.1.3  字重(粗细)

font-weight用来设置字体的字重(粗细)。

p {
  font-size: 14px;
}
Copier après la connexion
Copier après la connexion

图1-7  

1.9.1.4  文本颜色

颜色属性被用来设置文字的颜色。

颜色是通过CSS最经常的指定:

十六进制值 - 如: #FF0000

一个RGB值 - 如: RGB(255,0,0)

颜色的名称 - 如:  red

还有rgba(255,0,0,0.3),第四个值为alpha, 指定了色彩的透明度/不透明度,它的范围为0.0到1.0之间。

1.9.2 文字属性

1.9.2.1  文字对齐

text-align 属性规定元素中的文本的水平对齐方式。

图1-8  

1.9.2.2  文字装饰

ext-decoration 属性用来给文字添加特殊效果。

图1-9  

常用的为去掉a标签默认的自划线:

a {
  text-decoration: none;
}
Copier après la connexion

1.9.2.3  首行缩进

将段落的第一行缩进 32像素:

p {
  text-indent: 32px;
}
Copier après la connexion

1.9.3 背景属性

/*背景颜色*/
background-color: red;
/*背景图片*/
background-image: url('1.jpg');
/*
 背景重复
 repeat(默认):背景图片平铺排满整个网页
 repeat-x:背景图片只在水平方向上平铺
 repeat-y:背景图片只在垂直方向上平铺
 no-repeat:背景图片不平铺
*/
background-repeat: no-repeat;
/*背景位置*/
background-position: right top(20px 20px);
Copier après la connexion

支持简写:

background:#ffffff url('1.png') no-repeat right top;
Copier après la connexion

使用背景图片的一个常见案例就是很多网站会把很多小图标放在一张图片上,然后根据位置去显示图片。减少频繁的图片请求。

参考链接:http://www.w3school.com.cn/css/css_background.asp

例子:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>滚动背景图示例</title>
    <style>
        * {
            margin: 0;
        }
        .box {
            width: 100%;
            height: 500px;
            background: url("https://www.luffycity.com/static/img/width-bank.1c9d1b0.png") no-repeat center center;
            background-attachment: fixed;
        }
        .d1 {
            height: 500px;
            background-color: tomato;
        }
        .d2 {
            height: 500px;
            background-color: steelblue;
        }
        .d3 {
            height: 500px;
            background-color: mediumorchid;
        }
    </style>
</head>
<body>
    <p class="d1"></p>
    <p class="box"></p>
    <p class="d2"></p>
    <p class="d3"></p>
</body>
</html>
Copier après la connexion

1.9.4 边框

边框属性

l  border-width

l  border-style

l  border-color

#i1 {
  border-width: 2px;
  border-style: solid;
  border-color: red;
}
Copier après la connexion

通常使用简写方式:

#i1 {
  border: 2px solid red;
}
Copier après la connexion

边框样式

图1-10  

除了可以统一设置边框外还可以单独为某一个边框设置样式,如下所示:

#i1 {
  border-top-style:dotted;
  border-top-color: red;
  border-right-style:solid;
  border-bottom-style:dotted;
  border-left-style:none;
}
Copier après la connexion

1.9.5 border-radius

用这个属性能实现圆角边框的效果。

将border-radius设置为长或高的一半即可得到一个圆形。

1.9.6 display属性

用于控制HTML元素的显示效果。

 

图1-11  

1.9.6.1  display:"none"与visibility:hidden的区别:

visibility:hidden: 可以隐藏某个元素,但隐藏的元素仍需占用与未隐藏之前一样的空间。也就是说,该元素虽然被隐藏了,但仍然会影响布局。

display:none: 可以隐藏某个元素,且隐藏的元素不会占用任何空间。也就是说,该元素不但被隐藏了,而且该元素原本占用的空间也会从页面布局中消失。

1.9.7 CSS盒子模型

l  margin:            用于控制元素与元素之间的距离;margin的最基本用途就是控制元素周围空间的间隔,从视觉角度上达到相互隔开的目的。

l  padding:           用于控制内容与边框之间的距离;  

l  Border(边框):     围绕在内边距和内容外的边框。

l  Content(内容):   盒子的内容,显示文本和图像。

图1-12  

1.9.7.1  margin外边距

.margin-test {
  margin-top:5px;
  margin-right:10px;
  margin-bottom:15px;
  margin-left:20px;
}
Copier après la connexion

推荐使用简写:

.margin-test {
  margin: 5px 10px 15px 20px;
}
Copier après la connexion

顺序:上右下左

1.9.7.2  常见居中:

.mycenter {
  margin: 0 auto;
}
Copier après la connexion

1.9.7.3  padding内填充

.padding-test {
  padding-top: 5px;
  padding-right: 10px;
  padding-bottom: 15px;
  padding-left: 20px;
}
Copier après la connexion

推荐使用简写:

.padding-test {
  padding: 5px 10px 15px 20px;
}
Copier après la connexion

顺序:上右下左

补充padding的常用简写方式:

提供一个,用于四边;

l  提供两个,第一个用于上-下,第二个用于左-右;

l  如果提供三个,第一个用于上,第二个用于左-右,第三个用于下;

l  提供四个参数值,将按上-右-下-左的顺序作用于四边;

1.9.7.4  float

在 CSS 中,任何元素都可以浮动。

浮动元素会生成一个块级框,而不论它本身是何种元素。

关于浮动的两个特点:

l  浮动的框可以向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止。

l  由于浮动框不在文档的普通流中,所以文档的普通流中的块框表现得就像浮动框不存在一样。

三种取值

left:向左浮动

right:向右浮动

none:默认值,不浮动

参考链接:http://www.w3school.com.cn/css/css_positioning_floating.asp

1.9.7.5  clear

clear属性规定元素的哪一侧不允许其他浮动元素。

图1-13  

注意:clear属性只会对自身起作用,而不会影响其他元素。

父标签塌陷问题

.clearfix:after {
  content: "";
  display: block;
  clear: both;
}
Copier après la connexion

1.9.7.6  overflow溢出属性

图1-14  

l  overflow(水平和垂直均设置)

l  overflow-x(设置水平方向)

l  overflow-y(设置垂直方向)

1.10 定位(position)

1.10.1 static

static 默认值,无定位,不能当作绝对定位的参照物,并且设置标签对象的left、top等值是不起作用的的。

1.10.2 relative(相对定位)

相对定位是相对于该元素在文档流中的原始位置,即以自己原始位置为参照物。有趣的是,即使设定了元素的相对定位以及偏移值,元素还占有着原来的位置,即占据文档流空间。对象遵循正常文档流,但将依据top,right,bottom,left等属性在正常文档流中偏移位置。而其层叠通过z-index属性定义。

注意:position:relative的一个主要用法:方便绝对定位元素找到参照物。

1.10.3 absolute(绝对定位)

定义:设置为绝对定位的元素框从文档流完全删除,并相对于最近的已定位祖先元素定位,如果元素没有已定位的祖先元素,那么它的位置相对于最初的包含块(即body元素)。元素原先在正常文档流中所占的空间会关闭,就好像该元素原来不存在一样。元素定位后生成一个块级框,而不论原来它在正常流中生成何种类型的框。

重点:如果父级设置了position属性,例如position:relative;,那么子元素就会以父级的左上角为原始点进行定位。这样能很好的解决自适应网站的标签偏离问题,即父级为自适应的,那我子元素就设置position:absolute;父元素设置position:relative;,然后Top、Right、Bottom、Left用百分比宽度表示。

另外,对象脱离正常文档流,使用top,right,bottom,left等属性进行绝对定位。而其层叠通过z-index属性定义。

1.10.4 fixed(固定)

fixed:对象脱离正常文档流,使用top,right,bottom,left等属性以窗口为参考点进行定位,当出现滚动条时,对象不会随着滚动。而其层叠通过z-index属性 定义。 注意点: 一个元素若设置了 position:absolute | fixed; 则该元素就不能设置float。这 是一个常识性的知识点,因为这是两个不同的流,一个是浮动流,另一个是“定位流”。但是 relative 却可以。因为它原本所占的空间仍然占据文档流。

在理论上,被设置为fixed的元素会被定位于浏览器窗口的一个指定坐标,不论窗口是否滚动,它都会固定在这个位置。

返回顶部按钮样式示例




  
  <meta http-equiv="x-ua-compatible" content="IE=edge">
  
  返回顶部示例
  

111

返回顶部

Copier après la connexion

1.10.5 z-index

#i2 {
  z-index: 999;
}
Copier après la connexion

设置对象的层叠顺序,数值大的会覆盖在数值小的标签之上。z-index 仅能在定位元素上奏效。

自定义模态框示例




  
  <meta http-equiv="x-ua-compatible" content="IE=edge">
  
  自定义模态框
  

 

Copier après la connexion

1.10.6 opacity

用来定义透明效果。取值范围是0~1,0是完全透明,1是完全不透明。

1.11 综合示例

1.11.1 顶部导航菜单




  
  <meta http-equiv="x-ua-compatible" content="IE=edge">
  
  li标签的float示例
  

Copier après la connexion

1.11.2 圆形头像




  
  <meta http-equiv="x-ua-compatible" content="IE=edge">
  
  圆形的头像示例
  

  

Copier après la connexion

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

怎么操作JS里的无序列表属性

map标签与area标签怎样使用

js的自定义trim函数使用方法

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal