知问前端——Ajax表单插件
传统的表单提交,需要多次跳转页面,极大的消耗资源也缺乏良好的用户体验。而这款form.js表单的Ajax提交插件将解决这个问题。
一、核心方法
官方网站:http://malsup.com/jquery/form/
form.js插件有两个核心方法:ajaxForm()和ajaxSubmit(),它们集合了从控制表单元素到决定如何管理提交进行的功能。
若没有结合其他插件、js、jQuery里的submit()方法时,就用ajaxForm()提交表单。
若用js、jQuery里的submit()方法时,就采用submit()方法。
index.html:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>知问前端</title>
<script type="text/javascript" src="jquery-1.12.3.js"></script>
<script type="text/javascript" src="jquery-ui.js"></script>
<script type="text/javascript" src="jquery.validate.js"></script>
<script type="text/javascript" src="jquery.form.js"></script>
<script type="text/javascript" src="index.js"></script>
<link rel="shortcut icon" type="image/x-icon" href="img/favicon.ico" />
<link rel="stylesheet" type="text/css" href="jquery-ui.css" />
<link rel="stylesheet" type="text/css" href="style.css" />
</head>
<body>
<div id="box"></div>
<form id="reg" action="123.html">
<p class="myerror"></p>
<p>账号:<input type="text" name="user" id="user" /></p>
<p>密码:<input type="text" name="pass" id="pass" /></p>
<p><input type="submit" value="提交" /></p>
</form>
</body>
</html>
style.css:
.valid {
background: url(img/reg_succ.png) no-repeat right;
}
.abc {
border: 5px solid green;
}
jQuery代码如下:
$("#reg").ajaxForm(); //ajaxForm自动阻止了默认提交
$("#reg").submit(); //直接跳转
若此时<form>表单修改为:
<form id="reg" method="post" action="add.php">
<p class="myerror"></p>
<p>账号:<input type="text" name="user" id="user" /></p>
<p>密码:<input type="text" name="pass" id="pass" /></p>
<p><input type="submit" value="提交" /></p>
</form>
add.php:
<?php
echo 'add.php';
?>
1.ajaxForm提交方式:
//ajax()中success:function() {}就是这里的function
$("#reg").ajaxForm(function() {
alert("提交成功!");
});
如何证明ajaxForm()中的function就是ajax()中success:function() {}呢?只须将add.php修改为:
<?php
sleep(3);
echo 'add.php';
?>
使其睡眠3秒钟,然后回复给浏览器,成功返回,弹出“提交成功”对话框。
注意:使用ajaxForm()方法,会直接实现ajax提交。自动阻止了默认行为,而它提交的默认页面是form控件的action属性的值,提交的方式是method属性的值。
2.ajaxSubmit()提交方式
使用submit()提交时,由于会直接跳转,即submit()方法没有阻止默认提交,所以需要自行阻止,代码如下:
$('#reg').submit(function () {
....
return false;
});
$("#reg").submit(function() {
$(this).ajaxSubmit(); //达到的效果如同$("#reg").ajaxForm();
$(this).ajaxSubmit(function() { //达到的效果也如同$("#reg").ajaxForm(function() { alert("提交成功!"); });
alert("提交成功!");
}); //执行的也是ajax()中success方法
return false; //submit()方法没有阻止默认提交,需要自行阻止
});
注意:ajaxForm()方法,是针对form直接提交的,所以阻止了默认行为。而ajaxSubmit()方法,由于是针对submit()方法的,所以需要手动阻止默认行为。而使用了validate.js验证插件,那么ajaxSubmit()比较适合我们。
二、option参数
option参数是一个以键值对传递的对象,可以通过这个对象,设置各种Ajax提交的功能。
$("#reg").submit(function() {
$(this).ajaxSubmit({
url:"test.php", //设置提交的url,可覆盖action属性
target:"#box", //服务器返回的内容存放在#box里
type:"get", //GET,POST两种提交方式
dateType:null, //xml,json,script,默认为null,但经测试null和"html"均可用
//clearForm:true, //成功提交后,清空表单
//resetForm:true, //成功提交后,重置表单
data:{
aaa:"bbb" //增加额外的数据提交
},
beforeSubmit: function(formData,jqForm,options) {
//提交之前执行,一般用于数据验证
//alert(options.url); //test.php
//alert(jqForm.html()); //返回<form id="reg"></form>里面的html内容
//alert(formData[0].name); //得到传递表单元素的name,即user
//alert(formData[0].value); //得到传递表单元素的value,即输入的值
//如果数据验证不合法,就返回false,不让提交,返回true让提交,默认返回true
return true;
},
//成功后回调
success:function(responseText,statusText) {
//alert("提交成功!");
alert(responseText + " " + statusText); //为何返回0 [object HTMLDivElement]?,应该返回test.php success
},
//错误时调用
error:function(event,errorText,errorType) {
//alert("错误!");
alert(errorText + " " + errorType); //error Not Found
}
});
return false; //submit()方法没有阻止默认提交,需要自行阻止
});
三、工具方法
form.js除了提供两个核心方法之外,还提供了一些常用的工具方法。这些方法主要是在提交前或后对数据或表单进行处理的。
1.表单序列化:
alert($('#reg').formSerialize());
2.序列化某一个字段:
alert($('#reg #user').fieldSerialize());
3.得到某个字段的value值:
alert($('#reg #user').fieldValue());
4.重置表单:
$('#reg').resetForm();
5.清空某个字段:
$('#reg #user').clearFields();
知问前端——Ajax表单插件的更多相关文章
- 第一百八十六节,jQuery,验证表单插件,Ajax 表单插件,验证和提交表单
jQuery,验证表单插件,Ajax 表单插件,验证和提交表单 HTML <form id="reg" method="post" action=&quo ...
- 第一百八十五节,jQuery,Ajax 表单插件
jQuery,Ajax 表单插件 学习要点: 1.核心方法 2.option 参数 3.工具方法 传统的表单提交,需要多次跳转页面,极大的消耗资源也缺乏良好的用户体验.而这款 form.js 表单的 ...
- 知问前端——Ajax提交表单
本文,运用两大表单插件,完成数据表新增的工作. 一.创建数据库 创建一个数据库,名称为:zhiwen,表——user表,字段依次为:id.name.pass.email.sex.birthday.da ...
- 知问前端——Ajax登录
本文,将使用Ajax登录. 一.服务器端代码 is_user.php: <?php require 'config.php'; $query = mysql_query("SELECT ...
- 知问前端--Ajax
本节课主要是创建一个问题表,将提问数据通过 ajax 方式提交出去.然后对内容显示进行布局,实现内容部分隐藏和完整显示的功能. 一.Ajax 提问创建一个数据表:question,分别建立:id.ti ...
- 第一百八十七节,jQuery,知问前端--cookie 插件,注册成功后生成cookie,显示登录状态
jQuery,知问前端--cookie 插件 学习要点: 1.使用 cookie 插件 2.注册直接登录 Cookie 是网站用来在客户端保存识别用户的一种小文件.一般来用库可以保存用户登 录信息.购 ...
- Ajax表单提交插件jquery form
jQuery Form插件是一个优秀的Ajax表单插件,我们可以非常容易的使用它处理表单控件的值,清空和复位表单控件,附件上传,以及完成Ajax表单提交. jQuery Form有两个核心方法ajax ...
- jquery.form.js表单插件的使用
jquery.form.js官网:http://malsup.com/jquery/form API文档:http://malsup.com/jquery/form/#api 下载地址:http:// ...
- jQuery插件 -- Form表单插件jquery.form.js<转>
jQuery Form插件是一个优秀的Ajax表单插件,可以非常容易地.无侵入地升级HTML表单以支持Ajax.jQuery Form有两个核心方法 -- ajaxForm() 和 ajaxSubmi ...
随机推荐
- Java学习个人备忘录之抽象类
抽象类 特点:1. 方法只有声明没有实现时,该方法就是抽象方法,需要被abstract修饰,抽象方法必须定义在抽象类中.该类必须也被abstract修饰2. 抽象类不可以被实例化. 为什么? 因为调 ...
- AndroidUI设计之 布局管理器 - 详细解析布局实现
写完博客的总结 : 以前没有弄清楚的概念清晰化 父容器与本容器属性 : android_layout...属性是本容器的属性, 定义在这个布局管理器的LayoutParams内部类中, 每个布局管理器 ...
- java — 值传递和引用传递
在 Java 应用程序中永远不会传递对象,而只传递对象引用.因此是按引用传递对象.Java 应用程序按引用传递对象这一事实并不意味着 Java 应用程序按引用传递参数.参数可以是对象引用,而 Java ...
- lintcode-161-旋转图像
161-旋转图像 给定一个N×N的二维矩阵表示图像,90度顺时针旋转图像. 样例 给出一个矩形[[1,2],[3,4]],90度顺时针旋转后,返回[[3,1],[4,2]] 挑战 能否在原地完成? 标 ...
- 《学习OpenCV》课后习题解答4
题目:(P104) 练习使用感兴趣区域(ROI).创建一个210*210的单通道图像并将其归0.在图像中使用ROI和cvSet()建立一个增长如金字塔状的数组.也就是:外部边界为0,下一个内部边界应该 ...
- 基于3D卷积神经网络的人体行为理解(论文笔记)(转)
基于3D卷积神经网络的人体行为理解(论文笔记) zouxy09@qq.com http://blog.csdn.net/zouxy09 最近看Deep Learning的论文,看到这篇论文:3D Co ...
- pycharm/webstorm创建react项目
1.安装nodejs 2.安装reactapp依赖:npm install -g create-react-app 在pycharm/webstorm中选择react
- 当重写了 httpservlet重写了GenericServlet的init方法时候 必须显示调用GenericServlet的init方法时候 才能在别的方法(父类创建config实例) 例如 doget里面使用servletContext对象 不重写init 则可以直接使用
- css之display样式,padding,margin
1. 块级标签变成行内标签 <!DOCTYPE html> <html lang="en"> <head> <meta charset=& ...
- 配置和修改springboot默认国际化文件
SpringBoot默认国际化文件为:classpath:message.properties,如果放在其它文件夹中,则需要在application.properties配置属性spring.mess ...