当前位置:编程学习 > C#/ASP.NET >>

新手求解:泛型绑定gridview与dataset绑定的gridview,有什么区别?

--------------------编程问答-------------------- 用泛型的好处很大哦,打到哪里? 性能好把! --------------------编程问答-------------------- 谢谢 不需要顶贴 需要高手给答案 谢谢 --------------------编程问答--------------------  那你等把! 劝你最好别用这个控件了,垃圾控件,用别的都比他爽! --------------------编程问答-------------------- 那是因为你在RowDataBound事件中使用了gridview.rows.count
那个时候正在将数据源一行一行绑定至控件,所以无法给你返回真实的行数
你可以在Page级的事件中绑定数据源后使用 --------------------编程问答--------------------
建议别用gridview,会有一些没用的代码 --------------------编程问答-------------------- 在rowdatabound这个事件中e.row.cells[0].text往往取值为空,但是用dataset绑定的话就不会为空,这个需要怎么解决? --------------------编程问答-------------------- Gridview 绑定list 

gridview要自己绑定列
<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False">
    <Columns>
    <asp:TemplateField HeaderText="学号">
    <ItemTemplate >
    <%# ((visitor)Container.DataItem).Vid %>
    </ItemTemplate>
    </asp:TemplateField>
    <asp:TemplateField HeaderText="姓名">
    <ItemTemplate>
    <%# ((visitor)Container.DataItem).Vname %>
    </ItemTemplate>
    </asp:TemplateField>
    <asp:TemplateField HeaderText="地址">
    <ItemTemplate>
    <%# ((visitor)Container.DataItem).Vadd %>
    </ItemTemplate>
    </asp:TemplateField>
    </Columns>
    </asp:GridView>

后台代码
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.Collections;

public partial class _Default : System.Web.UI.Page 
{
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            this.GridView1.DataSource = bind();
            this.GridView1.DataBind();
        }
    }
    
    public List<visitor> bind()
    {
        List<visitor> lt = new List<visitor>();
       
        SqlConnection cn = new SqlConnection("server=.;database=pubs;uid=sa;pwd=sa");
        cn.Open();
        SqlCommand cmd = new SqlCommand("select stuid,stuname,stuadd from sj",cn);
        SqlDataReader dr = cmd.ExecuteReader();
        while (dr.Read())
        {   visitor vs = new visitor();
           vs.Vid= dr[0].ToString();
           vs.Vname = dr[1].ToString();
           vs.Vadd = dr[2].ToString();
           lt.Add(vs);
        }
       
        dr.Close();
        return lt;


    }
}
public class visitor
{
   public string Vname;
   public string Vid;
   public string Vadd;
}
--------------------编程问答-------------------- 虽然是高手 但是貌似答非所问  虽然我是新手 但这个简单的绑定方式 我还是会得  只是在绑定的时候  在rowdatabound事件中读不出来row。cell【】。text的值
补充:.NET技术 ,  ASP.NET
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,