C# 回传时如何将control clientID添加到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

我很快就需要帮助

我有一个Gridview,其中的列大部分是“Itemtemplates”,除了呈现时为其中的控件指定的客户端ID之外,没有为它们指定任何特定ID

我目前正在对现有页面进行更改,请求中显示了gridview中控件的少数客户端Id。表单集合和少数不显示。 我需要将客户机ID添加到Request.Form集合中,并在返回到服务器时从那里访问它的值

控件如何/何时添加到Request.Form集合?我对此感到困惑。 我们将非常感谢您的帮助

谢谢

将动态列添加到网格的代码:

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;
                    }
                }
            }
        }
    }
}