广告
返回顶部
首页 > 资讯 > 前端开发 > node.js >如何使用Ajax实现表单提交及后台处理
  • 387
分享到

如何使用Ajax实现表单提交及后台处理

2024-04-02 19:04:59 387人浏览 独家记忆
摘要

这篇文章主要为大家展示了“如何使用ajax实现表单提交及后台处理”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用Ajax实现表单提交及后台处理”这篇文章吧

这篇文章主要为大家展示了“如何使用ajax实现表单提交及后台处理”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用Ajax实现表单提交及后台处理”这篇文章吧。

首先先说下表单提交吧,要提交表单那么就得先收集表单数据(至于验证这个我就不说了,要说留下下次吧),有了Jquery取个html的值还是简单$("xxid").val()等就完了,但如果一张表单收集的数据很多,像这样的表单又有很多张,那用此方法肯定麻烦死,并且容易眼花录错。所以,我们就可以简单的来定义一个收集规则,如在要回传到服务器的数据表单控件,可以做个标记,到时取的时候把这些标记的数据一起取回去。

 就拿最简单的文体输入做例子吧<input type="text" id="txtcode" name="txtcode" datafield="Code"  />我们加一个"datafield"属性,存入的值为对应服务器相关类的属性名。有了这标记前台取数据就好办了。

我们可以定个通用方法如下面代码

getFORMData: function(formid) {    
    var data = {};

    //获取TEXT文件内容
    $("#" + formid + " input[type=text]").each(function(i, o) {
      var jo = $(o);
      if (jo.attr("datafield")) {
        var str = jo.val();
        str = str.replace(" ", "");
        if (str !== "") {          
          data[jo.attr("datafield")] = jo.val();
        }
      }
    });
    return data;
}

这里就是一个简单的获取表单里面所有text文本,并放入到一个data对象里面,至于其它表单控件值怎么取我就不多说了,原理差不多。

那么接下回就是把数据发到服务器上了,我这里就直接用jquery带的ajax。

var save = function(sender) {     
      $(sender).prop("disabled", true); //禁用按钮,防止重复发送
      var data = getFormData("form1");
      var JSONobj = { jsondata: data };
      var textdata = JSON.stringify(jsonobj);
      $.ajax({
        type: "POST",
        contentType: "application/json; charset=utf-8",
        url: "xxxxx.aspx/Save",
        dataType: "json",
        data: textdata,
        success: function(msg) {
          if (msg.d == "1") {
            document.form1.reset();
            alert("保存成功!");           
          }
          else if (msg.d == "0") {
            alert("保存失败!");
          }
        },
        complete: function(jqXHR, textStatus) {
          $(sender).prop("disabled", false); //还原按钮
        }
      });
    }

这里的"xxxxx.aspx/Save"就是ajax处理页面,其它就是一个WEBmethod。做了一下防止客户手速太快,服务处理太慢,重复点击的处理。

这样一个表单数据收集,回传服务器就完成了。这里使用json2.js的JSON.stringify方法统一将对象转成json字符,好处就是不用自己为拼json字符串而考虑json的格式问题,简单干净。

那么客户已经把数据收录好了,服务器也该要处理数据了。我们从前台来的数据的键(json的key),不可能全部包括某个数据类的所有属性。并且数据类也有很多个,应该是哪一个类只有服务器才知道。所以这里我们就需要写一个帮助的转换类。这里又有问题,有可能数据类有很多个,难道我要为每一个类写一个方法,那不是个坑么?所以我们分析下客户端传到服务端上的数据格式,它是一组键值对且不会重复,那么就相当于一个Dictionary<string, string>,后台的类有很多种,那么至少我们能确定一个传入参数了,传出的就是相关类。相关类?到底是哪一类还只有到了具体后台收集方法里才知道。那么,整理一下思路,现在有一个Dictionary<string, string>要变成一个数据类,数据类到底是什么有什么样的属性?搞不清,但这个Dictionary<string, string>的key(键)可以看做是这个数据类属性集的一个子集,而这个Dictionary<string, string>的value(值)是这个数据类属性值toString()的子集。那样这样就好办了。属性集怎么取?反射。这么多类到底是哪个?不管它,泛型解决。

