HTML 与 CSS
HTML 是什么:即 HyperText Markup language 超文本标记语言,咱们熟知的网页就是用它编写的,HTML 的作用是定义网页的内容和结构。
- HyperText 是指用超链接的方式组织网页,把网页联系起来
- Markup 是指用
<标签>
的方式赋予内容不同的功能和含义
CSS 是什么:即 Cascading Style Sheets 级联(层叠)样式表,它描述了网页的表现与展示效果
1. HTML 元素
HTML 由一系列元素 elements
组成,例如
1 | <p>Hello, world!</p> |
整体称之为元素
<p>
和</p>
分别称为起始和结束标签标签包围起来的 Hello, world 称之为内容
p 是预先定义好的 html 标签,作用是将内容作为一个单独的段落
元素还可以有属性,如
1 | <p id="p1">Hello, world!</p> |
- 属性一般是预先定义好的,这里的 id 属性是给元素一个唯一的标识
元素之间可以嵌套,如
1 | <p>HTML 是一门非常<b>强大</b>的语言</p> |
错误嵌套写法:
1 | <p>HTML 是一门非常<b>强大的语言</p></b> |
不包含内容的元素称之为空元素,如
1 | <img src="1.png"> |
- img 作用是用来展示图片
- src 属性用来指明图片路径
2. HTML 页面
前面介绍的只是单独的 HTML 元素,它们可以充当一份完整的 HTML 页面的组成部分
1 |
|
html
元素囊括了页面中所有其它元素,整个页面只需一个,称为根元素head
元素包含的是那些不用于展现内容的元素,如title
,link
,meta
等body
元素包含了对用户展现内容的元素,例如后面会学到的用于展示文本、图片、视频、音频的各种元素
3. 常见元素
1) 文本
Heading
1 | <h1>1号标题</h1> |
Paragraph
1 | <p>段落</p> |
List
无序列表 unordered list
1 | <ul> |
有序列表
1 | <ol> |
多级列表
1 | <ul> |
Anchor
锚,超链接
1 | <a href="网页地址">超链接文本</a> |
2) 多媒体
Image
1 | <img src="文件路径"> |
src 格式有 3 种
文件地址
data URL,格式如下
1
data:媒体类型;base64,数据
object URL,需要配合 javascript 使用
Video
1 | <video src="文件路径"></video> |
Audio
1 | <audio src="文件路径"></audio> |
3) 表单
作用与语法
表单的作用:收集用户填入的数据,并将这些数据提交给服务器
表单的语法
1 | <form action="服务器地址" method="请求方式" enctype="数据格式"> |
- method 请求方式有
- get (默认)提交时,数据跟在 URL 地址之后
- post 提交时,数据在请求体内
- enctype 在 post 请求时,指定请求体的数据格式
- application/x-www-form-urlencoded(默认)
- multipart/form-data
- 其中表单项提供多种收集数据的方式
- 有 name 属性的表单项数据,才会被发送给服务器
常见的表单项
文本框
1 | <input type="text" name="uesrname"> |
密码框
1 | <input type="password" name="password"> |
隐藏框
1 | <input type="hidden" name="id"> |
日期框
1 | <input type="date" name="birthday"> |
单选
1 | <input type="radio" name="sex" value="男" checked> |
多选
1 | <input type="checkbox" name="fav" value="唱歌"> |
文件上传
1 | <input type="file" name="avatar"> |
4. HTTP 请求
1) 请求组成
请求由三部分组成
- 请求行
- 请求头
- 请求体
可以用 telnet 程序测试
2) 请求方式与数据格式
get 请求示例
1 | GET /test2?name=%E5%BC%A0&age=20 HTTP/1.1 |
- %E5%BC%A0 是【张】经过 URL 编码后的结果
post 请求示例
1 | POST /test2 HTTP/1.1 |
application/x-www-form-urlencoed 格式细节:
- 参数分成名字和值,中间用 = 分隔
- 多个参数使用 & 进行分隔
- 【张】等特殊字符需要用 encodeURIComponent() 编码为 【%E5%BC%A0】后才能发送
json 请求示例
1 | POST /test3 HTTP/1.1 |
json 对象格式
1 | {"属性名":属性值} |
其中属性值可以是
- 字符串 “”
- 数字
- true, false
- null
- 对象
- 数组
json 数组格式
1 | [元素1, 元素2, ...] |
multipart 请求示例
1 | POST /test2 HTTP/1.1 |
- boundary=123 用来定义分隔符
- 起始分隔符是
--分隔符
- 结束分隔符是
--分隔符--
数据格式小结
客户端发送
- 编码
- application/x-www-form-urlencoded :url 编码
- application/json:utf-8 编码
- multipart/form-data:每部分编码可以不同
- 表单只支持以 application/x-www-form-urlencoded 和 multipart/form-data 格式发送数据
- 文件上传需要用 multipart/form-data 格式
- js 代码可以支持任意格式发送数据
服务端接收
- 对 application/x-www-form-urlencoded 和 multipart/form-data 格式的数据,Spring 接收方式是统一的,只需要用 java bean 的属性名对应请求参数名即可
- 对于 applicaiton/json 格式的数据,Spring 接收需要使用 @RequestBody 注解 + java bean 的方式
3) session 原理
Http 无状态,有会话
- 无状态是指,请求之间相互独立,第一次请求的数据,第二次请求不能重用
- 有会话是指,客户端和服务端都有相应的技术,可以暂存数据,让数据在请求间共享
服务端使用了 session 技术来暂存数据
存
1 | GET /s1?name=zhang HTTP/1.1 |
取
1 | GET /s2 HTTP/1.1 |
session 技术实现身份验证
1 | sequenceDiagram |
4) jwt 原理
jwt 技术实现身份验证
1 | sequenceDiagram |
生成 token
1 | GET /j1?name=zhang&pass=123 HTTP/1.1 |
校验 token
1 | GET /j2 HTTP/1.1 |
5. CSS
即 Cascading Style Sheets,它描述了网页的表现与展示效果
1) 选择器
type 选择器 - 根据标签名进行匹配(元素选择器)
class 选择器 - 根据元素的 class 属性进行匹配
id 选择器 - 根据元素的 id 属性进行匹配
2) 属性和值
- background-color : red;
- …
- display
3) 布局
与布局相关的 html 元素
- div
- template