本阶段学习的内容整体为:
Html 网页的结构 (标签的使用)
CSS 样式 网页的化妆师 (比如颜色)
JavaScript 事件 (比如点击确定)
jQuery js的插件库
ajax 前后交互
第一部分:HTML框架简介
(1)什么是HTML?
超文本标记语言(HyperText Markup Language,简称:HTML)
(2)怎么学HTML?
HTML是一门标记语言,标记语言由一套标记标签组成,学习HTML,就是学习标签。
(3)使用的工具:
编辑器:pycharm
浏览器:Firefox,Chrome
1.HTMl的基本结构
2.HTML的基本模板
<!DOCTYPE html> #文档类型的声明
<html lang="en"> #根标签,即文档的开始。 lang(language),en(english)。声明语言类型是英语
<head> #网页头部
<meta charset="UTF-8"> #国际编码 meta配置 字符集编码的类型
<title>Title</title> #网页标题
</head>
<body> #网页的主体,可视化区域
</body>
</html>
小知识点:
1.<!DOCTYPE html> 标签:作用:在html文件最前面进行声明,定义文档类型,告知浏览器用html规范去解析文档。
2.在pycharm中编写HTML文件时,<!-- 要注释的内容--> 为注释,快捷键是Ctrl+/。
3.在pycharm中编写HTML文件时,打标签时可直接打标签名,再Tab即可实现自动补全。
如:输入p,再Tab会自动补全为:<p></p>
第二部分:标签
(1)什么是标签?
由尖括号包裹单词构成,如:,所以标签不可能以数字开头。
(2)标签不区分大小写,推荐小写
(3)标签可以嵌套,但不能交叉嵌套
(4)标签也称为元素。比如:行内标签亦可成行内元素
错误示例:<a><b></a></b>
正确示例:<a><b></b></a>
1.标签的使用样式及属性
(1)标签的使用样式:
1.开始标签又称开放标签<a>标签体</a>结束标签又称闭合标签
2.自闭合标签,如:<meta charset="UTF-8">,<br>等
(2)标签属性:
a.通常为键值对形式出现,比如:<meta charset="UTF-8"> 里面的charset为标签的属性,对应的单引号或者双引号里的称为属性值;
b.属性只能出现在开始标签和自闭合标签内,但不能出现在结束标签里;
c.属性名字全部小写,属性值必须用单引号或者双引号包裹;
d.如果属性名和属性值完全一样,直接写属性名即可,如:"readonly"(input标签属性)
(3)块状标签
首先是:块状标签的特点:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>块状标签的特点</title>
</head>
<body>
<!--块状标签的特点:(通过段落标签p进行说明)-->
<!--1.设置宽高有效,以及外边距和内边距都可控制-->
<!--2.在不设置宽度的情况下,宽度始终与浏览器保持一致,与内容无关。是容器的100%。-->
<!--3.可以独占一行,实现自动换行。一个段落标签不管多少内容都占一行-->
<!--4.当多个块状标签写一起时,默认排列方式是从上向下-->
<!--5.可以容纳内联元素和其他块元素-->
<p style="width:100px; height:100px">这是个段落标签,我是块状标签</p>
</body>
</html>
小解释:
1.px是像素,是长度单位
2.在网页查看元素(ELements)显示的是宽度*高度
其次是:常用的块状标签:
总共有四个:
1.标题标签
2.段落标签
3.列表标签:有序列表,无序列表和定义列表
4.div标签
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>常用的块状标签</title>
</head>
<body>
<!--第一个:标题标签。h1到h6 (一般放在文章的标题)-->
<h1>我是一级标签,一个网页只能有一个,别的可以有多个</h1>
<h2>我是二级标签</h2>
<!--第二个:段落标签。 大小跟四级标题标签一样 (会把HTML文档分割成若干个段落)-->
<p>我是段落标签</p>
<!--第三个:列表标签-->
<!--(1)有序列表-->
<ol type="A" start="3"> <!--本行是有序列表的开始 type有五个选择.start规定从第几个开始排-->
<li>这是有序列表1</li>
<li>这是有序列表2</li>
<li>这是有序列表3</li>
</ol>
<!--(2)无序列表-->
<ul type="circle"> <!--本行是无序列表的开始 可以设置none(空的),circle(空心圆),square(正方形),disc(实心圆)等样式-->
<li>这是无序列表1</li>
<li>这是无序列表2</li>
<li>这是无序列表3</li>
<li>这是无序列表4</li>
</ul>
<!--(3)定义列表-->
<dl> <!--本行是定义列表的开始-->
<dt>水果</dt> <!--代表一个大的列项-->
<dd>葡萄</dd> <!--代表对上面列项的解释,即细分。-->
<dd>榴莲</dd>
<dt>蔬菜</dt>
<dd>花菜</dd>
<dd>包菜</dd>
</dl>
<!--第四个:div标签:用来分划一个一个的区域(width和height来规定区域大小;background-color是设置区域背景色)-->
<!--不宜过多使用。后期维护不好-->
<div style="width:500px;height: 500px;background-color: #66a9fe;">我是一个div</div>
</body>
</html>
小知识点:
如果嫌打列表标签太麻烦,可使用快捷方法:(n表示相应的标签的个数)
(4)内联标签(行内标签)
首先是:内联标签的特点:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>内联标签,又称行内标签的特点</title>
</head>
<body>
<!--内联标签的特点(通过文本标签span说明)-->
<!--1.设置宽高无效,以及外边距和内边距都无法控制-->
<!--2.宽度就是其文字或者图片宽度,无法控制-->
<!--3.不会进行自动换行,只有本行放满才会放下一行-->
<!--4.当多个内联标签写在一起时,默认排列方式是从左往右-->
<!--5.内联元素只能容纳文本或者其他内联元素-->
<span>我是个文本标签</span>
</body>
</html>
其次是:常用的内联标签:
总共有四种:
1.图片标签
2.粗体/斜体标签
3.超链接标签
4.文本标签
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>常用的内联标签(行内标签)</title>
</head>
<body>
<!--第一个:图片标签 img + Tab-->
<img src="" alt=""> <!--src是图片的地址,可以直接是网页里的图片地址,也可以是本地图片的地址(推荐使用相对路径)-->
<!--alt是当图片路径发生错误时显示的内容-->
<!--第二个:粗体/斜体标签 b+ Tab i+ Tab -->
<b>我是粗体</b>
<i>我是斜体</i>
<!--第三个:超链接标签 _self本身网页上打开;_blank打开一个新网页-->
<a href="" title="超链接的一个说明(鼠标放上会显示的文本)" target="_self">我是超链接</a> <!--href里可以写网址,可以写文件路径-->
<!--第四个:文字标签 和css配合使用才有用哦!-->
<span>我是文本标签</span>
</body>
</html>
小知识点:
如果图片标签里填的是本地图片的地址(相对路径):
1.如果图片在同级目录下,直接: 当前目录名/图片名
或者: ./当前目录名/图片名
2.如果图片在上级目录下,直接: . ./图片名
拓展小知识点:
为什么要实现行内标签和块状标签的相互转换,在后面css样式会用到。
比如:块状标签是不能放在一行了,但我们可以通过先转换为行内标签就可以了!!!
第三部分:特殊符号
(1)什么是特殊符号?
特殊符号就是网页上一些比较特殊的符号
(2)为什么需要特殊符号?
因为有时候我们需要特殊符号,比如:把html代码显示在网页上
(3)注意:如果在打印时空格,不管有多少个空格,最后在网页上只显示一个!
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>特殊字符</title>
</head>
<body>
<!--特殊符号以&开头,以;结尾-->
<span>这个是 空格</span>
<span>这是一个中文字的 宽度(字符宽)</span>
<span>这是个大于号></span>
<span>这是个小于号<</span>
<span>这是一个双引号:"</span>
<span>这是个特殊符号,输出是©。©</span>
<span>这是个特殊符号,输出为&。&</span>
</body>
</html>
第四部分:表格
(1)什么是表格?
比如Excel表格之类的
(2)表格如今用来干啥?
一般用于后台展示数据
(3)表格初识
分为:表头,表身和表脚
注意:
table:是表格标签
tr: 是行标签
td: 是列表签
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>表格</title>
</head>
<body>
<table border="1"> <!--border是设置边框,属性值为粗细-->
<caption>学生信息表</caption> <!--表格标题-->
<tr>
<th>学号</th> <!--表头 (在tr行标签中用th) 默认字体加粗-->
<th>姓名</th>
</tr>
<tr>
<td colspan="2">1</td> <!--colspan是合并列-->
<td rowspan="2">2</td> <!--rowspan是合并行-->
</tr>
<tr>
<td>3</td>
<td>4</td>
</tr>
</table>
</body>
</html>
第五部分:表单 (很重要哦!!!)
(1)表单是什么?
表单是搜集用户数据信息的各种表单元素的集合区域。
(2)表单的作用?
用于收取用户数据,并向后台发送
前后端交互的方式之一
(3)表单的应用?
登录注册,搜索,文件上传等。
1.表单(form)的属性:
(1)action: 提交时候的地址,默认使用当前页面。指向服务器的某个程序。
(2)method: 提交时候的方法,默认使用get
(3)entype: 目前使用默认即可
2.表单常用的标签:
(1)input标签:
1.input标签的常用属性:
一些小知识:
id主要用于样式或者js。不能用中文或者数字。主要用于表达唯一性
代码说明type属性值为image的情况:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form action="">
<!--type属性值为image时是一个图片形式的提交按钮。 -->
<!--src属性放图片地址;alt属性使图片变为可点击的,跟提交按钮作用一样,同时图片发生错误时显示alt的属性值-->
<input type="image" src="girl.jpg" alt="submit">
</form>
</body>
</html>
代码说明:
readonly:只读。比如你无法对你的QQ号进行操作。
disabled:禁用。比如你在使用pycharm时有些选项是灰白色的无法使用。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form action="">
用户名:<input type="text" name="user" readonly><br>
账 号:<input type="password" name="pdw" disabled>
</form>
</body>
</html>
效果截图:用户名是只读的,所以无法在text文本框里输入值;账号是禁用的,直接变成灰色了。
2.input标签常用的type属性值
text 文本框
password 密码框
radio 单选框
checkbox 复选框
file 文件选择
hidden 隐藏域 hidden是用户看不见的东西,给管理员(写网页的)操作保存信息的!
submit 提交
reset 重置
(2)select下拉框
option :下拉选项(下拉框的基本标签):有多少个option就有多少个下拉选项
selected :下拉状态:表示选中某个下拉选项
size :下拉框显示:表示下拉框,显示多少个,默认为一个
name :下拉框的名字:表示下拉框向后台提交数据的时候所传的名字
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form action="">
地址:<select name="address" id="address" size="1"> <!--属性size是显示几个下拉框-->
<optgroup label="湖南省"> <!--在标签optgroup里对下拉框进行分组-->
<option value="CS">长沙市</option> <!--标签option是下拉选项-->
<option value="ZZ">株洲市</option>
<option value="LD">娄底市</option>
</optgroup>
<optgroup label="湖北省">
<option value="WH" selected>武汉市</option> <!--selected属性代表下拉框默认选择-->
</optgroup>
</select>
</form>
</body>
</html>
效果截图:
3.总结:
表单form包含的元素:
<form>表单标签,下表为总结:
部分知识点的综合使用:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>表单</title>
</head>
<body>
<!--表单的标签 form+Tab-->
<form action="" method="">
<!--action需要提交到的路径 method里get有长度限制,不是很安全,会把你的信息显示;post没长度限制,且安全-->
姓名:<input type="text" placeholder="请输入姓名"><br>
密码:<input type="password" placeholder="请输入密码"><br> <!--如果type属性值是password则在网页里输入的时候不显示-->
<!--当网页刷新时,加checked的这个选项是默认选中的选项,注意这个标签属性checked就是属性名和属性值一样-->
性别:<input type="radio"name="sex" value="male" checked>男 <!--name属性里面的值相同的代表他们是同一类,只能选其一。实现单选!!!-->
<input type="radio" name="sex" value="female">女 <!--加value是传数据时传的相应的值-->
<br>
<input type="submit" value="登录"> <!--提交按钮,默认是提交两个字,可以通过改value来改-->
<input type="reset"> <!--重置按钮,所有信息恢复默认-->
<input type="button" value="这是个普通按钮"> <!-- 普通按钮 要配合js使用-->
</form>
</body>
</html>
4.拓展:
(1)表单中另外一些常用的标签:
fieldset标签:给表单设置分组
legend:设置分组表单的标题
label:提高用户体验度
对拓展的一些代码讲解:
(1)label标签
单选框只有点圆圈才能选中。label实现点相应的字也能选中,但使用之前按钮要取id,因为label的实现是根据id一一匹配的
(2)fieldset标签
给表单设置分组:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form action="">
<fieldset> <!--对表单进行分组,用标签fieldset-->
<legend>这是这个分组的名字!</legend> <!--对分组设置名字用标签legend-->
用户名:<input type="text" placeholder="请输入用户名" name="user"><br>
密 码:<input type="password" placeholder="请输入密码" name="pwd"><br>
</fieldset>
</form>
</body>
</html>
(2)拓展一些标签
斜体标签:
i
em 起强调作用(文本内容需要强调的部分)
加粗标签:
b
strong 起强调作用(文本内容需要强调的部分)
在网页中插入视频标签
video (src属性值为视频地址,可以是本地可以是网址
controls属性开启对视频的控制操作
width,height属性设置视频大小)
在网页中加入音乐标签
audio (src属性值为音频地址
controls属性打开对音频的控制操作)
注意:不管写了几个(单独一个标签放一首那样写),都可同时播放音频。
但是:::
如果像下面这样写,只会播放第一个地址正确的音频!!!
类似于字幕
marquee
相关属性及属性值:
滚动方向direction(包括4个值:up、 down、 left和 right 默认是left)
滚动方式behavior(scroll:循环滚动,默认效果; slide:只滚动一次就停止; alternate:来回交替进行滚动)
滚动速度scrollamount(滚动速度是设置每次滚动时移动的长度,以像素为单位)
滚动延迟scrolldelay(设置滚动的时间间隔,单位是毫秒)
滚动循环loop(默认值是-1,滚动会不断的循环下去)
设定活动字幕的背景颜色bgcolor,背景颜色可用RGB、16进制值的格式或颜色名称来设定。
width和height设置活动字幕的宽度和高度。
换行标签
br
分割线标签
hr