Ajax表单提交及后台处理简单应用
首先先说下表单提交吧,要提交表单那么就得先收集表单数据(至于验证这个我就不说了,要说留下下次吧),有了jquery取个html的值还是简单$("xxid").val()等就完了,但如果一张表单收集的数据很多,像这样的表单又有很多张,那用此方法肯定麻烦死,并且容易眼花录错。所以,我们就可以简单的来定义一个收集规则,如在要回传到服务器的数据表单控件,可以做个标记,到时取的时候把这些标记的数据一起取回去。
就拿最简单的文体输入做例子吧<input type="text" id="txtcode" name="txtcode" datafield="Code" style="width: 200px" />我们加一个"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 == "") {
- document.form1.reset();
- alert("保存成功!");
- }
- else if (msg.d == "") {
- 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) == )
- {
- 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 = "";
- 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 = "";
- return result;
- }
这里就是后台具体处理方法调用的核心使用了,prohandle.Insert(pro)将类存入数据库,pro.CreatorID,pro.CreatorName为项目的一些其它信息,这些就不说了。到这里一个表单前台数据收集,后台处理,除了保存那块以外,就都算完了,呵呵。
文章最后说下,这里只是个简单应用,像我说的这前台收集,很多前台js框架都已经早做了,考虑方面也比我这个全面得多,后台处理我这是基于我这种前台简单收集弄的,很多第三方框架都有完整的体系了,但我这里说的只是一种简单的思路,当你一时没有那么多控件时是否能把这一条路简单走通实现。当然我强烈建议不要重复造轮子,但要一定要明白轮子的核心作用和原理。
Ajax表单提交及后台处理简单应用的更多相关文章
- Ajax表单提交插件jquery form
jQuery Form插件是一个优秀的Ajax表单插件,我们可以非常容易的使用它处理表单控件的值,清空和复位表单控件,附件上传,以及完成Ajax表单提交. jQuery Form有两个核心方法ajax ...
- 使用Jquery.form.js ajax表单提交插件弹出下载提示框
现象: 使用jquery的from做ajax表单提交的时候,后台处理完毕返回json字符串,此时浏览器提示下载一个json文件而不是在success里面继续解析该json对象. 具体的原因: 浏览器兼 ...
- form表单提交,后台怎么获取select的值?后台直接获取即可,和input方式一样。
form表单提交,后台怎么获取select的值? 后台直接获取即可,和后台获取input的值方式一样. form提交后,后台直接根据select的name获取即可,即getPara("XXX ...
- form表单提交和ajax表单提交,关于移动端如何通过软键盘上的【搜索】和【前进】进行提交操作
[文章来源]由于自己对于form研究甚少,所以一直用的都是AJAX进行提交,这次后台提出要用form提交,顺便深入研究一下:之前在做表单的时候,发现input可以通过设置不同的type属性,调用不同的 ...
- 表单提交与后台PHP如何接口?
在网页中,常常有这样那样的表单需要提交,比如登陆,比如注册,比如查询,比如填写问卷.在这样的表单提交过程中,我们究竟向后台提交了什么,是以什么形式提交的,是一个很值得探讨的问题. 提交了什么——就是我 ...
- jquery.form.js(ajax表单提交)
Form插件地址: 官方网站:http://malsup.com/jQuery/form/ 翻译地址:http://www.aqee.net/docs/jquery.form.plugin/jquer ...
- 使用bean接收ajax表单提交数据包含文件上传
这几天写带图片上传的表单提交,一个配置小程序活动弹出框样式的功能,记录一下一些需要注意的地方 首先是 前端 JSP 文件的表单 <form class="search-wrapper& ...
- easyui表单提交,后台获取不到值
J2ee开发,使用easyui表单提交,在ie中可以正常将参数传递到后台,但使用firefox,chrome都无法将easyui的combobox值传递到后台,使用alert($('#form').s ...
- 20151223jquery学习笔记--Ajax表单提交
传统的表单提交, 需要多次跳转页面, 极大的消耗资源也缺乏良好的用户体验. 而这款form.js 表单的 Ajax 提交插件将解决这个问题.一. 核心方法官方网站: http://malsup.com ...
随机推荐
- 沃通tomcat jks 安装配置
废话不多说上代码: <Connector port="443" protocol="org.apache.coyote.http11.Http11NioProtoc ...
- Linux下安装oracle11g
1.安装环境: Linux:Redhat Enterprise Linux 6.3 64位 Oracle:Oracle Database 11g for Linux x86-64 64位 2.修改操作 ...
- pl sql练习(2)
1.尽可能了解oracle的功能,因为很多业务逻辑oracle已经为我们做了,比如oracle已经预定义了大量的异常代码,我们不必要写自己的异常而增加代码的复杂度. 例如oracle定义了当找不到符合 ...
- CDZSC_2015寒假新人(1)——基础 a
Description Contest time again! How excited it is to see balloons floating around. But to tell you a ...
- Kill命令模拟1
#include<sys/types.h> #include<signal.h> #include<stdio.h> #include<stdlib.h> ...
- 整数v,从高位到低位,取c位数,得到最大数 (其中:v>=10^c)
题目如上,例子v=22312324,c=3,求得最大数为334. 用自己的想法实现了一遍,如果你有更好的方法的话,欢迎不吝赐教. 我的思路是,先将整数v按位存入一个数组,数组低位为整数高位,如num[ ...
- Holding Bin-Laden Captive!(hdoj1085)代码并未完全看懂
We all know that Bin-Laden is a notorious terrorist, and he has disappeared for a long time. But rec ...
- 【MYSQL 清空所有的的表中的数据的SQL的生成】
MYSQL 清空所有的的表中的数据的SQL的生成 select Concat('TRUNCATE TABLE ', TABLE_NAME, ';') from INFORMATION_SCHEMA.T ...
- .net MVC内置js验证 jquery.validate.unobtrusive.js重置验证操作(备忘,找了很多次了)
(function ($) { $.validator.unobtrusive.parseDynamicContent = function (selector) { //use the normal ...
- js实现车轮的来回滚动
最近喜欢用js做车轮的来回滚动,简单的js动画分享给大家.有什么建议记得说出来大家一起讨论哦!效果图如下: 源代码: <style> #pic1{ width:20px; height:2 ...