热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

基于Ajax表单提交及后台处理简单的应用

下面小编就为大家带来一篇基于Ajax表单提交及后台处理简单的应用。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

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

 就拿最简单的文体输入做例子吧我们加一个"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,后台的类有很多种,那么至少我们能确定一个传入参数了,传出的就是相关类。相关类?到底是哪一类还只有到了具体后台收集方法里才知道。那么,整理一下思路,现在有一个Dictionary要变成一个数据类,数据类到底是什么有什么样的属性?搞不清,但这个Dictionary的key(键)可以看做是这个数据类属性集的一个子集,而这个Dictionary的value(值)是这个数据类属性值toString()的子集。那样这样就好办了。属性集怎么取?反射。这么多类到底是哪个?不管它,泛型解决。

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

public static T1 UpdateObjectByDic(T1 scrobj, IDictionary 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&#63; DateTime&#63;等)传统的Convert.ChangeType会有异常所以就简单改了下,ignoreCase就是属性(前台那个datafield对应的值)查找是否处理大小写(一般是不管大小写的,要管大小写相信会被前台口水流淹死)。

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

[WebMethod(EnableSession = true)]
    public static string Save(Dictionary jsondata)
    {
      string result = "0";
      Model.Project pro = ConvertHandle.UpdateObjectByDic(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表单提交及后台处理简单的应用就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。


推荐阅读
  • 本文将详细介绍如何在ThinkPHP6框架中实现多数据库的部署,包括读写分离的策略,以及如何通过负载均衡和MySQL同步技术优化数据库性能。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 本文探讨了在不使用服务器控件的情况下,如何通过多种方法获取并修改页面中的HTML元素值。除了常见的AJAX方式,还介绍了其他可行的技术方案。 ... [详细]
  • 探讨了如何解决Ajax请求响应时间过长的问题。本文分析了一个从服务器获取少量数据的Ajax请求,尽管服务器已经对JSON响应进行了缓存,但实际响应时间仍然不稳定。 ... [详细]
  • 在PHP后端开发中遇到一个难题:通过第三方类文件发送短信功能返回的JSON字符串无法解析。本文将探讨可能的原因并提供解决方案。 ... [详细]
  • 使用JS、HTML5和C3创建自定义弹出窗口
    本文介绍如何结合JavaScript、HTML5和C3.js来实现一个功能丰富的自定义弹出窗口。通过具体的代码示例,详细讲解了实现过程中的关键步骤和技术要点。 ... [详细]
  • 本文详细介绍了如何使用 HTML 和 CSS 对文件上传按钮进行样式美化,使用户界面更加友好和美观。 ... [详细]
  • 当unique验证运到图片上传时
    2019独角兽企业重金招聘Python工程师标准model:public$imageFile;publicfunctionrules(){return[[[na ... [详细]
  • 一个登陆界面
    预览截图html部分123456789101112用户登入1314邮箱名称邮箱为空15密码密码为空16登 ... [详细]
  • 本文详细介绍了如何利用Go语言和WebSockets技术构建一个高效的实时聊天系统。随着网络应用的日益复杂化,实时交互成为了提升用户体验的关键要素之一。通过本指南,开发者可以学习到最新的技术和最佳实践。 ... [详细]
  • 本文探讨了2019年前端技术的发展趋势,包括工具化、配置化和泛前端化等方面,并提供了详细的学习路线和职业规划建议。 ... [详细]
  • 本文深入探讨了JavaScript中实现继承的四种常见方法,包括原型链继承、构造函数继承、组合继承和寄生组合继承。对于正在学习或从事Web前端开发的技术人员来说,理解这些继承模式对于提高代码质量和维护性至关重要。 ... [详细]
  • 本文探讨了如何通过WebBrowser控件在用户点击输入框时自动显示图片验证码。该过程可能涉及JavaScript事件的触发与响应。 ... [详细]
  • 本文探讨了浏览器的同源策略限制及其对 AJAX 请求的影响,并详细介绍了如何在 Spring Boot 应用中优雅地处理跨域请求,特别是当请求包含自定义 Headers 时的解决方案。 ... [详细]
  • 深入解析ES6至ES8的新特性与应用
    本文详细介绍了自2015年发布的ECMAScript 6.0(简称ES6)以来,JavaScript语言的多项重要更新,旨在帮助开发者更好地理解和利用这些新特性进行复杂应用的开发。 ... [详细]
author-avatar
肥姐PK老赖
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有