C# 回传时如何将control clientID添加到Request.Form集合
我很快就需要帮助 我有一个Gridview,其中的列大部分是“Itemtemplates”,除了呈现时为其中的控件指定的客户端ID之外,没有为它们指定任何特定ID 我目前正在对现有页面进行更改,请求中显示了gridview中控件的少数客户端Id。表单集合和少数不显示。 我需要将客户机ID添加到Request.Form集合中,并在返回到服务器时从那里访问它的值 控件如何/何时添加到Request.Form集合?我对此感到困惑。 我们将非常感谢您的帮助 谢谢 将动态列添加到网格的代码:C# 回传时如何将control clientID添加到Request.Form集合,c#,javascript,asp.net,C#,Javascript,Asp.net,我很快就需要帮助 我有一个Gridview,其中的列大部分是“Itemtemplates”,除了呈现时为其中的控件指定的客户端ID之外,没有为它们指定任何特定ID 我目前正在对现有页面进行更改,请求中显示了gridview中控件的少数客户端Id。表单集合和少数不显示。 我需要将客户机ID添加到Request.Form集合中,并在返回到服务器时从那里访问它的值 控件如何/何时添加到Request.Form集合?我对此感到困惑。 我们将非常感谢您的帮助 谢谢 将动态列添加到网格的代码: else i
else if (Mode != ProductGridMode.Search)
{
grid.Columns.Add(CreateTemplateField(
path + "ProductDetailHeader.ascx",
path + "ProductDetailCell.ascx"));
grid.Columns.Add(CreateTemplateField(
path + "CustomerPartNumberHeader.ascx",
path + "CustomerPartNumberCell.ascx", "td-partnumber"));
grid.Columns.Add(CreateTemplateField(
path + "OrderQuantityHeader.ascx",
path + "OrderQuantityCell.ascx", "td-qty"));
if (Mode == ProductGridMode.OrderHistoryPayments
|| Mode == ProductGridMode.OrderHistoryPaymentsPrintView)
{
grid.Columns.Add(CreateTemplateField(
path + "AvailableToShipHeader.ascx",
path + "AvailableToShipCell.ascx"));
}
grid.Columns.Add(CreateTemplateField(
path + "PriceHeader.ascx",
path + "PriceCell.ascx", "td-price"));
grid.Columns.Add(CreateTemplateField(
path + "ExtendedPriceHeader.ascx",
path + "ExtendedPriceCell.ascx", "td-ext-price"));
if (Mode == ProductGridMode.OrderHistory || Mode == ProductGridMode.OrderHistoryPrintView
|| Mode == ProductGridMode.OrderHistoryPayments || Mode == ProductGridMode.OrderHistoryPaymentsPrintView)
{
grid.Columns.Add(CreateTemplateField(
path + "InvoiceHeader.ascx",
path + "InvoiceCell.ascx"));
grid.EmptyDataTemplate = LoadTemplate(path + "EmptyDataTemplate.ascx");
}
}
else
{
grid.Columns.Add(CreateTemplateField(
path + "ImageHeader.ascx",
path + "ImageCell.ascx"));
grid.Columns.Add(CreateTemplateField(
path + "MouserPartNumberHeader.ascx",
path + "MouserPartNumberCell.ascx"));
grid.Columns.Add(CreateTemplateField(
path + "MfrPartNumberHeader.ascx",
path + "MfrPartNumberCell.ascx"));
grid.Columns.Add(CreateTemplateField(
path + "ManufacturerHeader.ascx",
path + "ManufacturerCell.ascx"));
grid.Columns.Add(CreateTemplateField(
path + "DescriptionHeader.ascx",
path + "DescriptionCell.ascx"));
grid.Columns.Add(CreateTemplateField(
path + "DocumentHeader.ascx",
path + "DocumentCell.ascx"));
grid.Columns.Add(CreateTemplateField(
path + "AvailabilityHeader.ascx",
path + "AvailabilityCell.ascx"));
grid.Columns.Add(CreateTemplateField(
path + "PricingHeader.ascx",
path + "PricingCell.ascx"));
grid.Columns.Add(CreateTemplateField(
path + "QuantityHeader.ascx",
path + "QuantityCell.ascx"));
grid.Columns.Add(CreateTemplateField(
path + "OrderInfoHeader.ascx",
path + "OrderInfoCell.ascx"));
grid.Columns.Add(CreateTemplateField(
path + "RoHSHeader.ascx",
path + "RoHSCell.ascx"));
// Don't include Select column in count
Search_TemplateColumnCount = grid.Columns.Count - CellOffset;
// Due to their nature, the dynamic columns must be created as late as possible which is
// right before databinding instead of here.
}
一个项目模板(我关心的模板)中使用的用户控件的aspx
--%%>
用于用户控制的代码隐藏:
public partial class Controls_ProductGridTemplates_Search_MfgPartNumberCell : System.Web.UI.UserControl
{
protected void Page_PreRender(object sender, EventArgs e)
{
lnkCrossReference.Visible = (lnkCrossReference.NavigateUrl != string.Empty);
}
protected void MfrPartNumberLink_DataBinding(object sender, EventArgs e)
{
SearchResultItem searchItem = BusinessHelper.GetDataItem(this) as SearchResultItem;
MfrPartNumberLink.NavigateUrl = BusinessHelper.BuildProductDetailUrl(searchItem);
//life cycle
if (searchItem.LifeCycle != "")
{
if (!(searchItem.XXXX== false && searchItem.LifeCycle.ToLower().Trim() == "new at mouser"))
{
string lifecycleInfo = Mouser.BOM.ExcelHelper.ProductRules.BuildLifecycleText(searchItem.LifeCycle);
if (lifecycleInfo != "")
PHlifecycle.Controls.Add(new LiteralControl(lifecycleInfo + "<br/><br/>"));
}
}
}
protected void lnkCrossReference_DataBinding(object sender, EventArgs e)
{
SearchResultItem searchItem = BusinessHelper.GetDataItem(this) as SearchResultItem;
if (!string.IsNullOrEmpty(searchItem.CrossReference))
{
StringBuilder crossRefUrlBuilder = new StringBuilder();
crossRefUrlBuilder.Append("~/Search/CrossPopUp.aspx?xpn=");
crossRefUrlBuilder.Append(HttpUtility.UrlEncode(searchItem.MfrPartNumber));
crossRefUrlBuilder.Append("&criteria=");
crossRefUrlBuilder.Append(HttpUtility.UrlEncode(searchItem.CrossReference));
lnkCrossReference.NavigateUrl = crossRefUrlBuilder.ToString();
lnkCrossReference.Attributes.Add("onclick",
"javascript:window.open('" + ResolveUrl(lnkCrossReference.NavigateUrl)
+ "','CatalogPage', 'height=300,width=400,toolbars=no,menubar=no,location=no');return false;");
lnkCrossReference.Text = String.Format(Resources.MyCXXXX.lnkCrossReference, searchItem.CrossReference);
}
}
}
公共部分类控件\u ProductGridTemplates\u Search\u MfgPartNumberCell:System.Web.UI.UserControl
{
受保护的无效页面\u预呈现(对象发送方,事件参数e)
{
lnkCrossReference.Visible=(lnkCrossReference.NavigateUrl!=string.Empty);
}
受保护的void MfrPartNumberLink_数据绑定(对象发送方,事件参数e)
{
SearchResultItem searchItem=BusinessHelper.GetDataItem(this)作为SearchResultItem;
MfrPartNumberLink.NavigateUrl=BusinessHelper.BuildProductDetailUrl(searchItem);
//生命周期
如果(searchItem.LifeCycle!=“”)
{
if(!(searchItem.XXXX==false&&searchItem.LifeCycle.ToLower().Trim()==new at mouser”))
{
字符串lifecycleInfo=Mouser.BOM.ExcelHelper.ProductRules.BuildLifecycleText(searchItem.LifeCycle);
如果(lifecycleInfo!=“”)
PHlifecycle.Controls.Add(新的LiteralControl(lifecycleInfo+“
”);
}
}
}
受保护的void lnkCrossReference_数据绑定(对象发送方,事件参数e)
{
SearchResultItem searchItem=BusinessHelper.GetDataItem(this)作为SearchResultItem;
如果(!string.IsNullOrEmpty(searchItem.CrossReference))
{
StringBuilder crossRefUrlBuilder=新StringBuilder();
crossRefUrlBuilder.Append(“~/Search/CrossPopUp.aspx?xpn=”);
Append(HttpUtility.UrlEncode(searchItem.MfrPartNumber));
crossRefUrlBuilder.Append(“&criteria=”);
Append(HttpUtility.UrlEncode(searchItem.CrossReference));
lnkCrossReference.NavigateUrl=crossRefUrlBuilder.ToString();
lnkCrossReference.Attributes.Add(“onclick”,
“javascript:window.open('”+ResolveUrl(lnkCrossReference.NavigateUrl)
+“,”CatalogPage“,”高度=300,宽度=400,工具栏=no,菜单栏=no,位置=no');返回false;”;
lnkCrossReference.Text=String.Format(Resources.mycxxx.lnkCrossReference,searchItem.CrossReference);
}
}
}
HTML表单中的任何HTML输入
控件
都将包含在请求.表单
集合中。这些值包含在POST操作的HTTP头中
编辑:添加代码
default.aspx
<%@ Page Title="Home Page" Trace="true" Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true"
CodeBehind="Default.aspx.cs" Inherits="SO8362448._Default" %>
<asp:Content ID="HeaderContent" runat="server" ContentPlaceHolderID="HeadContent"> </asp:Content> <asp:Content ID="BodyContent" runat="server" ContentPlaceHolderID="MainContent">
<asp:GridView ID="gridView" runat="server" OnRowDataBound="gridView_rowDataBound" AutoGenerateColumns="false">
<Columns>
<asp:TemplateField>
<ItemTemplate>
<asp:Literal runat="server" Text='<%# Eval("Name") %>' />
<asp:LinkButton id="hyperLink" runat="server" Text="Click Me" />
<asp:HiddenField ID="hiddenField" runat="server" />
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView> </asp:Content>
default.aspx.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace SO8362448
{
public partial class _Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
gridView.DataSource = new List<Person>
{
new Person {Name = "Steve", Age = 21},
new Person {Name = "Cindy", Age = 34}
};
gridView.DataBind();
}
protected void gridView_rowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
LinkButton lb = e.Row.FindControl("hyperLink") as LinkButton;
if (lb != null)
{
HiddenField hf = e.Row.FindControl("hiddenField") as HiddenField;
if (hf != null)
{
hf.Value = lb.Text;
}
}
}
}
}
}
使用系统;
使用System.Collections.Generic;
使用System.Linq;
使用System.Web;
使用System.Web.UI;
使用System.Web.UI.WebControl;
名称空间SO8362448
{
公共部分类\u默认值:System.Web.UI.Page
{
受保护的无效页面加载(对象发送方、事件参数e)
{
gridView.DataSource=新列表
{
新人{Name=“Steve”,年龄=21},
新人{Name=“Cindy”,年龄=34}
};
gridView.DataBind();
}
受保护的void gridView_rowDataBound(对象发送方,GridViewRowEventArgs e)
{
如果(e.Row.RowType==DataControlRowType.DataRow)
{
LinkButton lb=e.Row.FindControl(“超链接”)作为LinkButton;
如果(lb!=null)
{
HiddenField hf=e.Row.FindControl(“HiddenField”)作为HiddenField;
如果(hf!=null)
{
hf.值=磅文本;
}
}
}
}
}
}
您可以添加gridview aspx代码吗?您好,…刚刚用一些代码编辑了我的问题。。。有帮助吗?或者你还需要其他东西吗?假设我正在尝试获取gridview中“超链接”字段的“文本”…如何将其附加到请求?@karry-添加一个类型为hidden的输入字段,并用超链接的文本填充它。这可以在服务器端完成,也可以在客户端使用jQuery。再次感谢Dave..这对我有帮助:)
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace SO8362448
{
public partial class _Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
gridView.DataSource = new List<Person>
{
new Person {Name = "Steve", Age = 21},
new Person {Name = "Cindy", Age = 34}
};
gridView.DataBind();
}
protected void gridView_rowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
LinkButton lb = e.Row.FindControl("hyperLink") as LinkButton;
if (lb != null)
{
HiddenField hf = e.Row.FindControl("hiddenField") as HiddenField;
if (hf != null)
{
hf.Value = lb.Text;
}
}
}
}
}
}