ASP.NET: когда и как динамически изменять headerText Gridview в коде позади?
У меня есть gridview с 2 столбцами. Я хочу изучать кодирование и не хочу делать это в файле ASPX. Как установить текст заголовка для моих столбцов динамически? В какой момент я это делаю? После того, как адаптер заполнил gridview данными? Прямо сейчас у меня есть текст заголовка, но он точно совпадает с именем поля данных, которое является last_name, и я хочу вместо этого видеть Фамилию в поле заголовка. я пробовал
GridView1.Columns[0].HeaderText = "Last Name";
но где бы я ни пытался это выразить, компилятор жалуется, что индекс находится вне диапазона.
Благодарю.
код aspx для вида сетки:
<asp:GridView ID="GridView1" runat="server" AllowPaging="True" AllowSorting="True"
BackColor="White" BorderColor="#DEDFDE" BorderStyle="None" BorderWidth="1px"
Width="728px" CellPadding="4" ForeColor="Black" GridLines="Vertical" OnPageIndexChanging="GridView1_PageIndexChanging"
OnSorting="GridView1_Sorting" PageSize="14" OnRowDataBound="GridView1_RowDataBound">
<AlternatingRowStyle BackColor="White" />
<FooterStyle BackColor="#CCCC99" />
<HeaderStyle BackColor="#6B696B" Font-Bold="True" ForeColor="White" />
<PagerStyle BackColor="#F7F7DE" ForeColor="Black" HorizontalAlign="Right" />
<RowStyle BackColor="#F7F7DE" />
<SelectedRowStyle BackColor="#CE5D5A" Font-Bold="True" ForeColor="White" />
<SortedAscendingCellStyle BackColor="#FBFBF2" />
<SortedAscendingHeaderStyle BackColor="#848384" />
<SortedDescendingCellStyle BackColor="#EAEAD3" />
<SortedDescendingHeaderStyle BackColor="#575357" />
<PagerSettings Mode="NumericFirstLast" FirstPageText="First" LastPageText="Last"
PageButtonCount="5" Position="Bottom" />
</asp:GridView>
3 ответа
Попробуйте поместить его в обработчик GridView1.RowDataBound. Оцените e.Row.RowType, чтобы определить, является ли это строкой заголовка, а затем замените HeaderText.
protected void GridView1_RowDataBound(object sender, System.Web.UI.WebControls.GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.Header) {
GridView1.Columns[0].HeaderText = "Last Name";
}
}
Однако если вы динамически создаете столбцы и используете сортировку, вам нужно будет подойти к этому так, чтобы предотвратить случайное преобразование ссылки для сортировки в простой текст:
protected void GridView1_RowDataBound(object sender, System.Web.UI.WebControls.GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.Header) {
LinkButton HLink = (LinkButton)e.Row.Cells[0].Controls[0];
HLink.Text = "Last Name";
}
}
С помощью любого добавьте этот атрибут к вашему Gridview в ASPX:
OnRowDataBound="GridView1_RowDataBound"
Добавить в Page_Load, но
GridView1.Columns[0].HeaderText = "Last Name";
не будет работать, так как будет жаловаться, что количество столбцов равно 0, поэтому сделайте это:
protected void grdProd_Load(object sender, EventArgs e)
{
grdProd.HeaderRow.Cells[0].Text = "Item";
grdProd.HeaderRow.Cells[1].Text = "Category";
}
Я не думаю, что вы хотите связывать текст для вашего заголовка во время каждого события связывания данных строки (1 раз для каждой строки) в вашей таблице!
Просто подключите событие Loaded для страницы и затем привяжите текст там, как он был у вас.
protected void Page_Load(object sender, EventArgs e)
{
GridView1.Columns[0].HeaderText = "Last Name";
}
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="grdvw8.aspx.cs" Inherits="grdvw8" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>
first header name change To<asp:TextBox ID="txt1" runat="server"></asp:TextBox>
<br />
Second header name change To<asp:TextBox ID="txt2" runat="server"></asp:TextBox>
<br />
<asp:Button ID="btnChange" Text="Change Header Text" runat="server" onclick="btnChange_Click" />
<asp:GridView ID="grdvw" runat="server">
<HeaderStyle Font-Bold="true" ForeColor="Brown" />
</asp:GridView>
</div>
</form>
</body>
</html>
/ASPX.CS PAGE/
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
using System.Data.SqlClient;
using System.Configuration;
public partial class grdvw8 : System.Web.UI.Page
{
SqlConnection con = new SqlConnection(ConfigurationManager.ConnectionStrings["code"].ConnectionString);
protected void Page_Load(object sender, EventArgs e)
{
Bind();
}
protected void Bind()
{
con.Open();
SqlCommand cmd=new SqlCommand("select * from gridview",con);
SqlDataAdapter da=new SqlDataAdapter(cmd);
DataSet ds=new DataSet();
da.Fill(ds);
grdvw.DataSource = ds;
grdvw.DataBind();
}
protected void btnChange_Click(object sender, EventArgs e)
{
if (grdvw.Rows.Count > 0)
{
grdvw.HeaderRow.Cells[0].Text = txt1.Text;
grdvw.HeaderRow.Cells[1].Text = txt2.Text;
}
}
}