HTML/CSS的基本使用

简介:   本篇博客主要介绍一下HTML/CSS的基本使用,关于它们的介绍便不在赘述,读者可自行google或百度。一、HTML  先来简单介绍一下HTML标签:     HTML 标签是由尖括号包围的关键词,比如     HTML 标签通常是成对出现的,比如 和     标签对中的第一个标签是开始标签,第二个标签是结束标签     开始和结束标签也被称为开放标签和闭合标签  首先在写每个HTML的文档之前需要一个基本模板,一般的HTML编辑器都会自动生成。

  本篇博客主要介绍一下HTML/CSS的基本使用,关于它们的介绍便不在赘述,读者可自行google或百度。

一、HTML

  先来简单介绍一下HTML标签:
    HTML 标签是由尖括号包围的关键词,比如 <html>
    HTML 标签通常是成对出现的,比如 <b> 和 </b>
    标签对中的第一个标签是开始标签,第二个标签是结束标签
    开始和结束标签也被称为开放标签和闭合标签

  首先在写每个HTML的文档之前需要一个基本模板,一般的HTML编辑器都会自动生成。

<!DOCTYPE html>
<!--在html文档中注释写成这种格式-->
<!--一般的html标签都是成对出现-->

<html lang="en">
<head> <meta charset="UTF-8" /> <title>Title</title> </head> <body> </body> </html>

   注1:如<html lang="en">,html是标签名称,lang是html标签的属性。

   注2:在HTML文档中,在<head>标签内设置一个文件的编码,标题等,在<body>标签内写文档的内容等。

   注3:在HTML中,存在自闭和标签,例如上面的<meta />标签,自闭和标签不需要结束标签,通常自闭和标签在结束时写一个'/'与普通标签区别。

一、<head>标签内的常用标签:

<!DOCTYPE html>

<html lang="en">
<head>
    <!--设置编码-->
    <meta charset="UTF-8" />

    <!--刷新和跳转只能使用一个-->
    <!--设置每隔3秒自动刷新-->
    <!--<meta http-equiv="Refresh" content="3" />-->
    <!--设置5秒后自动跳转-->
    <!--<meta http-equiv="Refresh" content="5; url=https://www.baidu.com" />-->

    <!--设置标题-->
    <title>Hello</title>
    <!--设置图标-->
    <link rel="shortcut icon" href="image/abc.jpg">

    <!--设置关键字,供搜索引擎使用,当用户搜索这些关键字时,搜索引擎可将你的网页链接提供给用户-->
    <meta name="keywords" content="博客园,html,w3c" />

    <!--简要描述网站的信息,写一下网站是干什么的-->
    <meta name="description" content="此网页用与学习html/css的基本使用" />

</head>
<body>
    <h1>hello world</h1>
</body>
</html>

  注1:在html中可以告诉浏览器当前文档的语言,如上述代码中<html lang="en">,就是告诉浏览器这个文档时英文的,比如当使用Chrome浏览器打开一个英文网页时浏览器会弹出是否翻译的询问窗口,浏览器辨别网页内容是什么语言时就会用到这个属性,不做强制要求。

  注2:上述代码中所说的标题和图标如下图,Hello是标题,它前面的那个是图标。

二、<body>标签内的常用标签:

 1 <!--块级标签:-->
 2 <!--block元素(块级标签)的特点是:-->
 3 <!--    总是在新行上开始;-->
 4 <!--    高度,行高以及顶和底边距都可控制;-->
 5 <!--    宽度缺省是它的容器的100%,除非设定一个宽度-->
 6 <!--    <div>, <p>, <h1>, <form>, <ul>和<li>是块元素的例子。-->
 7 <h1></h1>
 8 <h2></h2>
 9 ……
