走进前端之『HTML』篇
前端认知
前后端概念
前端开发
英文: WEB Front-end Development
后端开发
英文:WEB Back-end Development
前后端区别
后端即为服务器程序的开发
- 对数据库数据进行操作
- 逻辑处理
- 前端需要的接口
前端即为界面的开发包括结构样式和逻辑
- 结构 -> 盖房子 -> 搭建结构 -> 网页结构的布局 -> HTML
- 样式 -> 装修房子 -> 结构的布局与装修 -> CSS
- 逻辑 -> 房子内的东西可以动起来 -> 网页动态交互 -> JavaScript
前端的HTML&CSS&JavaScript:
- HTML负责网页结构搭建
- CSS负责网页样式呈现
- JavaScript负责网页动态行为交互
文件后缀:
.js-> JavaScript代码.css-> css代码.html/.htm-> html代码
VsCode编辑器快捷键
ctrl + s保存文件ctrl + z撤回ctrl + x剪切ctrl + c复制ctrl + v粘贴ctrl + a全选
HTML基础
超文本标记语言(HyperText Markup Language),不是编程语言(没有逻辑的语言)
word -> 文章 -> 文本
搜素引擎
搜素引擎认知的优先级:
title > description > keywords
网页设计概念:
- 物理性标签
- 语义性标签:每个标签是一个单词的缩写 (
<em>即emphasize), 迎合搜素引擎爬虫程序
标签
单双标签 -> <h1></h1> & <br/>
标签属性 -> 对一个当前标签的一种设置 -> 图片地址 src=""
标题标签
<h1></h1>, <h2></h2>, <h3></h3>, <h4></h4>, <h5></h5>, <h6></h6>
特性:
- 独占一行
- 粗体
- h1 = 2em
- h2 = 1.5em
- h3 = 1.17em
- h4 = 0em
- h5 = 0.83em
- h6 = 0.67em
浏览器默认文字大小为16px -> 2em -> 16px * 2 = 32px
段落标签
<p></p>
特性:
- 独占一行
- margin = 16px
缩进2字符
style="text-indent: 2em"
语义化标签
<strong></strong>
<em></em>加强语气
<del></del>删除标签
<ins></ins>下划线
<address></address>斜体的地址
物理性标签
<b></b>
<i></i>斜体标签 开发时用于添加图标
盒子标签
<div></div>
容器标签
division标签 布局用具有宽高的块状元素标签
锚点标签
<a></a>
href="" : hypertext reference 超文本引用
a标签的作用:
- 超链接标签
- 打电话
- 发邮件
- 锚点定位
- 协议限定符
<a href="https://www.baidu.com"></a><a href="tel:13700000000">联系我</a><a href="mailto:abc@abc.com">邮件我</a><a href="javascript:alert('我是a标签')">邮件我</a>
范围标签
<span></span>
特性:
- 低调不显摆
- 默认没有样式
作用:
- 在一个文本之内区分与其他文本的样式差别,给一段文本的中间某一段文字或某一个文字或某一个区的文字加上不同的样式来区分于其他文本的区别
- 文本中无法单独获取的东西,利用span标签就可以获取
<p>我是一个非常非常<span style="color: red;" id="niu">牛</span><span style="color: blue;">X</span>的前端工程师</p>
var niu = document.getElementById('niu');console.log(niu.innerText); // 牛
显示效果:

