Javascript高级编程学习笔记(74)—— 表单(2)表单提交及重置
表单提交
表单的很大一部分作用就是帮助用户完成和服务器的交互
所以表单提交是表单中比较重要的部分
虽然现如今的大部分应用场景都使用 AJAX 的异步请求来代替表单,但是仍有部分操作需要使用表单来完成,例如上传文件等
表单的提交一般来说是通过图像按钮,或者提交按钮来实现的
提交按钮既可以是 input 元素 也可以是 button 元素,如下所示:
<!--通用提交按钮-->
<input type = "submit" value = "Submit Form"> <!--自定义提交按钮-->
<button type = "submit">Submit Form </button> <!--图像按钮-->
<input type = "image" src = "loading.gif">
这些按钮在拥有焦点的情况下 按下表单就会提交;当然点击这些按钮也会提交
当通过这种方式提交表单时,浏览器会在将请求发送给服务器之前触发 submit 事件
该事件通常用于验证用户发送的信息,以便减轻服务器的负担
此外,通过阻止该事件的默认行为可以取消表单的提交
如下所示:
var form = document.forms[0]; // 获取页面的第一个表单
form.addEventListener("submit",function(event){
event.preventDefault();// 阻止默认事件,即就算点击了提交按钮也不会发送给服务器
},false)
当然我们也可以通过 submit 方法来提交表单:
form.submit();// 提交表单这里的 form 和上方代码中form一样
需要注意的是:调用submit方法并不会触发 submit 事件,所以我们在使用JS代码提交之前需要对表单信息进行验证
此外表单提交可能出现的最大问题就是重复提交,所以在处理时最好在第一次表单信息发送给服务器后将提交按钮禁用,或者取消后续的提交
重置表单
有时候我们需要重置表单的信息
只要 type 为 reset 的 input 或 button 元素都可以创建重置按钮
<!--通用重置按钮-->
<input type = "reset" value = "Reset"> <!--自定义重置按钮-->
<button type = "reset">Reset</button>
通过重置按钮重置表单时,所有表单字段会恢复到页面加载完成的初始状态
同样,在我们单击(或回车)重置按钮时,浏览器会触发 reset 事件
我们也可以通过阻止 reset 事件的默认行为来阻止浏览器的重置:
var form = document.forms[0]; // 获取页面的第一个表单
form.addEventListener("reset",function(event){
event.preventDefault();// 阻止默认事件,阻止浏览器的重置
},false)
同样,通过 reset 方法 我们可以通过代码来触发页面的重置
form.reset();
通常来说用到重置的地方很少,因为用户在你重置表单之后并不一定有耐心再重新填写一遍
所以在使用时要十分小心
Javascript高级编程学习笔记(74)—— 表单(2)表单提交及重置的更多相关文章
- Javascript高级编程学习笔记(75)—— 表单(3)表单字段
表单字段 表单作为web应用中不可或缺的一部分,当然也是可以使用原生的 DOM 元素来访问的 除了标准的访问方式之外,每个表单都拥有一个 elements 属性,该属性保存着该表单所有 表单元素 的集 ...
- JavaScript高级程序设计学习笔记第十四章--表单
1.在 HTML 中,表单是由<form>元素来表示的,而在 JavaScript 中,表单对应的则是 HTMLFormElement 类型. HTMLFormElement 继承了 HT ...
- Javascript高级编程学习笔记(80)—— 表单(8)表单序列化
表单序列化 随着 Ajax 的出现,表单序列化成为一种常见需求 以将表单信息序列化为查询字符串为例 我们可以利用表单的 type 属性,以及 name 和 value 实现对表单的序列化 序列化应满足 ...
- Javascript高级编程学习笔记(78)—— 表单(6)HTML约束验证API
自动切换焦点 使用JS可以极大地提升表单的易用性 其中最常用的一种就是当用户填写完当前字段后焦点自动切换到下一个字段 以下方的HTML代码为例: <input type="text&q ...
- Javascript高级编程学习笔记(77)—— 表单(5)过滤输入
在日常实践中,我们常常会需要用户按照某种规则输入数据 但是文本框在默认情况下缺少验证数据的手段,因此需要使用JS来完成此类过滤输入的操作 通过事件和DOM的结合手段就能够将普通的文本框转换为功能型控件 ...
- Javascript高级编程学习笔记(73)—— 表单(1)表单基础
表单 JS最初的一个用途就是帮助服务器分担处理表单的责任 时至今日,虽然web应用以及JS都有了长足的发展,但是表单依然是现在web应用中比较重要的部分. 因为默认的表单控件很丑,所以有时候我们会使用 ...
- Javascript高级编程学习笔记(79)—— 表单(7)选择框脚本
选择框脚本 选择框由<option>和<select>元素创建,为了方便选择框的交互,除了提供表单字段的公有方法之外 HTMLSelectElement 类型还提供下列特有的属 ...
- Javascript高级编程学习笔记(76)—— 表单(4)选择文本
文本框脚本 在HTML中文本框有两种实现方式: <input> <textarea> 这两种实现方式虽然在多数情况下表现一致,但是两者之间仍存在许多重要区别 对于<inp ...
- Javascript高级编程学习笔记(51)—— DOM2和DOM3(3)操作样式表
操作样式表 在JS中样式表用一种类型来表示,以便我们在JS对其进行操作 这一类型就是CSSStyleSheet 即CSS样式表类型,包括了之前 style 对象所不包括的外部样式表以及嵌入样式表 其中 ...
随机推荐
- 关于servelt的相关介绍
1.@WebServlet注解的作用 在Servlet 3.0中,使用@WebServlet注解可实现servlet和url的映射,它告知容器哪些Servlet会提供服务以及额外信息,其作用相当于之前 ...
- leetcode7:反转整数
给定一个 32 位有符号整数,将整数中的数字进行反转. 示例 1: 输入: 123 输出: 321 示例 2: 输入: -123 输出: -321 示例 3: 输入: 120 输出: 21 注意: 假 ...
- docker环境下solrcloud+zookeeper集群部署教程
前言:两个月前的16年11月份完成的配置,使用的solr6.1和zookeeper3.4,刚刚写成blog,目前版本可能有小版本的变化. 本例完成结果为:在docker环境下部署solrcloud集群 ...
- js中的回调函数 和promise解决异步操作中的回调地狱问题。
回调函数 : 函数作为参数传递到另外一个函数中.简单数据类型和引入数据类型中的数组和对象作为参数传递大家肯定都不陌生,其实引用数据类型中的函数也是可以的. 事实上大家见到的很多,用到的也很多,比如jQ ...
- 解决删除镜像时image is referenced in multiple repositories
1.查看镜像 docker images rt@:~# docker images REPOSITORY TAG IMAGE ID CREATED SIZE hours ago MB f8ab12e0 ...
- linux端口详解大全
0|无效端口,通常用于分析操作系统 1|传输控制协议端口服务多路开关选择器 2|管理实用程序 3|压缩进程 5|远程作业登录 7|回显 9|丢弃 11|在线用户 13|时间 17|每日引用 18|消息 ...
- [记录]MySQL 查询无法导出到文件
很多时候我们需要将数据导出到 xls文件, 然后交给数据分析师分析. 而这个查询数据+导出的动作,理应使用一个有只读权限的用户使用. 但查询某表时: select * from table ,此用户可 ...
- 安装ODBC前需要安装Visual C++
https://mariadb.com/resources/blog/resolving-error-1918-system-error-code-126-when-installing-mysql- ...
- Mysql双主互备+keeplived高可用架构(部分)
一.Mysql双主互备+keeplived高可用架构介绍 Mysql主从复制架构可以在很大程度保证Mysql的高可用,在一主多从的架构中还可以利用读写分离将读操作分配到从库中,减轻主库压力.但是在这种 ...
- Python基础------列表,元组的调用方法
Python基础------列表,元组的调用方法@@@ 一. 列表 Python中的列表和歌曲列表类似,也是由一系列的按特定顺序排列的元素组成的,在内容上,可以将整数,实数,字符串,列表,元组等任何类 ...