欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

如何理解jQuery中的ajaxSubmit方法

程序员文章站 2022-07-10 09:42:20
刚刚学习中,使用到了ajaxsubmit,犹豫以前没有接触㢧这个,所以刚开始是一脸懵逼状态,最后通过查找资料的方式,解决了这个问题这个很兴奋,做到了页面的无刷...

刚刚学习中,使用到了ajaxsubmit,犹豫以前没有接触㢧这个,所以刚开始是一脸懵逼状态,最后通过查找资料的方式,解决了这个问题这个很兴奋,做到了页面的无刷新上传图片,送给看我博客园的朋友一句话:“山高人为峰,努力定成功!”

下面我对ajaxsubmit做一下总结:

1.jquery引入进去;

2.网上下载jquery form插件;

(这里对form插件做一下介绍,因为刚开始做前端的人不一定能懂,

jquery form插件是一个优秀的ajax表单插件,可以非常容易地、无侵入地升级html表单以支持ajax。jquery form有两个核心方法 -- ajaxform() 和 ajaxsubmit(), 它们集合了从控制表单元素到决定如何管理提交进程的功能。另外,插件还包括其他的一些方法: formtoarray()、formserialize()、fieldserialize()、fieldvalue()、clearform()、clearfields() 和 resetform()等。

下载地址:

核心方法 -- ajaxform() 和 ajaxsubmit()

3.首先说用法,ajaxform和ajaxsubmit都可以接收0或1个参数,该参数可以是一个变量、一个对象或回调函数,这个对象主要有以下参数:

var object= {
      url:url,      //form提交数据的地址
       type:type,    //form提交的方式(method:post/get)
       target:target,  //服务器返回的响应数据显示的元素(id)号
      beforeserialize:function(){} //序列化提交数据之前的回调函数
       beforesubmit:function(){},  //提交前执行的回调函数
       success:function(){},     //提交成功后执行的回调函数
      error:function(){},    //提交失败执行的函数
       datatype:null,       //服务器返回数据类型
       clearform:true,       //提交成功后是否清空表单中的字段值
       restform:true,       //提交成功后是否重置表单中的字段值,即恢复到页面加载时的状态
       timeout:6000         //设置请求时间,超过该时间后,自动退出请求,单位(毫秒)。  

}
<!doctype html>
<html>
<head>
 <title>权限信息展示
 </title>
 <link href="~/content/jqueryeasyui/themes/default/easyui.css" rel="external nofollow" rel="stylesheet" />
 <link href="~/content/jqueryeasyui/themes/icon.css" rel="external nofollow" rel="stylesheet" />
 <script src="~/content/jqueryeasyui/jquery-1.8.3.min.js"></script>
 <script src="~/scripts/myjqueryform.js"></script>//这里引入
 <script src="~/content/jqueryeasyui/jquery.easyui.min.js"></script>
 <script src="~/content/jqueryeasyui/locale/easyui-lang-zh_cn.js"></script>
 <script src="~/scripts/datapattern.js"></script>
 <script src="~/scripts/jquery.unobtrusive-ajax.js"></script>
 <script type="text/javascript">
  $(function () {
   //绑定异步上传图片
   bindupload();
  });
  //绑定异步上传图片
  function bindupload() {
   alert("aaaaa");
   $("#btnuploadfile").click(function () {
    alert("bbbbb");
    $("#adddiglogdiv form").ajaxsubmit({
     url: '/actioninfo/uploadimg',
     type: "post",
     success: function (data) {
      alert("ccccc");
      //将返回的数据加载到隐藏域
      $("#iconimg").val(data);
      $("#showimgdiv").html("<img src='" + data + "' style='width:100px; height:80px'/>");
     }
    });
   });
  }

html代码是这样的:

<body>
 <!-------------添加对话框 start--------------------->
 <div id="adddiglogdiv">
  @using (ajax.beginform("addactioninfo", "actioninfo", new ajaxoptions() { onsuccess = "afteradd" }))
  {
   <table>
    <tr>
     <td>权 限 名:</td>
     <td>
      <input type="text" name="actionname" /></td>
    </tr>
    <tr>
     <td>url:</td>
     <td>
      <input type="text" name="url" /></td>
    </tr>
    <tr>
     <td>http方法类型:</td>
     <td>
      <select name="httpmethod">
       <option value="get">get</option>
       <option value="post">post</option>
      </select>
     </td>
    </tr>
    <tr>
     <td>是否是菜单:</td>
     <td>
      <input type="checkbox" id="ckbismenushow" value="true" name="ismenu" /></td>
    </tr>
    <tr id="trmenuadress">
     <td>菜单图片地址:</td>
     <td>
      <input type="hidden" id="iconimg" name="iconimg" />
      <input type="file" id="filemenuicon" name="filemenuicon" />
      <input type="button" value="上传" id="btnuploadfile" />
      <div id="showimgdiv"></div>
     </td>
    </tr>
    <tr>
     <td>排 序:</td>
     <td>
      <input type="text" name="sort" /></td>
    </tr>
    <tr>
     <td>备 注:</td>
     <td>
      <input type="text" name="remark" /></td>
    </tr>
   </table>
  }
 </div>
 <!-------------添加对话框 end --------------------->
</body>
</html>

最终要完成的项目是这样的:

如何理解jQuery中的ajaxSubmit方法

最终我成功的实现了异步无刷新上传图片的功能!

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!