10 <h6></h6> --- 标题标签,默认效果,加大加粗,从h1到h6加大字号不同。
11 <p></p> --- 段落标签,被p标签所包裹的内容独占一段,段落与段落之间有间距。
12 <div></div> --- 默认无效果,是最常见的块级标签。 
块级标签
1 <!--内联标签-->
2 <!--inline元素(内联标签)的特点是:-->
3 <!--    和其他元素都在一行上;-->
4 <!--    高,行高及顶和底边距不可改变;-->
5 <!--    宽度就是它的文字或图片的宽度,不可改变。-->
6 <!--    <span>, <a>, <label>, <input>, <img>, <strong>和<em>是inline元素的例子。-->
7 <span></span> --- 默认没有任何效果。
内联标签 
1 <!--最常用的特殊符号:-->
2 
3 <br /> --- 换行标签,在一般的文本文档中使用\r或\r\n做换行符,在HTML文档中使用此标签。
4 
5 < ------ &lt;
6 > ------ &gt;
7 空格 ------ &nbsp;
特殊符号
注1:在html中,一些特殊符号是无法直接显示的,比如要把<p>显示在网页上,可以这样写--------- &lt;p&gt;
   像这些特殊符号需要使用特殊的代码来表示,我们可以查阅HTML特殊字符编码对照表

 练习使用一下上面的标签(编辑成一个HTML文档,用浏览器打开):

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <h1>标题一</h1>
    <h2>标题二</h2>
    <h3>标题三</h3>
    <h4>标题四</h4>
    <h5>标题五</h5>
    <h6>标题六</h6>
    <p>123</p><p>456</p><p>678</p>
    <p>hello<br />world</p>

    <span>abc</span><span>def</span>
    <div>hij</div><div>klm</div>
    <div>asdfsfafsaf</div>
</body>
</html>

三、表单标签:

  在html中常常使用表单标签来向服务器端提交数据。html中的表单标签是<form></form>,其中间包裹的内容就是向服务端提交的数据(比如用户的账号密码,在某网站要发表的文章等)。

from标签内标签---input标签系列

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>

<body>
<div>
    <!--在form标签中,属性action写将表单数据提交到哪个URL,method写以哪种方法提交(get/post)-->
    <form action="http://localhost:8888/index" method="get">
        <div>
            <!--input标签中,type="text"时,输入框内可输入任意文本内容-->
            <!--当input做输入框时,name属性必须设置,后台程序使用name的值提取表单数据-->
            <input type="text" name="user" />
        </div>

        <div>
            <!--input标签中,type="password"时,输入框内输入密码-->
            <input type="password" name="password" />
        </div>

        <div>
            <!--当input做输入框时,可使用value属性为输入框提供默认值-->
            <input type="text" name="email" value="abc@example.com" />
        </div>

        <p>
            <span>请选择性别:</span>
            <!--使用input标签做单选按钮,属性设置type="radio" name="gender"几个选项的name必须一样-->
            <!--当checked="checked"时,该项默认选中-->
            男:<input type="radio" name="gender" value="F" checked="checked" />
            女:<input type="radio" name="gender" value="M"/>
            <br />
            <span>爱好:</span>
            <!--使用input标签做复选按钮,属性设置type="checkbox" name="hobby"几个选项的name必须一样-->
            <!--当checked="checked"时,该项默认选中-->
            篮球:<input type="checkbox" name="hobby" value="1" checked="checked" />
            游泳:<input type="checkbox" name="hobby" value="2" />
            阅读:<input type="checkbox" name="hobby" value="3" checked="checked" />
            唱歌:<input type="checkbox" name="hobby" value="4" />
        </p>


        <div>
            <!--input标签中,type="button"时,为普通按钮,默认无任何功能,可用CSS为其添加功能-->
            <!--当input做按钮时,value的值显示在按钮上-->
            <input type="button" value="按钮" />
        </div>

        <div>
            <!--input标签中,type="reset"时,为重置按钮,重置当前表单的所有内容-->
            <input type="reset" value="重置">
            <!--input标签中,type="submit"时,为提交按钮,在浏览器中点击后向服务器端提交表单数据-->
            <input type="submit" value="提交" />
        </div>
    </form>

    <p>
        <!--当要上传文件时,form标签的enctype="multipart/form-data"属性需设置-->
        <form enctype="multipart/form-data">
            <!--input标签做文件上传按钮,type="file"-->
            上传文件:<input type="file" name="filename" /><br />
            <input type="submit">
        </form>
    </p>

</div>
</body>
</html>

