View Full Version : سوال: نمایس یک سطر از grid view در lable
barbii
شنبه 21 مرداد 1391, 16:01 عصر
سلام
میخوام مقدار یک سطر از grid view داخل یه lable نمایش داده بشه با find control
alonemm
شنبه 21 مرداد 1391, 16:22 عصر
باسلام:
در قالب یک پروژه:
فرض کنید که این وب فرم ما هست که به کدش به شکل زیر هست که دارای یک کنترل گرید و یک شی اتصال به پایگاه داده SQL:
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>GridView Select Example</title>
</head>
<body>
<form id="form1" runat="server">
<h3>GridView Select Example</h3>
<asp:gridview id="CustomersGridView"
datasourceid="CustomersSource"
autogeneratecolumns="False"
autogenerateselectbutton="True"
allowpaging="True"
selectedindex="1"
onselectedindexchanged="CustomersGridView_SelectedIndexChanged"
runat="server" DataKeyNames="CustomerID">
<Columns>
<asp:BoundField DataField="CustomerID"
HeaderText="CustomerID"
InsertVisible="False" ReadOnly="True"
SortExpression="CustomerID" />
<asp:BoundField DataField="FirstName"
HeaderText="FirstName"
SortExpression="FirstName" />
<asp:BoundField DataField="MiddleName"
HeaderText="MiddleName"
SortExpression="MiddleName" />
<asp:BoundField DataField="LastName"
HeaderText="LastName"
SortExpression="LastName" />
<asp:BoundField DataField="Phone"
HeaderText="Phone"
SortExpression="Phone" />
</Columns>
<selectedrowstyle backcolor="LightCyan"
forecolor="DarkBlue"
font-bold="true"/>
</asp:gridview>
<br/>
<asp:label id="MessageLabel"
forecolor="Red"
runat="server"/>
<!-- This example uses Microsoft SQL Server and connects -->
<!-- to the Northwind sample database. Use an ASP.NET -->
<!-- expression to retrieve the connection string value -->
<!-- from the Web.config file. -->
<asp:sqldatasource id="CustomersSource"
selectcommand="SELECT CustomerID, FirstName, MiddleName, LastName, Phone FROM SalesLT.Customer"
connectionstring="<%$ ConnectionStrings:AdventureWorksLTConnectionString %>"
runat="server"/>
</form>
</body>
</html>
خب با انتخاب هر ردیف از شی گرید به مقدار اون در لیبل دسترسی دارید همانند زیر:
void CustomersGridView_SelectedIndexChanged(Object sender, EventArgs e)
{
// Get the currently selected row using the SelectedRow property.
GridViewRow row = CustomersGridView.SelectedRow;
// Display the company name from the selected row.
// In this example, the third column (index 2) contains
// the company name.
MessageLabel.Text = "You selected " + row.Cells[2].Text + ".";
}
موفق باشید.
barbii
شنبه 21 مرداد 1391, 17:17 عصر
باسلام:
در قالب یک پروژه:
فرض کنید که این وب فرم ما هست که به کدش به شکل زیر هست که دارای یک کنترل گرید و یک شی اتصال به پایگاه داده SQL:
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>GridView Select Example</title>
</head>
<body>
<form id="form1" runat="server">
<h3>GridView Select Example</h3>
<asp:gridview id="CustomersGridView"
datasourceid="CustomersSource"
autogeneratecolumns="False"
autogenerateselectbutton="True"
allowpaging="True"
selectedindex="1"
onselectedindexchanged="CustomersGridView_SelectedIndexChanged"
runat="server" DataKeyNames="CustomerID">
<Columns>
<asp:BoundField DataField="CustomerID"
HeaderText="CustomerID"
InsertVisible="False" ReadOnly="True"
SortExpression="CustomerID" />
<asp:BoundField DataField="FirstName"
HeaderText="FirstName"
SortExpression="FirstName" />
<asp:BoundField DataField="MiddleName"
HeaderText="MiddleName"
SortExpression="MiddleName" />
<asp:BoundField DataField="LastName"
HeaderText="LastName"
SortExpression="LastName" />
<asp:BoundField DataField="Phone"
HeaderText="Phone"
SortExpression="Phone" />
</Columns>
<selectedrowstyle backcolor="LightCyan"
forecolor="DarkBlue"
font-bold="true"/>
</asp:gridview>
<br/>
<asp:label id="MessageLabel"
forecolor="Red"
runat="server"/>
<!-- This example uses Microsoft SQL Server and connects -->
<!-- to the Northwind sample database. Use an ASP.NET -->
<!-- expression to retrieve the connection string value -->
<!-- from the Web.config file. -->
<asp:sqldatasource id="CustomersSource"
selectcommand="SELECT CustomerID, FirstName, MiddleName, LastName, Phone FROM SalesLT.Customer"
connectionstring="<%$ ConnectionStrings:AdventureWorksLTConnectionString %>"
runat="server"/>
</form>
</body>
</html>
خب با انتخاب هر ردیف از شی گرید به مقدار اون در لیبل دسترسی دارید همانند زیر:
void CustomersGridView_SelectedIndexChanged(Object sender, EventArgs e)
{
// Get the currently selected row using the SelectedRow property.
GridViewRow row = CustomersGridView.SelectedRow;
// Display the company name from the selected row.
// In this example, the third column (index 2) contains
// the company name.
MessageLabel.Text = "You selected " + row.Cells[2].Text + ".";
}
موفق باشید.
ممنون از راهنمایی تون دوست عزیز
در حقیقت من میخوام لیست نمرات دانش آموزان که داخل یک grid view هستو با یه تکس باکس دریافت کنم و همراه با شماره دانش آموزی در بانک ذخیره کنم می خوام تک تک همه رکوردا رو بدست بیاره و ذخیره کنه
alonemm
شنبه 21 مرداد 1391, 18:14 عصر
ممنون از راهنمایی تون دوست عزیز
در حقیقت من میخوام لیست نمرات دانش آموزان که داخل یک grid view هستو با یه تکس باکس دریافت کنم و همراه با شماره دانش آموزی در بانک ذخیره کنم می خوام تک تک همه رکوردا رو بدست بیاره و ذخیره کنه
درود:
به عنوان مثال به شکل زیر عمل کنید:
protected void ImageButton1_Click(object sender, ImageClickEventArgs e)
{
foreach (GridViewRow row in GridView1.Rows)
{
//for templated control
TextBox tb = row.FindControl("yourtextboxid") as TextBox;
//for bound field
string str = row.Cells[yourcellindex];
}
}
و یا:
for (int i = 0; i < GridView1.Rows.Count ;i++)
{
String str;
//To Read a TextBox in First Column
TextBox txt = (TextBox)GridView1.Rows[i].Cells[0] .FindControl("txtFirstName");
str = txt.Text;
//To Read a Label in First Column
Label lbl = (Label)GridView1.Rows[i].Cells[0].FindControl("LabelFirstName");
str = lbl.Text;
//To Read a Cell in First Column
str = GridView1.Rows[i].Cells[0].Text ;
}
vBulletin® v4.2.5, Copyright ©2000-1404, Jelsoft Enterprises Ltd.