html
叫做超本文标记语言,注意它只是标记语言,不是编程语言。
编写规范:
-
由标记(html, div, p, h1等)组成
-
标记成对出现(<html>...</html>),也有例外,比如<img src=""/>、<br/>
- 标记有层级关系
<html>
? ?<head>
? ?</head>
? ?<body>
? ?</body><html>
- 标记有内容文本或属性
<title>这是一个标签</title><meta name="" content=""></meta>
注意:
-
html不区分大小写
- 建议大家用双引号
当然单引号也可以,但是双引号才是professional的表现
html基本结构
<!DOCTYPE html><html lang="en"> ? ?<head>
? ? ? ?<meta charset="UTF-8">
? ? ? ?<title>Title</title> ? ?</head> ? ?<body> ? ?</body></html>
-
doctype:必须这样写
-
html:其实不写也可以,为了规范,还是写上吧
-
head:用来设置网页的信息,比如标题、小图标等
- body:网页内容(可视化标签)
特殊符号
- 空格: 【分号是必须写的】
注意,空格这里写一个 表示添加了一个空格,写多个也只会有一个空格
好,现在我们新建一个名为index.html
的文件,你可以在桌面建一个txt文件,然后修改扩展名为HTML,然后打开方式选择sublime,或者其他编辑器。船长这里是建了一个flask项目,然后在templates
文件夹下新建了一个。这里提醒大家的是,以后大家能用英文的地方尽量用英文,比如文件夹名、文件名等,不然会有各种问题等着你。
用pycharm这种IDE的话发现它会帮你写好模板,这里建议大家清空然后自己写一遍加深印象:
<!DOCTYPE html><html>
? ?<head>
? ? ? ?<title>第一节课</title>
? ? ? ?<meta charset="UTF-8"/>
? ?</head>
? ?<body>
? ? ? ?Hello World! ? ?</body></html>
写了Hello World!
你就开始了HTML学习啦~
先和大家说一下什么是可视化标签
,一句话:可以在<body>
中看到的标签就是可视化标签,比如<p>、<body>、<div>等
这些都是可以看到的,所以是可视化标签;而<style>、<meta>等
在<body>
中不能看到的标签,就是非可视化标签
。注意:只有可视化标签,才能用css改变它的样式。
常用的可视化标签
这里只说几个有代表性的,其实所有标签都差不多,就像钢笔和铅笔一样,都是写字用的,只是作用不一样。
- div
<!DOCTYPE html>
<html>
? ?<head>
? ? ? ?<title>第一节课</title>
? ? ? ?<meta charset="UTF-8"/>
? ? ? ?<style>
? ? ? ? ? ?div{
? ? ? ? ? ? ? ?border:1px solid green;
? ? ? ? ? ?}
? ? ? ? ? ?span{
? ? ? ? ? ? ? ?border:1px solid red;
? ? ? ? ? ?}
? ? ? ?</style>
? ?</head>
? ?<body>
? ? ? ?<div>This is a div</div>
? ? ? ?<span>This is a span</span>
? ?</body>
</html>
上面代码页面没讲的内容大家不要急,后面会讲。显示:
发现上面那个框比较长,下面的和文字长度一样,这是因为有一个display
属性,div标签display默认值是block
,span标签display默认值是inline
,所以如果我把span标签的display
值改为block
,那么两个显示就会相同了:
<!DOCTYPE html><html>
? ?<head>
? ? ? ?<title>第一节课</title>
? ? ? ?<meta charset="UTF-8"/>
? ? ? ?<style>
? ? ? ? ? ?div{ ? ? ? ? ? ? ? ?border:1px solid green; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?display: block; ? ? ? ? ? ? ? ? ? ? ? ?}
? ? ? ? ? ?span{ ? ? ? ? ? ? ? ?border:1px solid red; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?display: block; ? ? ? ? ? ? ? ? ? ? ? ?}
? ? ? ?</style>
? ?</head>
? ?<body>
? ? ? ?<div>This is a div</div>
? ? ? ?<span>This is a span</span>
? ?</body></html>
显示:
(代码里style标签里的内容就是css修改可视化标签的方式。)
我们再加一个p标签:
<!DOCTYPE html><html>
? ?<head>
? ? ? ?<title>第一节课</title>
? ? ? ?<meta charset="UTF-8"/>
? ? ? ?<style>
? ? ? ? ? ?div{ ? ? ? ? ? ? ? ?border:1px solid green; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?display: block; ? ? ? ? ? ? ? ? ? ? ? ?}
? ? ? ? ? ?span{ ? ? ? ? ? ? ? ?border:1px solid red; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?display: block; ? ? ? ? ? ? ? ? ? ? ? ?}
? ? ? ? ? ?p{ ? ? ? ? ? ? ? ?border: 1px solid palevioletred; ? ? ? ? ? ? ? ? ? ? ? ?}
? ? ? ?</style>
? ?</head>
? ?<body>
? ? ? ?<div>This is a div</div>
? ? ? ?<span>This is a span</span>
? ? ? ?<p>This is a p</p>
? ?</body></html>
发现p标签和上面的内容空了一行,这是因为p标签的margin属性默认值不是0,所以如果想去掉空行,只需要在style
中修改p标签margin
值为0:
<!DOCTYPE html><html>
? ?<head>
? ? ? ?<title>第一节课</title>
? ? ? ?<meta charset="UTF-8"/>
? ? ? ?<style>
? ? ? ? ? ?div{ ? ? ? ? ? ? ? ?border:1px solid green; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?display: block; ? ? ? ? ? ? ? ? ? ? ? ?}
? ? ? ? ? ?span{ ? ? ? ? ? ? ? ?border:1px solid red; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?display: block; ? ? ? ? ? ? ? ? ? ? ? ?}
? ? ? ? ? ?p{ ? ? ? ? ? ? ? ?border: 1px solid palevioletred; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?margin: 0px; ? ? ? ? ? ? ? ? ? ? ? ?}
? ? ? ?</style>
? ?</head>
? ?<body>
? ? ? ?<div>This is a div</div>
? ? ? ?<span>This is a span</span>
? ? ? ?<p>This is a p</p>
? ?</body></html>
看到页面样式变成了这样:
- a标签
a
标签因为有一个href
属性,才变成了一个超链接,而div
标签就没有href
属性,以后我们遇到**页面跳转或表单提交的的文字,都用a标签
**:
<!DOCTYPE html><html>
? ?<head>
? ? ? ?<title>第一节课</title>
? ? ? ?<meta charset="UTF-8"/>
? ? ? ?<style>
? ? ? ? ? ?div{ ? ? ? ? ? ? ? ?border:1px solid green; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?display: block; ? ? ? ? ? ? ? ? ? ? ? ?}
? ? ? ? ? ?span{ ? ? ? ? ? ? ? ?border:1px solid red; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?display: block; ? ? ? ? ? ? ? ? ? ? ? ?}
? ? ? ? ? ?p{ ? ? ? ? ? ? ? ?border: 1px solid palevioletred; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?margin: 0px; ? ? ? ? ? ? ? ? ? ? ? ?}
? ? ? ?</style>
? ?</head>
? ?<body>
? ? ? ?<div>This is a div</div>
? ? ? ?<span>This is a span</span>
? ? ? ?<p>This is a p</p>
? ? ? ?<a href="https://www.baidu.com">百度</a>
? ?</body></html>
这里要注意的是,href
属性的地址写的时候必须加协议,就是http
或https
或file
等,如果不加就会页面跳转错误。
此外,大家看到这样写页面是在当前页面进行,跳转,很多时候页面跳转需要新开标签页,那么我们就要给a
标签增加一个target
属性,值为_blank
:
<a href="https://www.baidu.com" target="_blank">百度</a>
这个target
默认值为_self
。
- img标签
我们先看一下文档结构:
这里我们文件当前位置就是lesson.html
,所以现在我们img
属性src
给的值要进入imgs
文件夹,所以我们可以用相对路径
来表示,看代码:
<!DOCTYPE html><html>
? ?<head>
? ? ? ?<title>第一节课</title>
? ? ? ?<meta charset="UTF-8"/>
? ?</head>
? ?<body>
? ? ? ?<a href="https://www.baidu.com" target="_blank">百度</a>
? ? ? ?<img src="imgs/0.png">
? ?</body></html>
上面src
后面跟的就是相对路径。
页面显示:
src
除了用来设置图片路径以外,还用来设置alt
属性,alt
属性是用来给搜索引擎用的,以便你写的页面可以被搜索引擎搜索到。此外它还有width
和height
属性,比如刚才的图片比较大,我们现在修改图片的大小,只需要:
<img src="imgs/0.png" width="5%" height="5%">
如果你希望自己的图片是网络上的图片,那只需要粘贴你希望放上去的图片地址,比如,放百度的背景,那么只需要看一下百度的地址:
然后复制这个地址,粘贴到你的src
路径里:
<img src="https://www.baidu.com/img/bd_logo1.png" width="50%" height="50%">
但是要注意,如果图片写的是网络上的图片,要必须确定有网,不然图片是不显示的。
- ul li标签
这两个标签是列表
。
<!DOCTYPE html><html>
? ?<head>
? ? ? ?<title>第一节课</title>
? ? ? ?<meta charset="UTF-8"/>
? ?</head>
? ?<body>
? ? ? ?<a href="https://www.baidu.com" target="_blank">百度</a>
? ? ? ?<img src="https://www.baidu.com/img/bd_logo1.png" width="10%" height="10%">
? ? ? ?<ul>
? ? ? ? ? ?<li>第一行</li>
? ? ? ? ? ?<li>第二行</li>
? ? ? ? ? ?<li>第三行</li>
? ? ? ?</ul>
? ?</body></html>
显示:
你可能会说除了ul li
还有ol li
,不用管那么多,记住这个就够了。
记住,只要页面中有固定样式的列表,那就用ul li
,比如:
不信大家就去天猫看一下。
- table
表格。之前说过了,以今天的为准。tr
代表行,td
代表列。
<table>
? ?<tr>
? ? ? ?<td>第1行1列</td>
? ? ? ?<td>第1行2列</td>
? ?</tr>
? ?<tr>
? ? ? ?<td>第2行1列</td>
? ? ? ?<td>第2行2列</td>
? ?</tr></table>
显示:
如果想显示边框,可以加个border
属性:
<table border="1">...</table>
还要知道,table
已经用的很少了,因为存在浏览器的兼容性,很多时候都被ul li
代替了。大家会想到上次还说的tbody
现在却没有写,其实即使我们不写浏览器也会帮我们加上:
上图中的tbody
就是浏览器默认给我们加上的。此外,如果是表的第一行,需要加粗显示的话,可以将tr
改为th
:
<table border="1">
? ?<tr>
? ? ? ?<th>第1行1列</th>
? ? ? ?<th>第1行2列</th>
? ?</tr>
? ?<tr>
? ? ? ?<td>第2行1列</td>
? ? ? ?<td>第2行2列</td>
? ?</tr></table>
th
用来做表头,默认字体居中显示。
还有caption
作为表格的标题:
<table border="1">
? ?<caption>表格标题</caption>
? ?<tr>
? ? ? ?<th>第1行1列</th>
? ? ? ?<th>第1行2列</th>
? ?</tr>
? ?<tr>
? ? ? ?<td>第2行1列</td>
? ? ? ?<td>第2行2列</td>
? ?</tr></table>
tbody
和caption
等这些都不用记。
合并表格:
<table border="1">
? ?<caption>表格标题</caption>
? ?<tr>
? ? ? ?<th>第1行1列</th>
? ? ? ?<th>第1行2列</th>
? ? ? ?<th>分数</th>
? ?</tr>
? ?<tr>
? ? ? ?<td>第2行1列</td>
? ? ? ?<td>第2行2列</td>
? ? ? ?<td>10</td>
? ?</tr>
? ?<tr>
? ? ? ?<td colspan="2">总成绩</td> ? ? ? ? ? ? ? ? ? ? ? ?
? ? ? ?<td>20</td>
? ?</tr></table>
我们给td
标签加了colspan="2"
,就可以合并两行了:
最后给大家看一个例子,图片来自https://nba.hupu.com/teams:
<!DOCTYPE html><html>
? ?<head>
? ? ? ?<title>第一节课</title>
? ? ? ?<meta charset="UTF-8"/>
? ?</head>
? ?<body>
? ? ? ?<a href="https://www.baidu.com" target="_blank">百度</a>
? ? ? ?<img src="https://www.baidu.com/img/bd_logo1.png" width="10%" height="10%">
? ? ? ?<ul>
? ? ? ? ? ?<li>第一行</li>
? ? ? ? ? ?<li>第二行</li>
? ? ? ? ? ?<li>第三行</li>
? ? ? ?</ul>
? ? ? ?<table border="1">
? ? ? ? ? ?<caption>表格标题</caption>
? ? ? ? ? ?<tr>
? ? ? ? ? ? ? ?<th>第1行1列</th>
? ? ? ? ? ? ? ?<th>第1行2列</th>
? ? ? ? ? ? ? ?<th>分数</th>
? ? ? ? ? ? ? ?<th>一整行</th>
? ? ? ? ? ?</tr>
? ? ? ? ? ?<tr>
? ? ? ? ? ? ? ?<td><img src="imgs/0.png"></td>
? ? ? ? ? ? ? ?<td><img src="imgs/1.png"></td>
? ? ? ? ? ? ? ?<td><img src="imgs/2.png"></td>
? ? ? ? ? ? ? ?<td rowspan="3"><img src="imgs/logo.png"></td>
? ? ? ? ? ?</tr>
? ? ? ? ? ?<tr>
? ? ? ? ? ? ? ?<td><img src="imgs/3.png"></td>
? ? ? ? ? ? ? ?<td><img src="imgs/4.png"></td>
? ? ? ? ? ? ? ?<td><img src="imgs/5.png"></td>
? ? ? ? ? ?</tr>
? ? ? ? ? ?<tr>
? ? ? ? ? ? ? ?<td><img src="imgs/6.png"></td>
? ? ? ? ? ? ? ?<td><img src="imgs/7.png"></td>
? ? ? ? ? ? ? ?<td><img src="imgs/8.png"></td>
? ? ? ? ? ?</tr>
? ? ? ?</table>
? ?</body></html>
如果对软件测试、接口测试、自动化测试、面试经验交流。感兴趣可以加软件测试交流:1085991341,还会有同行一起技术交流。
显示:
写会了上面这个例子,table
这里就没什么问题了。
大家想学就得加把劲,自己不努力谁也教不会。
以上内容希望对你有帮助,有被帮助到的朋友欢迎点赞,评论。