from标签内标签---其他标签

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div>
    <!--在form标签中,属性action写将表单数据提交到哪个URL,method写以哪种方法提交(get/post)-->
    <form action="http://xxx.xxx.xxx/xxx" method="get">
        <div>
            <span>城市:</span>
            <!--下拉选择框使用select标签,单选-->
            <select name="city">
                <!--选项使用option标签,提交选项的value的值-->
                <option value="BeiJing">北京</option>
                <!--默认选中,使用selected="selected"属性-->
                <option value="ShangHai" selected="selected">上海</option>
                <option value="GuangZhou">广州</option>
                <option value="ShenZhen">深圳</option>
            </select>
            <br />
            <span>城市(多选):</span>
            <!--下拉选择框使用select标签,多选使用multiple="multiple"属性, size为默认显示几条选项-->
            <select name="city" multiple="multiple" size="4">
                <!--选项使用option标签,提交选项的value的值-->
                <option value="BeiJing">北京</option>
                <!--默认选中,使用selected="selected"属性-->
                <option value="ShangHai" selected="selected">上海</option>
                <option value="GuangZhou">广州</option>
                <option value="ShenZhen">深圳</option>
            </select>
            <br />
            <span>城市(分组选):</span>
            <!--下拉选择框使用select标签,单选-->
            <select name="city">
                <!--使用optgroup标签对选项进行分组-->
                <optgroup label="中国">
                    <!--选项使用option标签,提交选项的value的值-->
                    <option value="BeiJing">北京</option>
                    <!--默认选中,使用selected="selected"属性-->
                    <option value="ShangHai" selected="selected">上海</option>
                    <option value="GuangZhou">广州</option>
                    <option value="ShenZhen">深圳</option>
                </optgroup>

                <optgroup label="美国">
                    <!--选项使用option标签,提交选项value属性的值-->
                    <option value="1">华盛顿</option>
                    <!--默认选中,使用selected="selected"属性-->
                    <option value="2" selected="selected">纽约</option>
                    <option value="3">洛杉矶</option>
                </optgroup>
            </select>
        </div>

        <p>
            <!--多行文本输入,使用textarea标签-->
            <textarea name="docs">默认值</textarea>
            <input type="submit" />
        </p>
    </form>


</div>

</body>
</html>

四、a标签的用途

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <!--a标签做超链接,target="_blank",用一个新标签页打开超链接内容-->
    <a href="https://www.baidu.com" target="_blank">百度</a>
    <br />

    <div>
        <!--a标签做锚,href="#目标标签的ID值"-->
        <a href="#1">第一节</a>
        <a href="#2">第二节</a>
        <a href="#3">第三节</a>
        <a href="#4">第四节</a>
    </div>

    <div>
        <!--在一个HTML文档中,标签的id值不能相同-->
        <div id="1" style="height: 800px;">第一节的内容</div>
        <div id="2" style="height: 800px;">第二节的内容</div>
        <div id="3" style="height: 800px;">第三节的内容</div>
        <div id="4" style="height: 800px;">第四节的内容</div>
    </div>
</body>
</html>

 body标签内的图片标签和列表标签

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>

<body>
<!--将图标标签包裹在a标签之内,当用户点击图片时跳转到指定链接-->
<a href="https://www.baidu.com">
    <!--img是图片标签,属性src是图片的位置,属性title的值在鼠标指针悬停在图片上时显示,当图片未加载成功显示alt的值-->
    <img src="image/1.png" title="山" alt="风景" style="height: 200px"/>
</a>

<!--列表标签由三种,ul,ol,dl-->
<ul>
    <li>ul列表标签的样式</li>
    <li>ul列表标签的样式</li>
    <li>ul列表标签的样式</li>
</ul>

<ol>
    <li>ol列表标签的样式</li>
    <li>ol列表标签的样式</li>
    <li>ol列表标签的样式</li>
</ol>

<dl>
    <dt>dl列表标签的样式</dt>
    <dd>hello world</dd>
    <dd>hello world</dd>
    <dd>hello world</dd>
    <dt>ol列表标签的样式</dt>
    <dd>hello world</dd>
    <dd>hello world</dd>
    <dd>hello world</dd>
</dl>
</body>
</html> 

  上面三种列表的样式如下图:

                                                                                

 

body标签内的表格标签:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>