说下这么多,贴下核心代码

public static T1 UpdateObjectByDic<T1>(T1 scrobj, IDictionary<string, string> sourceobject, bool ignoreCase)
     where T1 : new()
    {
      T1 result = scrobj;
      PropertyInfo[] pifresults = typeof(T1).GetProperties();
      foreach (var dic in sourceobject)
      {
        foreach (PropertyInfo pifresult in pifresults)
        {
          if (string.Compare(dic.Key, pifresult.Name, ignoreCase) == 0)
          {
           pifresult.SetValue(result, ChangeType(dic.Value, pifresult.PropertyType), null);
            break;
          }
        }
      }
      return result;
    }

    public static Object ChangeType(object value, Type targetType)
    {
      Type convertType = targetType;
      if (targetType.IsGenericType && targetType.GetGenericTypeDefinition().Equals(typeof(Nullable<>)))
      {
        NullableConverter nullableConverter = new NullableConverter(targetType);
        convertType = nullableConverter.UnderlyingType;

      }
      return Convert.ChangeType(value, convertType);
    }

我这里T1 scrobj是把更新做在一起,如添加表单就传个new的对象进来,如果是更新把单就把原表单数据传进来。这里顺带说下ChangeType方法,其它就是数据类里有些属性是nullable的(int? DateTime?等)传统的Convert.ChangeType会有异常所以就简单改了下,ignoreCase就是属性(前台那个datafield对应的值)查找是否处理大小写(一般是不管大小写的,要管大小写相信会被前台口水流淹死)。

这样后台数据处理核心就完了,调用部分代码也贴下

[WebMethod(EnableSession = true)]
    public static string Save(Dictionary<string, string> jsondata)
    {
      string result = "0";
      Model.Project pro = ConvertHandle.UpdateObjectByDic< Model.Project>(jsondata,new Model.Project,true);      
      pro.CreatorID = BLL.Sys_User.GetCurUser().ID.ToString();
      pro.CreatorName = BLL.Sys_User.GetCurUser().Name;    
      prohandle.Insert(pro);
      result = "1"; 
      return result;
    }

这里就是后台具体处理方法调用的核心使用了,prohandle.Insert(pro)将类存入数据库,pro.CreatorID,pro.CreatorName为项目的一些其它信息,这些就不说了。到这里一个表单前台数据收集,后台处理,除了保存那块以外,就都算完了,呵呵。

文章最后说下,这里只是个简单应用,像我说的这前台收集,很多前台js框架都已经早做了,考虑方面也比我这个全面得多,后台处理我这是基于我这种前台简单收集弄的,很多第三方框架都有完整的体系了,但我这里说的只是一种简单的思路,当你一时没有那么多控件时是否能把这一条路简单走通实现。当然我强烈建议不要重复造轮子,但要一定要明白轮子的核心作用和原理。

以上是“如何使用Ajax实现表单提交及后台处理”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网node.js频道!

--结束END--

本文标题: 如何使用Ajax实现表单提交及后台处理

