前台和后台的相互传值

目录

一、把json对象转成字符串

二、创建数据容器对象 [用来绑定要传给后台的前台控件值]

三、创建绑定前台数据对象 [用来读取后台传过来的值,并绑定到前台页面]

四、使用示例

前后台的相互传值如果值太多,写的麻烦累人,且容易出错。这里整理出一套使用标记 标签属性的办法来传值, 后台取值和前台的绑定都有了大大的简化。

一、把json对象转成字符串

 1    $.extend({
 2             //将json对象转换成字符串   [貌似jquery没有自带的这种方法]
 3             toJSONString: function (object) {
 4                 if (object == null)
 5                     return;
 6                 var type = typeof object;
 7                 if (‘object‘ == type) {
 8                     if (Array == object.constructor) type = ‘array‘;
 9                     else if (RegExp == object.constructor) type = ‘regexp‘;
10                     else type = ‘object‘;
11                 }
12                 switch (type) {
13                     case ‘undefined‘:
14                     case ‘unknown‘:
15                         return;
16                         break;
17                     case ‘function‘:
18                     case ‘boolean‘:
19                     case ‘regexp‘:
20                         return object.toString();
21                         break;
22                     case ‘number‘:
23                         return isFinite(object) ? object.toString() : ‘null‘;
24                         break;
25                     case ‘string‘:
26                         return ‘"‘ + object.replace(/(\\|\")/g, "\\$1").replace(/\n|\r|\t/g, function () {
27                             var a = arguments[0];
28                             return (a == ‘\n‘) ? ‘\\n‘ : (a == ‘\r‘) ? ‘\\r‘ : (a == ‘\t‘) ? ‘\\t‘ : ""
29                         }) + ‘"‘;
30                         break;
31                     case ‘object‘:
32                         if (object === null) return ‘null‘;
33                         var results = [];
34                         for (var property in object) {
35                             var value = $.toJSONString(object[property]);
36                             if (value !== undefined) results.push($.toJSONString(property) + ‘:‘ + value);
37                         }
38                         return ‘{‘ + results.join(‘,‘) + ‘}‘;
39                         break;
40                     case ‘array‘:
41                         var results = [];
42                         for (var i = 0; i < object.length; i++) {
43                             var value = $.toJSONString(object[i]);
44                             if (value !== undefined) results.push(value);
45                         }
46                         return ‘[‘ + results.join(‘,‘) + ‘]‘;
47                         break;
48                 }
49             }
50         });

二、创建数据容器对象 [用来绑定要传给后台的前台控件值]

 1 var DataClass = {
 2     create: function () {
 3                 return function () {
 4                     this.MyInit.apply(this, arguments);//创建对象的构造函数  //arguments 参数集合  系统名称 不能写错
 5                 }
 6             }
 7 }
 8 var MyDataPack = DataClass.create();
 9 MyDataPack.prototype = {
10     //初始化
11     MyInit: function (url, operation, params) {
12
13                 this.data = new Object();   //所有数据容量
14
15                 var bdata = new Object();
16                 bdata.url = url;            //地址
17                 bdata.operation = operation;//操作
18                 bdata.params = params;      //参数
19
20                 this.data.BasicData = bdata; //基本数据
21             },
22     //添加数据 如:addValue("obj", "111");
23     addValue: function (p, obj) {
24         this.data[p] = obj;
25     },
26     //取得 所有标记控件的值 并写入数据
27     getValueSetData: function (togName) {
28                 var values = Object(); //值的集合
29                 $("[subtag=‘" + togName + "‘]").each(function () {
30                     //如果是input 类型 控件
31                     if (this.localName == "input") {
32                         //如果是text 控件
33                         if (this.type == "text" || this.type == "hidden") {
34                             values[this.id] = this.value;
35                         }
36                         else if (this.type == "...") {
37
38                         }
39                         //......
40                     }
41                     else if (this.localName == "...") {
42
43                     }
44                     //................
45                 });
46                 this.data[togName] = values;//添加到数据集合
47             },
48     //取值 如:getValue("BasicData")
49     getValue: function (p) {
50                 return this.data[p];
51             },
52     //获取或设置url
53     getUrl: function (url) {
54                 if (url)
55                     this.data.BasicData["url"] = url;
56                 else
57                     return this.data.BasicData["url"];
58             }
59     ,
60     //取值 转成字符串的对象 数据
61     getJsonData: function () {
62         return $.toJSONString(this.data);
63     }
64 }