<body>
<!--table标签是表格标签,border="1"是显示表格边框,不写则不显示-->
<table border="1">
    <!--thead标签,表示表头-->
    <thead>
    <!--在table标签内,tr标签表示一行-->
    <tr>
        <!--在thead标签内,th标签表示一列-->
        <th>表头1</th>
        <th>表头2</th>
        <th>表头3</th>
        <th>表头4</th>
    </tr>
    </thead>
    
    <!--tbody标签表示表格的数据部分-->
    <tbody>
    <tr>
        <!--在tbody标签内,td表示一列-->
        <td >1行,1列</td>
        <!--属性rowspan="2",表示此单元格竖向占两个单元格,即将1行2列和2行2列合并,此属性常用来单元格合并-->
        <td rowspan="2">1行,2列</td>
        <!--属性colspan="2",表示此单元格横向占两个单元格,即将1行3列和1行4列合并,此属性常用来单元格合并-->
        <td colspan="2">1行,3列</td>
        <!--由于1行,3列单元格合并需要,所以需删掉此单元格-->
        <!--<td>1行,4列</td>-->
    </tr>

    <tr>
        <td>2行,1列</td>
        <!--由于1行,2列单元格合并需要,所以需删掉此单元格-->
        <!--<td>2行,2列</td>-->
        <td>2行,3列</td>
        <td>2行,4列</td>
    </tr>

    <tr>
        <td>3行,1列</td>
        <td>3行,2列</td>
        <td colspan="2" rowspan="2">3行,3列</td>
        <!--<td>3行,4列</td>-->
    </tr>

    <tr>
        <td>4行,1列</td>
        <td>4行,2列</td>
        <!--<td>4行,3列</td>-->
        <!--<td>4行,4列</td>-->
    </tr>
    </tbody>
</table>
</body>
</html>

  上面的表格标签形成如下图所示的表格:

label标签与fieldset标签:

  label标签常用来与input标签做关联,当用户点击label标签包裹的内容时,光标将出现在与其关联的输入框内。fieldset标签常与legend标签搭配使用形成如下图所示的边框。

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6 </head>
 7 <body>
 8 
 9 <fieldset>
10     <legend>登录界面</legend>
11     <div>
12         <label for="i1">*账号:</label>
13         <input id="i1" type="text" name="username"/>
14     </div>
15     <div>
16         <label for="i2">*密码:</label>
17         <input id="i2" type="password" name="username"/>
18     </div>
19     <input type="submit" value="登录">
20 </fieldset>
21 </body>
22 </html>
label标签与fieldset标签的使用

 

二、CSS的基本使用

   CSS是用来装饰HTML标签的,比如设置标签的宽度,高度,背景色,字体的颜色,大小等。只有熟练的使用HTML和CSS才能做出漂亮的网页。

例一、给标签设置背景色,高度和宽度

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <div style="background-color: red; width: 60%; height: 45px">hello world!</div>
</body>
</html>

在标签的style属性中进行样式设置:
    background-color: red;        ---     设置标签背景色为红色
    width: 60%;                       ---     设置标签宽度为浏览器显示宽度的60%
    height: 45px                      ---     设置标签高度为45像素

  注1:高度,宽度的设置单位可以是px, %, cm等。

  注2:关于颜色得设置,可以直接写先颜色的名称,也可以写每种颜色所对应的编码(可通过RGB颜色查询对照表查询)。

例二、设置标签中文字的颜色,大小,宽度,边框

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <div style="color: blue; font-size: 20px; font-weight: bolder; border: 1px solid red">hello world!</div>
</body>
</html>


color: blue;     ---   设置字体颜色
font-size: 20px; ---   设置字体大小 
font-weight: bolder  --- 加宽字体
border: 1px solid red;  ---  设置边框, 宽度为1px,虚线,红色

   注:所有颜色的设置都可以使用RGB颜色查询对照表中的颜色和编码。

例三、设置文字在标签中的位置(比如,让文字在标签所占区域中居中)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <div style="background-color: red; height: 35px; text-align: center; line-height: 35px;">hello world!</div>
</body>
</html>

text-align: center;    --- 设置水平居中
line-height: 35px;     --- 设置垂直居中, 这里的数值等于标签高度的数值

 

  在标签的style属性中固然可以设置样式,但是如果多个标签要用同一个样式,那就得多次重复相同的代码,所以可以使用选择器来设置样式。

