JavaScript:__doPostBack中的多个参数

首先,我发现这个唯一的帖子( calling-multiple-dopostback-from-javascript)没有帮助我的问题,所以我不相信这个帖子是重复的.

我的ASPX网页中包含一个__doPostBack函数的JavaScript函数

function OpenSubTable(bolID,controlID) {
  // code
  __doPostBack('UpdatePanelSearch',bolID);
  // more code
}

完美的工作,我可以得到bolID的价值在我的代码如下:

protected void UpdatePanelSearch_Load(object sender,EventArgs e)
{
  var bolID = Request["__EVENTARGUMENT"];
  // code
}

问题是,我必须通过回发传递2个不同的值.有什么简单的解决方案吗?显然这样的东西不行:

function OpenSubTable(bolID,bolID,controlID); // not that simple,i'm afraid :(
  // more code
}

任何帮助将是最受欢迎的.

问候,
贡纳尔

解决方法

您可以将两个值作为JSON字符串传递:
function OpenSubTable(bolID,controlID) {
  __doPostBack('UpdatePanelSearch',JSON.stringify({ bolID: bolID,controlID: controlID}));
}

然后在服务器上解析它:

protected void UpdatePanelSearch_Load(object sender,EventArgs e)
{
  SomeDTO deserializedArgs = 
      JsonConvert.DeserializeObject<SomeDTO>(Request["__EVENTARGUMENT"]);
  var bolID = deserializedArgs.bolID;
  var controlID = deserializedArgs.controlID;
}

public class SomeDTO
{
    public string bolID { get; set; }
    public string controlID { get; set; }
}

如果你使用的是.Net> = 4.0,我相信你可以反序列化一个通用的组合,并避免创建SomeDTO.编辑:More information about deserializing to dynamic types.

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...