序列标签
ol有序列表标签 or ul无需列表标签 or dl定义列表
关于有序列表 order list
- 当字母超过26位,会aa显示,依次类推
- 除了数字,其他不能中途开始
reversed="reversed"属性为倒序,如果倒序的数字小于实际数字,会以负数显示
//阿拉伯数字<ol type="1"><li>HTML</li><li>CSS</li><li>JavaScript</li><li>PHP</li><li>GO</li></ol>1.HTML2.CSS3.JavaScript4.PHP5.GO
//大写字母<ol type="A"><li>HTML</li><li>CSS</li><li>JavaScript</li><li>PHP</li><li>GO</li></ol>A.HTMLB.CSSC.JavaScriptD.PHPE.GO
//小写字母<ol type="a"><li>HTML</li><li>CSS</li><li>JavaScript</li><li>PHP</li><li>GO</li></ol>a.HTMLb.CSSc.JavaScriptd.PHPe.GO
//罗马数字<ol type="i"><li>HTML</li><li>CSS</li><li>JavaScript</li><li>PHP</li><li>GO</li></ol>i.HTMLii.CSSiii.JavaScriptiv.PHPv.GO
//除了数字,其他不能中途开始<ol type="1" start="10"><li>HTML</li><li>CSS</li><li>JavaScript</li><li>PHP</li><li>GO</li></ol>10.HTML11.CSS12.JavaScript13.PHP14.GO
//如果倒序的数字小于实际数字,会以负数显示<ol type="1" start="5" reversed="reversed"><li>HTML</li><li>CSS</li><li>JavaScript</li><li>PHP</li><li>GO</li><li>GO</li><li>GO</li><li>GO</li></ol>5.HTML4.CSS3.JavaScript2.PHP1.GO0.GO-1.GO-2.GO
关于无序列表 unorder list
- 横排或竖排排列的块级布局
//disc默认为圆点//square 为小方块//circle 为空心圆<ul type="disc"><li>HTML</li><li>CSS</li><li>JavaScript</li><li>PHP</li><li>GO</li></ul>
关于定义列表 definition list
//dl definition list//dt definition term//definition description<dl type="disc"><dt></dt><dd>我要成为WEB开发工程师</dd><dd>我正在学习前端开发</dd></dl>
下拉菜单标签
适用于手机端
<select name="" id=""><option value="">111</option><option value="">222</option><option value="">333</option></select>
表格标签
标题标签caption
作用:用来布局的
<!-- 标题标签caption --><!-- tr table row 表格行标签 包裹--><!-- th table header cell 表头标签 --><!-- td table deta cell 单元格标签 --><!-- border 边距 --><!-- cellpadding 单元格内边距 --><!-- cellspacing 单元格间距 --><!-- colspan 列合并 --><!-- rowspan 行合并 向下合并 --><!-- align="left|center|right" 居左居中居右 --><table border="1" cellpadding="10" cellspacing="10"><caption>VIP班级学生联络表</caption><!-- 页眉 --><tr><th>ID</th><th>姓名</th><th>电话</th><th>备注</th></tr><tr><td align="center">1</td><td align="center">东东</td><td align="center">13922222222</td><td align="center">班长</td></tr><tr><td>信息</td><td>3班</td><td colspan="2">13位学生</td></tr><tr><td>2</td><td>张三</td><td>13922222333</td><td rowspan="2">小队长</td></tr><tr><td>3</td><td>李四</td><td>13922222444</td></tr><!-- 页尾 --><tr><td colspan="4" align="right">*学生都要成为WEB开发工程师</td></tr></table>
<!-- thead tbody tfoot 必须同时出现 --><!-- 如果存在大量数据情况,先加载页眉页尾部分,再加载主体 --><!-- thead 表格页眉标签 --><!-- tbody 表格主体标签 --><!-- tfoot 表格页尾标签 --><table border="1" cellpadding="10" cellspacing="10"><caption>VIP班级学生联络表</caption><!-- 页眉 --><thead><tr><th>ID</th><th>姓名</th><th>电话</th><th>备注</th></tr></thead><!-- 主体 --><tbody><tr><td align="center">1</td><td align="center">东东</td><td align="center">13922222222</td><td align="center">班长</td></tr><tr><td>信息</td><td>3班</td><td colspan="2">13位学生</td></tr><tr><td>2</td><td>张三</td><td>13922222333</td><td rowspan="2">小队长</td></tr><tr><td>3</td><td>李四</td><td>13922222444</td></tr></tbody><!-- 页尾 --><tfoot><tr><td colspan="4" align="right">*学生都要成为WEB开发工程师</td></tr></tfoot></table>
表格效果:

字符实体
| 显示结果 | 描述 | 实体名称 | 实体编号 |
|---|---|---|---|
| `` | 空格 |   |
  |
< |
小于号 | < |
< |
> |
大于号 | > |
> |
& |
和号 | & |
& |
上下标标签
sup: superscripted
sub: subscripted
<sup></sup> & <sub></sub>
前端<sup><a href="#">[1]</a></sup>10<sup>5</sup>Na<sup>+</sup>H<sub>2</sub>SO<sub>4</sub>
显示效果为:
前端[1]
10
Na
HSO
标签结构
兼容性模式:
docment.compatMode:
- 有
<!DOCTYPE html>: CSS1Compat(W3C标准模式)- 没有
<!DOCTYPE html>: BackCompat(怪异模式)
//html5声明方式 并不是标签 告诉浏览器用哪个版本编写<!DOCTYPE html>//lang language<html lang="zh-CN"><head>//title//主页:网站名称 + 主要关键字/关键词的描述//详情页:详情名称 + 网站名称 + 简介//列表页:分类名称 + 关键字 + 网站名称<title></title>//meta标签设置 charset字符集编码//关于GB2312 中国信息处理国家标准码 -> 简体中文编码//关于GBK 汉族扩展规范 -> 扩大汉族收录,增加了繁体中文,增加了藏蒙维吾尔文字等小数名族的文字//关于UTF-8 unicode 万国码<meta charset="UTF-8" />//keyword 100字符 网站名称 + 分类信息 + 网站名称<meta name="keyword" content="" />//description 描述信息 80-120汉字//综合title + keywords的简单描述<meta name="description" content="" /></head><body></body></html>
标签属性
| 属性名 | 作用 |
|---|---|
href |
跳转链接 |
src |
图片地址 |
target |
_blank目标新开空页签 |
书写标准
- 标签只能小写
- 属性名也只能小写
- 属性值用双引号包裹
标签嵌套
<strong><em></em></strong>
<div><p></p></div>
判断标签能否嵌套
- 内联元素可以嵌套内联元素
- 块级元素可以嵌套任何元素
- p标签不可以嵌套div标签
- a标签不可以嵌套a标签
元素
标签加上内部的内容
内联元素
行间元素 行内元素(inline element)
strong, em, del, ins, sub, sup, span
特性:
- 不独占一行
- 无法定义宽高
块级元素
block element
p, h1, div, address, ul, ol, li
特性:
- 独占一行
- 可以定义宽高
内联块级元素
inline-block element
特性:
- 不独占一行
- 可以定义宽高
