form表单是一个包含表单元素的区域,允许用户在表单中(比如:文本域、下拉列表、单选框、复选框等等)输入信息的元素。是前后端交互的重要标签。
规定表单或标签的名称
# form表单
eg:
"""
input标签中有两个非常重要的属性:
1.name属性
类似于字典的key(前端程序员写)
2.value属性
类似于字典的value(用户自己传)
如果标签是选择类型的,那么还需要前端程序员自己填写value,
用于区分具体数据含义
ps:我们在编写input标签的时候应该添加name属性
"""
控制数据的提交地址:规定当提交表单时,向何处发送表单数据(默认为当前页面)。
# 方式1:写全路径
action="http://www.aa7a.cn/user.php"
# 方式2:写后缀
action="user.php"
# 方式2:不写(朝网页所在的地址提交)
action=""
"""url:统一资源定位符"""
form表单中有一个method属性 用于控制提交的方式
有两个选项,默认是get请求
# 最常见的网络请求方式有两种
1.get请求: 朝服务端索要数据
2.post请求: 朝服务端提交数据
# 两种请求都可以携带数据
1.get请求是在url后面通过?组织数据:
url?name=jason&pwd=123&email=123@qq.com
'''
get请求虽然可以携带数据,但是一般只用于不重要的数据携带,
并且get请求携带数据的大小有限制 最多只能携带2KB左右
'''
2.post请求是在请求体中组织数据
HTTP请求数据格式
获取用户各中类型数据的标签(html里面的变形金刚)
根据其type
属性值的不同,呈现不同的状态
单个文件: 多个文件:# type=""
1. text # 正常展示的普通文本
placeholder:提示文本
value:默认值
name:名称
readonly:只读,布尔属性
required:必须输入,布尔属性
disabled:不可用,布尔属性,input,select,textarea的通用属性
minlength:最小长度,提交时判定
maxlength:最大可输入的长度
pattern:正则匹配
antocomplete :自动记录输入,以后输入时可以自动选择完成。可选值为on/off,默认on
用户名:
2. password # 密文展示
属性和text一样,主要区别是,会自动隐藏输入的内容
密码:
3. date # 日历展示
生日:
4. radio # 单选
(1)可以通过添加checked="checked"设置默认值
ps:如果属性名和属性值相同 可以简写checked
(2)name:名称,必须有,相同name的单选会作为一组,会相互排斥
(3)value:选项对应的值
性别:
男
女
其他
5. checkbox # 多选
可以产生多选框,也可以通过添加checked="checked"设置默认值
爱好:
篮球
足球
排球
6. email # 邮箱格式数据
邮箱:
7.file # 文件数据
用于添加文件数据,可以通过添加multiple属性控制获取单个还是多个文件
8. submit # 触发form表单提交数据
9. reset # 重置页面填写的数据
10. button # 普通按钮没有任何功能
意味着以后可以给它添加任意的功能(JS事件)
11. image # 图片按钮
作用同提交按钮一样,只是用属性src替换了value,表示图片地址
省市: 前女友:# 下拉框:一个个的下拉选项是一个个option标签
# 默认是单选
# 可以添加multiple变成多选
# 通过size调整界面显示个数
文本域,用于输入大批量的文本
# cols控制每行显示长度,rows控制显示行数,主要用于调整文本域大小,不会限制输入的文本
# 因为是双标签,所以默认内容不再是写在value属性中,而是直接写再标签里
(1)提示标签:专门给input标签配文字说明,也可以不使用
(2)属性for
的值是:要提示的组件的id
(3)label可以跟某个input绑定 , 点击label就可以激活对应的input
eg:
# 写法1
# 写法2
按钮,在form
中使用时有提交功能,和的功能一样,标签的文本即是按钮的提示文字
# 提交数据的功能
# 可以代替submit的提交功能
注意:与input属性中的button按钮的区别
# 仅仅是普通按钮
选择器 {属性名1:属性值1;属性名2:属性值2}
一个正常的网页css样式是非常多的 就算专门开设css文件存储也很乱,这个时候就可以在css文件中通过注释来辅助辨别与查找
/*注释内容*/
head内style标签内部直接编写css代码
ps:建议在小白学习阶段可以使用 方便查看
Hello world.
head内link标签引入外部css文件,
ps:工作中一般使用的都是link形式,符合标准
即嵌入式:
嵌入式是将CSS样式集中写在网页的标签对应的标签中。
也称之为"行内式",是最不推荐使用的一种方式,因为它会将HTML和CSS柔和到一起,增加了耦合度
问题来了:CSS是用于调整HTML标签样式的,但是同一个页面上有很多相同的标签并且可能需要有不同的样式,怎么办呢?
首先我们要知道修改样式的标签是哪一个,因此:
CSS的学习流程是:
先学会如何查找标签(CSS选择器)
之后才能学如何给标签修改样式
# 直接通过标签名查找标签
h1 {
color: deeppink; /*让所有h1标签内部所有的字体颜色变为深粉色*/
}
通过标签的class属性查找标签(关键符号是句点符)
.c1 {
color: greenyellow; /*将所有class属性中含有c1的标签内部字体颜色改为亮绿色*/
}
通过标签的id属性查找标签,即通过标签id号查找(关键符号是#)
#d1 {
color: orange;
}
可以查找所有的标签
* {
color: blue;
}
p1 p2# 补充:标签关系
span1
span2
"""
通过嵌套层级来表示亲属关系
1.对于div1来说div2、p2、span2都是儿子
2.对于div2、p2、span2来说div1就是父亲
3.对于p1来说div2是父亲 div1是爷爷(可以将div1和div2统称为祖先)
4.对于span2来说div2、p2是哥哥 span2是弟弟
5.div1内部所有的标签无论层级都可以称之为是div1的后代
ps:判断的时候一定要看层级关系
"""
# 查找id是d1的标签内部所有的儿子span
#d1>span {
color: red
}
# 查找id是d1标签内部所有的后代span
#d1 span {
color: red;
}
# 查找id是d1标签同级别下面紧挨着第一个a标签
#d1 + a {
color: red;
}
# 查找id是d1标签同级别下面所有a标签
#d1 ~ a {
color: red;
}
[type] {
background-color: red;
}
[type='text'] {
background-color: red;
}
div[type='text'] {
background-color: red;
}
# 查找div或者p或者span标签
div, p, span {
color: red;
}
# 查找id是d1或者class包含c1或者span标签
# d1, .c1, span {
color: red;
}
# 玩法1:
div#d1 查找id是d1的div标签
div.c1 查找class包含c1的div标签
# 玩法2:
div #d1 查找div内部id是d1的后代标签
#d1>.c1 查找id值是d1的标签内部class包含c1的儿子标签
# 鼠标移动到p标签上方,字体颜色动态修改为橙色
p:hover {
color: orange;
}
# 输入框被鼠标左键选中就会产生聚焦效果
input:focus {
background-color: black;
}
通过css操作文本内容
# 1.修改首个字体样式
p:first-letter {
color: red;
font-size: 48px;
}
# 2.在文本开头添加内容
p:before {
content:'开头';
color: blue;
}
# 3.在文本结尾添加内容
p:after {
content:'结尾';
color: yellow;
}
使用场景:
(1)用于后面清除浮动带来的负面影响
(2)用于网站的内容防爬
继承是CSS的一个主要特征,只要定义了一个标签的样式,它也会作用域它的后代,例如一个body定义了的字体颜色值也会应用到段落的文本中,不过只要给对应的子标签设置字体颜色就可以覆盖继承的样式。
CSS继承权重是0,因此优先级很低
在一个HTML页面中有很多种方式找到一个元素并且为其设置样式,浏览器是根据选择器的权重来应用哪个样式的
# html文件中
1.相同选择器
'就近原则':谁离标签越近就听谁的
2.不同选择器
行内选择器 > id选择器 > 类选择器 > 标签选择器
权重计算方式如下图:
除此之外还可以通过添加 !important方式来强制让样式生效,但并不推荐使用。因为如果过多的使用!important会使样式文件混乱不易维护。
万不得已可以使用!important
...
用户名: 密码: 性别: 爱好: 生日: 邮箱: 单个文件: 多个文件: 省市: 前女友: 个人介绍:
用户注册
男
女
其他
篮球
足球
排球
我是个p标签
学习之路本身就是充满荆棘的!!!
学习之路本身就是充满荆棘的!!!
学习之路本身就是充满荆棘的!!!
学习之路本身就是充满荆棘的!!!
学习之路本身就是充满荆棘的!!!
学习之路本身就是充满荆棘的!!!
学习之路本身就是充满荆棘的!!!
我是个span标签