例四、选择器

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7         /* 以.开头为类选择器 */
 8         .c1{
 9             background-color: red;
10             width: 60%;
11             height: 45px;
12             color: blue;
13             font-size: 20px;
14             font-weight: bolder;
15             text-align: center;
16             line-height: 45px;
17         }
18     </style>
19 </head>
20 <body>
21     <!--使用类选择器,只需使标签的class属性的值为类名即可,下面的p标签就使用了c1中的样式-->
22     <p class="c1">hello world!</p>
23 </body>
24 </html>
类选择器
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7         /* 标签选择器,为此HTML中的每一个div标签设置此样式 */
 8         div{
 9             background-color: red;
10             width: 60%;
11             height: 45px;
12             color: blue;
13             font-size: 20px;
14             font-weight: bolder;
15             text-align: center;
16             line-height: 45px;
17         }
18     </style>
19 </head>
20 <body>
21     <div>hello world</div>
22     <span>1234</span>
23     <div>asdf</div>
24 </body>
25 </html>
标签选择器
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7         /* 属性选择器,对具有特定属性(可以是自定义的属性)的特定标签设置样式,下面的样式只给具有type="text"属性的input标签设置 */
 8         input[type="text"]{
 9             background-color: aliceblue;
10             width: 180px;
11             height: 45px;
12         }
13     </style>
14 </head>
15 <body>
16 <div>
17     <input type="text" name="user" />
18     <input type="text" name="email" />
19     <input type="password" name="pwd" />
20 </div>
21 </body>
22 </html>
属性选择器
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7         /* 关联选择器,为此HTML中的每一个被span标签包裹的div标签设置此样式 */
 8         span div{
 9             background-color: red;
10             width: 60%;
11             height: 45px;
12             color: blue;
13             font-size: 20px;
14             font-weight: bolder;
15             text-align: center;
16             line-height: 45px;
17         }
18     </style>
19 </head>
20 <body>
21     <div>asdfghjkl</div>
22     <span>12345678</span>
23     <span>
24         <div>hello world</div>
25     </span>
26 
27 </body>
28 </html>
关联选择器
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7         /* id选择器 */
 8         /* 当使用关联选择器是,标签路径太过复杂,可以使用id选择器,为某一标签设置样式*/
 9         /*给包裹hello world的div标签设置样式*/
10         #i1{
11             background-color: red;
12             width: 60%;
13             height: 45px;
14             color: blue;
15             font-size: 20px;
16             font-weight: bolder;
17             text-align: center;
18             line-height: 45px;
19         }
20     </style>
21 </head>
22 <body>
23     <div>
24         <span>
25             <p>
26                 <div>
27                     <div id="i1">hello world</div>
28                 </div>
29             </p>
30         </span>
31     </div>
32 </body>
33 </html>
id选择器
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7         /*组合选择器,为多个标签设置同一个样式*/
 8         div,p{
 9             background-color: red;
10             width: 60%;
11             height: 45px;
12             color: blue;
13             font-size: 20px;
14             font-weight: bolder;
15             text-align: center;
16             line-height: 45px;
17         }
18     </style>
19 </head>
20 <body>
21     <div>1. hello world</div>
22     <p> 2. hello world</p>
23 </body>
24 </html>
组合选择器

  注:对于关联选择器和组合选择器而言,可以使用不同类型的其他选择器构成这两种选择器。你可以使用id选择器和标签选择器构成一个关联选择器,你也可以使用类型选择器和属性选择器构成一个组合选择器,对于使用哪种选择器视情况而定即可。

例五、内联标签与块级标签的相互转换

   HTML标签的默认属性是固定的,但我们可以使用CSS修改默写默认属性,比如p标签、div标签默认是块级标签,可以将其转为内联标签,span标签默认是内联标签,可以将其转为块级标签。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <!--使用style中的display字段即可转换块级标签和内联标签-->
    <p style="display: inline; background-color: green">123</p>
    <span style="display: block; background-color: red">abc</span>
    <div style="display: inline; background-color: green">456</div>
</body>
</html>



display: none    让标签消失
        display: inline  块级标签转内联
        display: block   内联标签转块级
        display: inline-block  同时具有内联标签和块级标签的部分特性

  注:内联标签默认无法设置宽度和高度,要对其做此设置须转为块级标签。

例六、是标签浮动起来

  要实现下面的效果,需要将两个块级标签放到一行,但块级标签默认是占一行的,该如何实现呢?这就需要使用CSS的float字段了,使用float可以让标签浮动起来,从而实现多个块级标签出现在同一水平线上,实现标签堆叠。 

hello
world

 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <div style="background-color: red; width: 40%; float: left">hello</div>
    <div style="background-color: green; width: 60%; float: left">world</div>
</body>
</html>


float:
    - left标签从左开始浮动堆叠
    - right标签从右开始浮动堆叠

