簡體   English   中英

名稱“”在當前上下文中不存在

[英]The name ' ' does not exist in the current context

當前上下文Catalog.aspx中不存在名稱“ Label2.Text”

 <asp:DataList ID="DataList1" runat="server" DataKeyField="Id" DataSourceID="SqlDataSource1" RepeatColumns="4" RepeatLayout="Flow">
    <ItemTemplate>
        <div class="Item">
            <div class="name">
                <asp:Label ID="NameLabel" runat="server" Text='<%# Eval("Name") %>' />
            </div>
            <div>
                Код:<asp:Label ID="Label2" runat="server" Text='<%# Eval("Id") %>' />
            </div>
            <img src="<%# Eval("Image") %>" height="115" alt="item"/>
            <div class="price">
                Цена:

                <asp:Label ID="PriceLabel" runat="server" Text='<%# Eval("Price")%>' />p.
                <asp:Button ID="Button2" runat="server" ForeColor="Black" 
                    onclick="Button2_Click" Text="В КОРЗИНУ" />
            </div>
            <div class="desc">
                <asp:Label ID="DescriptionLabel" runat="server" Text='<%# Eval("Description") %>' />

            </div>
        </div>
    </ItemTemplate>
</asp:DataList>

Catalog.aspx.cs

sqlCon.Open();
SqlCommand cmd_SQL = new SqlCommand("INSERT INTO Cart(ClientId,ProductId,Amount) VALUES (@ClientId,@ProductId,@Amount)", sqlCon);
cmd_SQL.Parameters.Add("@ClientId", SqlDbType.NVarChar).Value =Membership.GetUser().ProviderUserKey.ToString();
cmd_SQL.Parameters.Add("@ProductId", SqlDbType.NVarChar).Value =Label2.Text;
cmd_SQL.Parameters.Add("@Amount", SqlDbType.NVarChar).Value = 1;

cmd_SQL.CommandType = CommandType.Text;
cmd_SQL.ExecuteNonQuery();

名稱“ Label2.Text”在當前上下文中不存在

您的標簽位於項目模板的內部,這意味着您不能僅在頁面上的任何舊位置訪問它。 如果要訪問標簽內的值,則需要綁定DataList事件之一,例如OnItemCommand(例如,如果要通過單擊命令按鈕來訪問該值)。 您可以在事件處理程序中使用FindControl訪問該值。 例如:

<asp:DataList runat="server" ID="test" OnItemCommand="test_ItemCommand">
    <ItemTemplate>
        <asp:Label runat="server" ID="Label2" Text="Test" />
    </ItemTemplate>
</asp:DataList>

protected void test_ItemCommand(object source, System.Web.UI.WebControls.DataListCommandEventArgs e)
{
    if (e.Item != null)
    {
        var label2 = e.Item.FindControl("Label2");

        if (label2 != null && label2 is Label)
        {
            var productID = ((Label)label2).Text;

            // now you have the contents of the label's text property
        }
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM