Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,037

HOME > .NET Framework > Forum > ASP.Net DropDownList ไม่แสดง row ถัดไป เดาน่าจะเกี่ยวกับ Index ครับ



 

ASP.Net DropDownList ไม่แสดง row ถัดไป เดาน่าจะเกี่ยวกับ Index ครับ

 



Topic : 114652



โพสกระทู้ ( 33 )
บทความ ( 0 )



สถานะออฟไลน์




Dropdownlist combo ไม่แสดง row ถัดไป เดาน่าจะเกี่ยวกับ Index แต่หาไม่เจอครับ ช่วยทีนะครับ งง TTCode (C#)
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

namespace WebApplication1
{
    public partial class Creat_Cliam_From_A_Add_labour_Quatation : System.Web.UI.Page
    {
        
       // int rowIndex = 0;  
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!Page.IsPostBack)
            {
                
                SetInitialRow();
                BindDropDownList();
            
            }    

        }

        private void SetInitialRow()
        {
           // BindDropDownList();
            DataTable dt = new DataTable();
            DataRow dr = null;
            dt.Columns.Add(new DataColumn("RowNumber", typeof(string)));
            dt.Columns.Add(new DataColumn("Column1", typeof(string)));
            dt.Columns.Add(new DataColumn("Column2", typeof(string)));
            dt.Columns.Add(new DataColumn("Column3", typeof(string)));
            dt.Columns.Add(new DataColumn("Column4", typeof(string)));
            dt.Columns.Add(new DataColumn("Column5", typeof(string)));
            dt.Columns.Add(new DataColumn("Column6", typeof(string)));
           

            dr = dt.NewRow();
            dr["RowNumber"] = 1;
            dr["Column1"] = string.Empty;
            dr["Column2"] = string.Empty;
            dr["Column3"] = string.Empty;
            dr["Column4"] = string.Empty;
            dr["Column5"] = string.Empty;
            dr["Column6"] = string.Empty;
           

            dt.Rows.Add(dr);
            ViewState["CurrentTable"] = dt;
            Gridview1.DataSource = dt;
            Gridview1.DataBind();

        }//end SetInitialRow
        private void addNewRowToGrid()
        {

            
            SqlConnection con = new SqlConnection("Data Source=OMG-NB;Initial Catalog=DB_Modified;Integrated Security=True");
         
           int rowIndex = 0;
            if (ViewState["CurrentTable"] != null)
            {

                DataTable dtCurrentTable = (DataTable)ViewState["CurrentTable"];
                DataRow drCurrentRow = null;
                if (dtCurrentTable.Rows.Count > 0)
                {
                    for (int i = 1; i <= dtCurrentTable.Rows.Count; i++)
                    {
                    
                       
                        DropDownList drop2 = (DropDownList)Gridview1.Rows[rowIndex].Cells[1].FindControl("DropDownList2");
                        TextBox box2 = (TextBox)Gridview1.Rows[rowIndex].Cells[2].FindControl("TextBox2");
                        TextBox box3 = (TextBox)Gridview1.Rows[rowIndex].Cells[3].FindControl("TextBox3");
                        TextBox box4 = (TextBox)Gridview1.Rows[rowIndex].Cells[4].FindControl("TextBox4");
                        TextBox box5 = (TextBox)Gridview1.Rows[rowIndex].Cells[5].FindControl("TextBox5");
                        TextBox box6 = (TextBox)Gridview1.Rows[rowIndex].Cells[6].FindControl("TextBox6");
                       
                        try
                        {
                            
                            Response.Write(drop2);
                            con.Open();


                            SqlCommand cmd = new SqlCommand();
                            cmd.Connection = con;
                         //   Response.Write(drop2.Text);
                           cmd.CommandText = "INSERT INTO [dbo].[Labour]([LaborCode],[Work code],[LaborName],[ModelCar],[LabourHour],[Group])VALUES('" + drop2.SelectedIndex+ "','" + box2.Text + "','" + box3.Text + "','" + box4.Text + "','" + box5.Text + "','" + box6.Text + "')";



       

                            cmd.ExecuteNonQuery();
                        
                       
                           
                          con.Close();

                        }
                        catch
                        {
              



                        }
                        
                        drCurrentRow = dtCurrentTable.NewRow();
                        drCurrentRow["RowNumber"] = i + 1;

                       dtCurrentTable.Rows[i - 1]["Column1"] = drop2.Text;
                        dtCurrentTable.Rows[i - 1]["Column2"] = box2.Text;
                        dtCurrentTable.Rows[i - 1]["Column3"] = box3.Text;
                        dtCurrentTable.Rows[i - 1]["Column4"] = box4.Text;
                        dtCurrentTable.Rows[i - 1]["Column5"] = box5.Text;
                        dtCurrentTable.Rows[i - 1]["Column6"] = box6.Text;
                    
                        rowIndex++;
                   
                     
                      
                    }//end for 
                    dtCurrentTable.Rows.Add(drCurrentRow);
                    ViewState["CurrentTable"] = dtCurrentTable;

                    Gridview1.DataSource = dtCurrentTable;
                    Gridview1.DataBind();        
                }//end if
            }//end if
            else
           {
                Response.Write("ViewState is null");
           }
            //Set Previous Data on Postbacks
           SetPreviousData();
        }//end addNewRowToGrid
        private void SetPreviousData()
        {
            int rowIndex = 0;
            if (ViewState["CurrentTable"] != null)
            {
                DataTable dt = (DataTable)ViewState["CurrentTable"];
                if (dt.Rows.Count > 0)
                {
                    for (int i = 0; i < dt.Rows.Count; i++)
                    {
                        DropDownList drop2 = (DropDownList)Gridview1.Rows[rowIndex].Cells[1].FindControl("DropDownList2");
                        TextBox box2 = (TextBox)Gridview1.Rows[rowIndex].Cells[2].FindControl("TextBox2");
                        TextBox box3 = (TextBox)Gridview1.Rows[rowIndex].Cells[3].FindControl("TextBox3");
                        TextBox box4 = (TextBox)Gridview1.Rows[rowIndex].Cells[4].FindControl("TextBox4");
                        TextBox box5 = (TextBox)Gridview1.Rows[rowIndex].Cells[5].FindControl("TextBox5");
                        TextBox box6 = (TextBox)Gridview1.Rows[rowIndex].Cells[6].FindControl("TextBox6");
                    



                        drop2.Text = dt.Rows[i]["Column1"].ToString();
                        box2.Text = dt.Rows[i]["Column2"].ToString();
                        box3.Text = dt.Rows[i]["Column3"].ToString();
                        box4.Text = dt.Rows[i]["Column4"].ToString();
                        box5.Text = dt.Rows[i]["Column5"].ToString();
                        box6.Text = dt.Rows[i]["Column6"].ToString();
                        rowIndex++;
                 
                       

                    }
                    //BindDropDownList();
                }
                
            }
        }

        protected void ButtonAdd_Click(object sender, EventArgs e)
        {
            addNewRowToGrid();
      
            BindDropDownList();
            
            
            
            
        }

        protected void Button7_Click(object sender, EventArgs e)
        {
            OpenNewWindow("result_labour_search.aspx");
        }//end med
        public void OpenNewWindow(string url)
        {

            ClientScript.RegisterStartupScript(this.GetType(), "newWindow", String.Format("<script>window.open('{0}');</script>", url));

        }

        private void BindDropDownList()
        {
            int rowIndexa = 0;
            
           // DropDownLrowIndexaist ddlCountries = Gridview1.FooterRow.FindControl("ddlCountries") as DropDownList;
           // TextBox box1 = (TextBox)Gridview1.Rows[rowIndex].Cells[1].FindControl("TextBox1");

            SqlConnection connection = new SqlConnection("Data Source=OMG-NB;Initial Catalog=DB_Modified;Integrated Security=True");
            try
            {
                DataTable dt = new DataTable();
                string LaborCode = string.Empty;
                string Workcodee = string.Empty;
                string ModelCar = string.Empty;
                string Equipment = string.Empty;
                string newName = string.Empty;
                

                connection.Open();
                string sqlStatement = "SELECT * FROM Labour";
                SqlCommand sqlCmd = new SqlCommand(sqlStatement, connection);
                SqlDataAdapter sqlDa = new SqlDataAdapter(sqlCmd);
                
                int a = 0;
                sqlDa.Fill(dt);
               if (dt.Rows.Count > 0)
                {
                    for (int i = 0; i <= dt.Rows.Count; i++)
                    {
                            LaborCode = dt.Rows[i]["LaborCode"].ToString();
                            Workcodee = dt.Rows[i]["Work code"].ToString();
                            ModelCar = dt.Rows[i]["ModelCar"].ToString();
                            Equipment = dt.Rows[i]["Equipment"].ToString();

                            newName = LaborCode + " ---- " + Workcodee + "   | " + ModelCar + "   | " + Equipment;
                            DropDownList drop2 = (DropDownList)Gridview1.Rows[rowIndexa].Cells[1].FindControl("DropDownList2");
                            drop2.Items.Add(new ListItem(newName, LaborCode));
                          //  
                  
                    }
                    rowIndexa++;
                      
                }
                

            }
            catch (System.Data.SqlClient.SqlException ex)
            {
                string msg = "Fetch Error:";
                msg += ex.Message;
                throw new Exception(msg);
            }
            catch (Exception ex)
            {
                Response.Write(ex.Message.ToString());
            }
            finally
            {
               // connection.Close();
            }
        }




    }//end class
}

นี้ครับ รัน



Tag : ASP, Web (ASP.NET), C#, VS 2012 (.NET 4.x), Windows







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2015-02-24 17:49:11 By : tongiggabite View : 840 Reply : 1
 

 

No. 1



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Twitter Facebook

Quote:
for (int i = 0; i <= dt.Rows.Count; i++)


น่าจะแค่ < น่ะครับ เพราะมีปัญหาตำแหน่งของ Index ใน Array






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-02-24 21:09:58 By : mr.win
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : ASP.Net DropDownList ไม่แสดง row ถัดไป เดาน่าจะเกี่ยวกับ Index ครับ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

Load balance : Server 01
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2024 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่