例七、边距

  外边距:标签外部的边距。如下图,绿色的标签据顶部红色边框25px。外边距由属性margin设置。

hello world
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6 </head>
 7 <body>
 8     <div style="height: 75px; border: 1px solid red;">
 9         <div style="height: 80px; background-color: green; margin-bottom: 10px">hello world</div>
10     </div>
11 </body>
12 </html>
13 
14 margin --- 设置上下左右四个方向的边距
15 margin-top --- 设置上方边距
16 margin-bottom --- 设置下方边距
17 margin-left --- 设置左边边距
18 margin-right --- 设置右边边距
外边距

   内边距:标签内部的边距。如下图,标签内的字距上方35px。

hello world 
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6 </head>
 7 <body>
 8     <div style="background-color: green; height: 45px;">hello world</div>
 9     <br />
10     <div style="background-color: green; height: 45px; padding-top: 35px">hello world</div>
11 </body>
12 </html>
内边距

 

例八、标签在页面布局中的位置

  有一些标签在页面中的位置是固定不变的,比如返回顶部的按钮,就一直在页面的右下角,有些网站的菜单栏,就一直在浏览器界面的正上方,无论将页面拉倒什么位置它们的位置都不会变。

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6 
 7     <style>
 8         #i1{
 9             background-color: #000000;
10             color: #ffffff;
11             display: inline-block;
12             position: fixed;            /* postion: fixed 设置标签位置固定 */
13             bottom: 1cm;                /* 距浏览器显示界面底部1cm */
14             right: 1cm;                 /* 距浏览器显示界面右边界1cm */
15         }
16         #i2{
17             height: 5000px;
18             background-color: #dddddd;
19         }
20     </style>
21 </head>
22 <body style="margin: 0 auto">
23     <div id="i1">返回顶部</div>
24     <!--检验下拉是否会改变标签位置-->
25     <div id="i2">asdf</div>
26 </body>
27 </html>
返回顶部按钮
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6 
 7     <style>
 8         #i1{
 9             background-color: black;
10             height: 60px;
11             color: white;
12             position: fixed;
13             top:0;
14             left: 0;
15             right: 0;
16         }
17         #i2{
18             background-color: #dddddd;
19             height: 5000px;
20             margin-top: 75px;
21         }
22     </style>
23 </head>
24 <body style="margin: 0 auto">
25     <div id="i1">菜单栏</div>
26     <div id="i2">内容</div>
27 </body>
28 </html>
菜单栏

   还有一些标签的位置是相对于其他标签而言的,比如下图,黑色背景标签相对于红色边框标签在它的左下角,这就是标签的相对位置。

hello
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6 </head>
 7 <body>
 8     <div style="width: 15cm; height: 8cm; border: 1px solid red; margin: 0 auto; position: relative">
 9         <div style="width: 4cm; height: 2cm; background-color: black; position: absolute; left: 0; bottom: 0">hello</div>
10     </div>
11     <div style="width: 500px; height: 280px; border: 1px solid red; margin: 0 auto; position: relative">
12         <div style="width: 4cm; height: 2cm; background-color: black; position: absolute; right: 0; bottom: 0"></div>
13     </div>
14     <div style="width: 500px; height: 280px; border: 1px solid red; margin: 0 auto; position: relative">
15         <div style="width: 4cm; height: 2cm; background-color: black; position: absolute; left: 0; top: 0"></div>
16     </div>
17 </body>
18 </html>
标签的相对位置

 

   注1:postion设置为fixed时,设置标签的固定位置。

   注1:只有当外层标签的postion设置为relative,内层标签的postion设置为absolute才能设置标签的相对位置。

   注2:使用top bottom right left这四个参数设置标签的位置。

例九、页面内容分层

   我们常常在访问一个网页时会出现这样一种情景,点击某个按钮,标签弹出一个输入框,这时在这个输入框下的内容边不能再被选中,这其实是将整个页面分为三层,最底层为刚开始的内容,当点击按钮是显示第二层和第三层。当使用position设置标签位置时,标签其实已经不在同一层,在实际运用中我们还要设置层级顺序,透明度(常用在覆盖内容层)等。

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6 
 7     <style>
 8         #i1{
 9             height: 5000px;
