【四】HTML之表单标签

【四】HTML之表单标签

  • 是HTML中最终的标签之一,主要是提供了输入框或按钮等标签提供给用户进行交互输入数据。将来表单可以提交到指定服务端程序中进行数据处理。

1 form标签

属性描述
action设置当前表单的表单数据处理应用程序的url地址,默认值是当前url地址。
method设置当前表单的HTTP提供方式,默认是get。 get,以查询字符串的格式,把表单数据附加在url地址栏上提交数据 post,以数据包格式,把表单数据附在HTTP网络请求体中提交数据
enctype设置当前表单提交的数据格式,默认值是application/x-www-form-urlencoded。 application/x-www-form-urlencoded:以普通表达数据格式提交 multipart/form-data:以多种数据格式提交 text/plain:以纯文本数据格式提交

2 表单项标签(input/select/button/textarea )

类型用法描述
单行文本框<input type="text" name="" value="" placeholder="">name:设置输入框的值的变量名称,用于服务端接受数据。 value:设置输入框的默认值。 placeholder:设置输入框的提示内容。
密码框<input type="password" name="" value="" placeholder="">只允许输入单行密码,属性描述同上
单行文本框(数值框)<input type="number" name="" value="" placeholder="">只允许输入数值内容,属性描述同上。 就版本浏览器中不支持时会被默认为text单行文本框。
单行文本框(日期输入框)<input type="date" name="">只允许输入日期格式内容,属性描述同上。 低版本浏览器中不支持时会被默认为text单行文本框。
单行文本框(时间输入框)<input type="time" name="">只允许输入时间格式内容,属性描述同上。 低版本浏览器中不支持时会被默认为text单行文本框。
单行文本框(日期时间输入框)<input type="datetime-local" name="">只允许输入日期时间格式内容,属性描述同上。 低版本浏览器中不支持时,会被默认为text单行文本框。
文件上传框<input type="file" multiple name="">multiple:布尔属性,允许一次性上传多个文件。 其他属性描述同上。
单选框<input type="radio" name="" value="">用于提供一组多个选择让用户选一个选项的按钮组。 多个单选框必须name值相同才能为一组。 同一组单选框中的value值必填,而且值要唯一。
多选框<input type="checkbox" name="fav" value="1">用于提供一组多个选择让用户选多个选项的按钮组。 多个多选框必须name值相同才能为一组。 同一组多选框中的value值必填,而且值要唯一。
下拉列表框<select name=""> <option value="选项1值">选项1</option> <option value="选项2值">选项2</option> <option value="...">...</option> <option value="选项n值">选项n</option> </select>属性描述同上。
多行文本框/文本域<textarea name="" cols="" rows=""></textarea>cols:设置多行文本框默认列数[宽度] rows:设置多行文本框默认行数[高度] 注意:多行文本框标签中的任意内容都会被原样记录。
提交按钮<input type="submit" value="提交">value:表示当前按钮的提示文本。 用于提交表单数据到action属性对应的地址中。
普通按钮<input type="button" value="">属性描述同上,主要用于配合js完成网页特效。
普通按钮<button></button>普通按钮,中间可以显示图片或文本。 主要用于配合js完成网页特效。
重置按钮<input type="reset" value="重置">点击以后,会把当前表单中用户输入的所有内容进行还原到页面刚刷新状态。
隐藏域输入框<input type="hidden" name="" value="">隐藏域输入框的作用是附带一些默认数据提交给服务端,但是不希望用户看到。

3 表单项的常用属性

属性名描述
name表示当前表单项的值的变量名,用于提供服务端获取本次提交的数据项。
value表示当前表单项的值,如果值在代码中提前设置了,则为默认值
type表示input框的类型
disabled布尔属性,设置当前输入框是否被禁用
maxlength设置当前输入框[textarea,input]中最大输入内容的长度。
multiple设置允许文件上传框选择上传多个文件
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <form action="http://httpbin.org/post" method="post" enctype="multipart/form-data">
        <input type="hidden" name="hide" value="1.0">
        <label>账号:
        <input type="text" name="username" value="root" disabled placeholder="请输入账号">
        </label><br>
        <label>密码:
        <input type="password" name="password" value="" maxlength="16" placeholder="请输入密码">
        </label><br>
        <label>年龄:
            <input type="number" name="age" value="" placeholder="请输入年龄">
        </label><br>
        <label>出生年月
            <input type="date" name="born">
        </label>
        <br>
        <label>时间:
            <input type="time" name="time">
        </label>
        <br>
        <label>本地日期时间:
            <input type="datetime-local" name="datetime">
        </label>
        <br>
        头像[单文件]:<input type="file" name="avatar"><br>
        头像[多文件]:<input type="file" multiple name="imgs[]">
        <br>
        性别:
            <label><input type="radio" name="sex" value="1"> 男</label>
            <label><input type="radio" name="sex" value="2"> 女</label>
        <br>
        爱好:
            <label><input type="checkbox" name="fav" value="1">篮球</label>
            <label><input type="checkbox" name="fav" value="2">足球</label>
            <label><input type="checkbox" name="fav" value="3">排球</label>
            <label><input type="checkbox" name="fav" value="4">水球</label>
            <label><input type="checkbox" name="fav" value="5">气球</label>
        <br>
        城市:
        <select name="city">
            <option value="1">北京</option>
            <option value="2">天津</option>
            <option value="3">唐山</option>
            <option value="4">廊坊</option>
            <option value="5">上海</option>
            <option value="6">其他</option>
        </select>
        <br>
        个性签名:<br>
        <textarea name="description" cols="30" rows="10"></textarea>
        <br>
        <input type="submit" value="提交表单">
        <input type="button" value="普通按钮">
        <button><img src="goods.png" width="30" height="30" alt=""></button>
        <input type="reset" value="重置表单数据">
    </form>
</body>
</html>

BASE64编码解码

import base64

# base64是一个专门用于处理网络传输数据格式的算法,网络中传输的二进制数据是不能直接被打印或提取的,所以一般都是转换成base64编码进行数据传输。
# 把二进制数据(0~1)经过base64算法形成base64编码
# base64编码主要是 64个字符组成:[0-9A-Za-z+/]
# python内置了base64模块,提供了2个方法给我们对二进制数据进行编码与解码

# 编码
with open("1.jpeg", "rb") as f:
    code = base64.b64encode(f.read()).decode()
    print(f"data:image/jpeg;base64,{code}")

# 解码
content = ""
img_content = content.split(",")[-1]
with open("2.jpeg", "wb") as f:
    content = base64.b64decode(img_content.encode())
    print(content)
    f.write(content)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值