Как добавить кнопку ссылки, используя datatable в качестве источника данных в gridview динамически? - PullRequest
1 голос
/ 17 января 2012

Здесь я сделал все из codebehind. Я динамически создал вид сетки.

DataTable dt = null;
dt = loadDynamicGrid (columnname, ds);

GridView grdnew = newGridView ();

grdnew.DataSource = dt;

grdnew.DataBind ();

private DataTable loadDynamicGrid(string [] column,DataSet ds)
{       
    #region Code for preparing the DataTable

    DataTable dt = new DataTable();

    //Create an ID column for adding to the Datatable
    DataColumn dcol ;//= new DataColumn(ID1, typeof(System.Int32));
    ButtonColumn btncolm;
    HyperLinkColumn hplink;

    for (int i = 0; i < column.Count(); i++)
    {
        if (column[i] != "" & column[i]!=null)
        {
            if (column[i] == "BUY" || column[i] == "Buy" || column[i] == "BuyNow" || column[i] == "Details" || column[i] == "ViewDetails" || column[i] == "BuyQty" || column[i] == "Purchase")
            {
                //btncolm = new ButtonColumn();
                //btncolm.HeaderText = column[i];
                //btncolm.Text = column[i];

                //dt.Columns.Add(btncolm.Text);
                hplink = new HyperLinkColumn();

                hplink.HeaderImageUrl = "http://www.google.com";
                hplink.HeaderText = column[i];
                hplink.Text = column[i];
                dt.Columns.Add(hplink.Text);

            }
            else
            {
                dcol = new DataColumn(column[i], typeof(System.String));
                dt.Columns.Add(dcol);
            }
        }
    }

    int k=0;

    foreach (DataRow dr in ds.Tables[0].Rows)
    {
        DataRow myrow = dt.NewRow();
        for (int j = 0; j < column.Count(); j++)
        {
            if (column[j] != "" & column[j] != null)
            {

                string sdfsd = Convert.ToString(dr[column[j]]);
                if (column[j] == "BUY" || column[j] == "Buy" || column[j] == "BuyNow" || column[j] == "Details" || column[j] == "ViewDetails" || column[j] == "BuyQty" || column[j] == "Purchase")
                {
                   //myrow[column[j]] = "http://www.google.com1/";
                   myrow[column[j]] = dr[column[j]];
                }                    
                else
                {
                    if (Convert.ToString(dr[column[j]]).TrimEnd() == "&nbsp;")
                    {
                        myrow[column[j]] = "";
                    }
                    else
                    {
                        myrow[column[j]] = dr[column[j]];
                    }
                }
                if (column[j] == "Stock" || column[j] == "QtyInStock" || column[j] == "Qty" || column[j] == "Available" || column[j].ToLower() == "onhand" || column[j] == "QuantityOnHand" || column[j] == "QtyAvailable" || column[j] == "InStock" || column[j] == "Avail" || column[j] == "Inventory" || column[j] == "Quantity" || column[j] == "Availability")
                {
                    if (Convert.ToString(dr[column[j]]) != "0" && Convert.ToString(dr[column[j]]) != "" && dr[column[j]] != null && Convert.ToString(dr[column[j]]).TrimEnd()!="&nbsp;")
                    {
                        stock = dr[column[j]].ToString();
                    }
                }

            }
        }
        k++;
        dt.Rows.Add(myrow);          

    }       

    #endregion

    column = null;

    return dt;      
}

Затем я добавляю в div каждый раз, как:

mydiv.Controls.Add (grdnew);

, как указано выше, я повторяю цикл для разных таблиц данных для привязки к gridview. Здесь мне нужна кнопка ссылки на gridview. Поэтому я добавил столбец гиперссылки в datatable, но я не получаю никаких ссылок в сетке. У меня есть более 20 таблиц данных для привязки к сетке. Поэтому я предпочел динамически создавать сетку.

Ответы [ 2 ]

3 голосов
/ 23 января 2012

Просто замените сетку сеткой данных и добавьте столбец гиперссылки в таблицу данных и передайте данные в этот столбец, щелкнув меня

DataTable dt=new DataTable();

HyperLinkColumn hplink = new HyperLinkColumn();
hplink.Text = column1[i];
dt.Columns.Add(hplink.Text);

DataRow myrow = dt.NewRow();
myrow[column1[l]] = String.Format("<a href='" + imageUrl(gettablename(tablename)) + "' target='_blank'>" + dr[column[j]] + "</a>");

 dt.Rows.Add(myrow);
 DataGrid1.DataSource=dt;
 DataGrid1.DataBind();

Вот и все проблемы.

1 голос
/ 17 января 2012
    TableCell tc1 = new TableCell();
tc1.Wrap=true;
this.lnkRecvGpNo=new LinkButton();
lnkRecvGpNo.Text="RecvGp No";
this.lnkRecvGpNo.Click+=new EventHandler(lnkRecvGpNo_Click);
tc1.Controls.Add(lnkRecvGpNo);
...