10             background-color: green;
11         }
12 
13         #i2{
14             background-color: black;
15             z-index: 9;     /*设置层级顺序,数字越大,越在上层*/
16             opacity: 0.7;   /*设置透明度,从0~1,0为完全透明,1为完全不透明*/
17             position: fixed;
18             /*覆盖整个页面*/
19             top: 0;
20             bottom: 0;
21             left: 0;
22             right: 0;
23         }
24 
25         #i3{
26             width: 150mm;
27             height: 80mm;
28             background-color: white;
29             z-index: 10;
30             position: fixed;
31             top: 15%;
32             left: 50%;
33             margin-left: -75mm;
34         }
35     </style>
36 </head>
37 <body>
38     <!--最上层,可输入-->
39     <div id="i3">   
40         <input type="text" name="user" />
41         <br />
42         <input type="password" name="pwd" />
43         <br />
44         <input type="submit" value="登录" />
45     </div>
46     <!--第二层,用以覆盖最底层-->
47     <div id="i2"></div>
48     <!--最底层-->
49     <div id="i1">hello world</div>
50 </body>
51 </html>
一个三层内容的页面

例十、img在标签内的限制

  在上面的的HTML标签使用介绍中我们了解了img标签(图片标签的使用),它常常被其他标签所包裹,但是在CSS中我们学会了设置标签的大小,如果图片的大小超过了它外层标签的大小(比如外层标签的大小是800×400而它包裹的图片是)会怎样呢? 此时图片便会超出外层标签的限制,换而言之图片会完全覆盖掉外层标签,此时就需要在外层标签对内层做出限制,使用CSS的overflow字段。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <div style="width: 15cm; height: 8cm; overflow: auto">
        <img src="image/1.png">
    </div>
    
    <div style="width: 15cm; height: 8cm; overflow: hidden">
        <img src="image/1.png">
    </div>
</body>
</html>

overflow: auto   -----  从图片的左上角开始显示符合范围的大小,可拉动滚动条查看其余部分
overflow: hidden   -----  从图片的左上角开始显示符合范围的大小,其余部分将被隐藏

例十一、鼠标指针移到某个标签改变其样式

   在我们访问网站时,当鼠标移到菜单栏上的某个选项时,其样式会改变,如下图,这是某购物网站的菜单栏,当指针移到腕表这一选项时,此选项的背景色,字体色都发生了改变,这种效果是如何实现的呢?

 

 

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7         .c1{
 8             height: 48px;
 9             background-color: #2459a2;
10             line-height: 48px;
11             position: fixed;
12             right: 0;
13             left: 0;
14             top: 0;
15         }
16         .c2{
17             margin-top: 50px;
18         }
19         .w{
20             width: 980px;
21             margin: auto;
22         }
23         .c1 .menu{
24             display: inline-block;
25             margin: 0 100px;
26             color: white;
27         }
28         .c1 .menu:hover{
29             background-color: blue;
30         }
31     </style>
32 </head>
33 <body>
34     <div class="c1">
35         <div class="w">
36             <a class="logo">LOGO</a>
37             <a class="menu">选项一</a>
38             <a class="menu">选项二</a>
39             <a class="menu">选项三</a>
40         </div>
41     </div>
42     <div class="c2">
43         <div class="w">a</div>
44     </div>
45 </body>
46 </html>
47 
48 
49 /* 使用类似下面这种格式的选择器,为标签设置的样式,当指针移到这个标签时此样式才会生效*/
50 .c1 .menu:hover{
51     background-color: blue;
52 }
被鼠标指针指到样式生效

例十二、背景图片

  在之前的样式里,介绍了标签背景色的使用,在此例中,将结束标签背景图片的设置,如下两图就是背景图片的使用:

标签的背景图片是标签占多大背景图片占多大,当图片大小超过标签大小时会按标签大小从左上角开始切割图片,当图片大小小于标签大小时,图片重复显示。

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7         .c1{
 8             width: 100px;
 9             height: 100px;
10             background-image: url(image/1.png);
11             background-repeat: no-repeat;
12         }
13     </style>
14 </head>
15 <body>
16     <div class="c1" style="background-position: 0 0;">hello</div>
17     <br />
18     <div class="c1" style="background-position: 0 -140px;">world</div>
19 </body>
20 </html>
21 
22 
23 背景图片:
24         background-image:url()   ---  默认div大,图片重复放,url括号内写图片地址
25         当标签大小大于图片大小时:重复, 水平方向重复,垂直方向重复,不重复
26         background-repeat: repeat,repeat-x, repeat-y, no-repeat  
27         
28         以左上角顶点做参考
29         background-position-x   向水平方向移动图片  负数向左移  整数向右移
30         background-position-y   向垂直方向移动图片  负数向上移  正数向下移
31     
32 可简写为 background: url(image/1.png) no-repeat 0 -140px;
背景图片

 