三、创建绑定前台数据对象 [用来读取后台传过来的值,并绑定到前台页面]

var MyDataBinder = {
    //绑定数据到 控件 data:数据 tag:标签
    Bind: function (data, Tag) {
        var MJson = $.parseJSON(data);
        //只绑定 标记 了的 标签
        $("[bindtag=‘" + Tag + "‘]").each(function () {
            if (this.localName == "input") {
                if (MJson[this.id]) //如果后台传了值
                    $(this).attr("value", MJson[this.id]);
            }
            else if (this.localName == "...") {
            }
            //....
        });
    }
};

四、使用示例

前台html:

 1 <table>
 2     <tr>
 3         <th>一</th>
 4         <th>二</th>
 5         <th>三</th>
 6     </tr>
 7     <tr>
 8         <td id="td1"><input type="text" id="inp_1" subtag="subtag" bindtag="bind" /></td>
 9         <td id="td2"><input type="text" id="inp_2" subtag="subtag" value="我只是测试一下下" /></td>
10         <td><input type="text" id="inp_3" subtag="subtag" bindtag="bind" /></td>
11     </tr>
12 </table>

前台js:

1 //====================使用示例======================================
2 var MyDataPack = new MyDataPack("Handler1.ashx", "CESHI", "");
3 MyDataPack.getValueSetData("subtag");//将控件数据写入对象   “subtag”为要取 控件 值 的标签
4 //-------------------传前台值到后台---------------
5 $.post(MyDataPack.getUrl(), MyDataPack.getJsonData(), function (data) {
6     //-------------------绑定后台值到前台-----------------
7     MyDataBinder.Bind(data, "bind");  //"bind" 为 要绑定控件的 标签
8 });

后台:

 1         public void ProcessRequest(HttpContext context)
 2         {
 3             context.Response.ContentType = "text/plain";
 4             //====================取前台值=============================================
 5             //因为后台传过来的是 json对象 转换后的字符串  所以 所有数据都 做为一个参数传过来了
 6             var values = context.Request.Form[0];
 7             //需要引入程序集System.Web.Extensions.dll
 8             JavaScriptSerializer _jsSerializer = new JavaScriptSerializer();
 9             //将 json 对象字符串  转成 Dictionary 对象
10             Dictionary<string, Dictionary<string, string>> dic = _jsSerializer.Deserialize<Dictionary<string, Dictionary<string, string>>>(values);
11
12             //现在 dic 里面就包含了 所有前台传过来的值 想怎么用 就怎么用了。
13             string inp_2 = dic["subtag"]["inp_2"];//这样就直接取到了前台 页面 id为 inp_2 的 控件value 值
14
15
16
17             //=====================传值到前台============================================
18             Dictionary<string, string> dic2 = new Dictionary<string, string>();
19             dic2.Add("inp_1", "修改1");//这里只用对应控件id 传值即可
20             dic2.Add("inp_2", "修改2");
21             dic2.Add("inp_3", "修改3");
22             context.Response.Write(_jsSerializer.Serialize(dic2));
23         }

demo

时间: 2024-11-06 19:29:38

前台和后台的相互传值的相关文章

前台向后台传值的两种方法 以及 从后台获取数据的方法

1.前台向后台传值方法一: 表单提交的方式: 1 <form action="${path }/manage/logon.do" method="post" id="logonForm"> 2 <table cellpadding="0" cellspacing="0" border="0"> 3 <tr height="50">

菜鸟学习Spring——SpringMVC注解版前台向后台传值的两种方式