本文链接: https://www.lsjlt.com/news/81011.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何使用Ajax实现表单提交及后台处理
    这篇文章主要为大家展示了“如何使用Ajax实现表单提交及后台处理”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用Ajax实现表单提交及后台处理”这篇文章吧...
    99+
    2022-10-19
  • Ajax如何实现提交Form表单及文件上传
    这篇文章主要为大家展示了“Ajax如何实现提交Form表单及文件上传”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Ajax如何实现提交Form表单及文件上传”这...
    99+
    2022-10-19
  • 如何使用Ajax方法实现Form表单的提交
    这篇文章主要介绍了如何使用Ajax方法实现Form表单的提交,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。常见的form表单提交方式<...
    99+
    2022-10-19
  • 如何使用ajax异步提交表单
    这篇文章主要介绍如何使用ajax异步提交表单,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!方式一手工收集所有的用户输入,封装为大的“k1=v1&k2=v2…”键值对形式,使用...
    99+
    2022-10-19
  • ajax如何实现前台后台跨域请求处理
    这篇文章主要为大家展示了“ajax如何实现前台后台跨域请求处理”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“ajax如何实现前台后台跨域请求处理”这篇文章吧。跨...
    99+
    2022-10-19
  • layui如何实现表单提交到后台自动封装到实体类
    这篇文章主要介绍layui如何实现表单提交到后台自动封装到实体类,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1、表单中的每一项的name属性值,必须和你所封装的实体中的属性名字一一...
    99+
    2022-10-19
  • 使用ajax怎么实现在提交时校验表单
    这篇文章给大家介绍使用ajax怎么实现在提交时校验表单,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。什么是ajaxajax是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术,可以通过在后台与服务器进行少量数据...
    99+
    2023-06-08
  • 如何使用JavaWeb实现表单提交
    这篇文章主要介绍如何使用JavaWeb实现表单提交,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!register.html<!DOCTYPE html PUBLIC "-...
    99+
    2023-06-29
  • 纯javascript中ajax如何实现php异步提交表单
    这篇文章将为大家详细讲解有关纯javascript中ajax如何实现php异步提交表单,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。很多时候需要异步提交表单,当表单太多是时候,一个个getElementB...
    99+
    2023-06-08
  • ajax如何实现无刷新提交表单、上传文件
    这篇文章主要介绍ajax如何实现无刷新提交表单、上传文件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、HTML代码 <!DOCTYPE html PUBLIC &...
    99+
    2022-10-19
  • js如何使用ajax传值给后台以及后台返回字符串进行处理
    这篇文章主要为大家展示了“js如何使用ajax传值给后台以及后台返回字符串进行处理”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“js如何使用ajax传值给后台以...
    99+
    2022-10-19
  • bootstrap+Validator如何实现模态框、jsp、表单验证 Ajax提交功能
    这篇文章主要介绍bootstrap+Validator如何实现模态框、jsp、表单验证 Ajax提交功能,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!效果图:如图,这是使用Valid...
    99+
    2022-10-19
  • 使用AjaxSubmit()方法怎么实现Form提交表单后回调功能
    今天就跟大家聊聊有关使用AjaxSubmit()方法怎么实现Form提交表单后回调功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。2.    ...
    99+
    2023-06-08
  • layui中如何实现form表单提交之后重新加载数据表格
    小编给大家分享一下layui中如何实现form表单提交之后重新加载数据表格,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!如下图,...
    99+
    2022-10-19
  • 如何实现Jquery基于Ajax方法自定义无刷新提交表单Form
    本篇内容主要讲解“如何实现Jquery基于Ajax方法自定义无刷新提交表单Form”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何实现Jquery基于Ajax...
    99+
    2022-10-19
  • 如何使用php函数来优化表单处理和提交功能?
    随着Web应用程序的发展,表单处理和提交是开发中非常重要的一部分。在PHP中,使用合适的函数来处理和提交表单可以提高代码的可读性和可维护性。本文将介绍一些常用的PHP函数,以及它们在表单处理和提交中的应用。htmlspecialchars(...
    99+
    2023-10-21
    表单处理 PHP函数 提交功能
  • 如何用Ajax方式提交带文件上传的表单及怎么隐藏iframe应用
    本篇文章给大家分享的是有关如何用Ajax方式提交带文件上传的表单及怎么隐藏iframe应用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一般的...
    99+
    2022-10-19
  • 如何实现layui中表单提交以及验证和修改弹框
    这篇文章主要介绍如何实现layui中表单提交以及验证和修改弹框,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! HTML <div class="layui-...
    99+
    2022-10-19
  • 如何使用layui前端框架弹出form表单以及提交
    小编给大家分享一下如何使用layui前端框架弹出form表单以及提交,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!第一步: 引用...
    99+
    2022-10-19
  • JavaScript在form表单中如何使用button按钮实现submit提交方法
    这篇文章将为大家详细讲解有关JavaScript在form表单中如何使用button按钮实现submit提交方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。submit...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作