目录
相关文章
|
29天前
|
前端开发 测试技术 定位技术
如何利用HTML和CSS构建企业级网站的全过程。从项目概述到页面结构设计,再到HTML结构搭建与CSS样式设计,最后实现具体页面并进行优化提升,全面覆盖了网站开发的关键步骤
本文深入介绍了如何利用HTML和CSS构建企业级网站的全过程。从项目概述到页面结构设计,再到HTML结构搭建与CSS样式设计,最后实现具体页面并进行优化提升,全面覆盖了网站开发的关键步骤。通过实例展示了主页、关于我们、产品展示、新闻动态及联系我们等页面的设计与实现,强调了合理布局、美观设计及用户体验的重要性。旨在为企业打造一个既专业又具吸引力的线上平台。
58 7
|
29天前
|
前端开发 JavaScript 搜索推荐
HTML与CSS在Web组件化中的核心作用及前端技术趋势
本文探讨了HTML与CSS在Web组件化中的核心作用及前端技术趋势。从结构定义、语义化到样式封装与布局控制,两者不仅提升了代码复用率和可维护性,还通过响应式设计、动态样式等技术增强了用户体验。面对兼容性、代码复杂度等挑战,文章提出了相应的解决策略,强调了持续创新的重要性,旨在构建高效、灵活的Web应用。
37 6
|
1月前
|
移动开发 前端开发 JavaScript
[HTML、CSS]细节与使用经验
本文总结了前端开发中的一些重要细节和技巧,包括CSS选择器、定位、层级、全局属性、滚轮控制、轮播等。作者以纯文字形式记录,便于读者使用<kbd>Ctrl + F</kbd>快速查找相关内容。文章还提供了示例代码,帮助读者更好地理解和应用这些知识点。
48 1
|
29天前
|
存储 移动开发 前端开发
高效的 HTML 与 CSS 编写技巧,涵盖语义化标签、文档结构优化、CSS 预处理、模块化设计、选择器优化、CSS 变量、媒体查询等内容
本文深入探讨了高效的 HTML 与 CSS 编写技巧,涵盖语义化标签、文档结构优化、CSS 预处理、模块化设计、选择器优化、CSS 变量、媒体查询等内容,旨在提升开发效率、网站性能和用户体验。
42 5
|
29天前
|
前端开发 JavaScript UED
在数字化时代,Web 应用性能优化尤为重要。本文探讨了CSS与HTML在提升Web性能中的关键作用及未来趋势
在数字化时代,Web 应用性能优化尤为重要。本文探讨了CSS与HTML在提升Web性能中的关键作用及未来趋势,包括样式表优化、DOM操作减少、图像优化等技术,并分析了电商网站的具体案例,强调了技术演进对Web性能的深远影响。
35 5
|
1月前
|
移动开发 前端开发 JavaScript
[HTML、CSS]知识点
本文涵盖前端知识点扩展、HTML标签(如video、input、canvas)、datalist和details标签的使用方法,以及CSS布局技巧(如margin、overflow: hidden和动态height)。文章旨在分享作者的学习经验和实用技巧。
35 1
[HTML、CSS]知识点
|
2月前
|
前端开发 JavaScript 搜索推荐
打造个人博客网站:从零开始的HTML和CSS之旅
【9月更文挑战第32天】在这个数字化的时代,拥有一个个人博客不仅是展示自我的平台,也是技术交流的桥梁。本文将引导初学者理解并实现一个简单的个人博客网站的搭建,涵盖HTML的基础结构、CSS样式的美化技巧以及如何将两者结合来制作一个完整的网页。通过这篇文章,你将学会如何从零开始构建自己的网络空间,并在互联网世界留下你的足迹。
|
1月前
|
移动开发 JavaScript 前端开发
html table+css实现可编辑表格的示例代码
html table+css实现可编辑表格的示例代码
63 12
|
1月前
|
前端开发 JavaScript
用HTML CSS JS打造企业级官网 —— 源码直接可用
必看!用HTML+CSS+JS打造企业级官网-源码直接可用,文章代码仅用于学习,禁止用于商业
143 1