一.概述. 在很多企业的开法中常常用到SpringMVC+Spring+Hibernate(mybatis)这样的架构,SpringMVC相当于Struts是页面到Contorller直接的交互的框架也是界面把信息传输到Contorller层的一种架构,通过这个架构可以让我们把页面和Contorller层解耦,使得开发人员的分工更加明确. 二.代码演示. 1.首先配置SpringMVC环境. 1.1导入jar. 值得注意的是红色标记的commons-logging这个jar包一定得引入进去不然会

EF5(7) 后台使用SelectListItem传值给前台显示Select下拉框;mvc后台Action接收浏览器传值的4种方式; 后台Action向前台View视图传递数据的四种方式

一:后台使用SelectListItem 传值给前台显示Select下拉框 我们先来看数据库的订单表,里面有3条订单,他们的用户id对应了 UserInfo用户表的数据,现在我们要做的是添加一个Order控制器,显示订单列表,并且在修改订单的时候,把用户的id 用 select 下拉框显示出来,并且可以提交修改数据   1.1 我们通过比较原始的方法,来把数据 传递到前台后,前台使用  循环来显示 select 并且显示是哪个元素被选中 我们在前台的cshtml中,使用 @model 命令 指定

ajax之前台和后台数据传输

Spring中ajax数据传输 由于项目需要用ajax提交数据,而不是form提交数据.因此我需要学习ajax,这也是我在开发小组做的最后一个东西,尽管由于暑假要去东软实训,这个ajax提交也没有做完,但对于数据的在前台和后台的传递是解决了. 如何把数据通过ajax从前台传到后台,在网上查询的方法都是通过"data:"把数据传到后台,但是后台"String endTime=request.getParameter("eTime");"时间的值是空

前台和后台互相传递多维数组

上一篇文章介绍了前台和后台相互传递数组的方法,从客户端传一维数组到服务器可以用jquery的ajax方法直接传递.但如果传递的是多维数组呢? 此时可以借用json的stringify()方法将字符串数组转换为json数组对象传递到后台,后台再使用JSONArray对象的fromObject()方法将其转换为数组即可. 示例: JS代码: $(function(){ var array1 = new Array(); array1.push("A"); array1.push("

C#和JavaScript交互(asp.net前台和后台互调)总结 (转)

http://www.cnblogs.com/poleices/archive/2011/02/24/1963727.html C#代码与javaScript函数的相互调用: 1.如何在JavaScript访问C#函数? 2.如何在JavaScript访问C#变量? 3.如何在C#中访问JavaScript的已有变量? 4.如何在C#中访问JavaScript函数? 问题1答案如下: javaScript函数中执行C#代码中的函数: 方法一:页面和页面类相结合 1.函数声明为public 后台代

js前台与后台数据交互-前台调后台【转】

前台调用后台方法与变量: 方法一:通过WebService来实现 步骤: 后台 ?  首先引入命名空间(using System.Web.Services;) ?  然后定义公共的静态的方法(必须为public和static的,且静态方法不能访问外部的非静态变量,此时后台与前台相当于父类与子类的关系),并在该方法头部上加上[System.Web.Services.WebMethod],来标注方法特性. 前台 ?  添加ScriptManager服务器控件,并把其EnablePageMethods

JS 之 前台调用后台变量和方法

      在我们平时的网站开发过程中,并不是所有的网页都是后台查询出一个DataTable或者List然后绑定到DataGrid上.我们可能还会遇到前台需要后台的某一个变量,或者前台某个显示的地方需要调用一下后台的某一个查询的方法.下面我就给大家列举一个小例子: Asp.Net前台代码: <html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> <meta ht

LigerUi-js中ajax前台调用后台Json格式转换!(已解决)

LigerUi-js中ajax前台调用后台Json格式转换!(已解决) success: function (data, status) { var aaa = JSON2.stringify(data); alert(aaa ); } LigerUi-js中ajax前台调用后台Json格式转换!(已解决),布布扣,bubuko.com