0

我有一个显示一些搜索结果的网格视图。但是在不同的搜索结果中,我看到了这个 gridview 的不同大小,而且外观并不好看。这里是:

在此处输入图像描述

在此处输入图像描述

如您所见,听证会和行的大小发生了变化。这是gridview的代码:

<asp:GridView ID="searchResults" runat="server" AutoGenerateColumns="False" OnSelectedIndexChanged="searchResults_SelectedIndexChanged"
    BackColor="White" BorderColor="White" BorderStyle="None" BorderWidth="1px" CellPadding="4"
    ForeColor="Black" GridLines="Vertical" style="margin-right: 0px" Width="1018px" 
                Height="192px">
    <RowStyle BackColor="#F7F7DE" />
    <Columns>
        <asp:TemplateField>
            <ItemTemplate>
                <asp:CheckBox ID="checkboxRegister" runat="server" />
            </ItemTemplate>
        </asp:TemplateField>
        <asp:BoundField DataField="CRN" HeaderText="CRN" />
        <asp:BoundField DataField="CourseCode" HeaderText="Course Code" />
        <asp:BoundField DataField="CourseNumber" HeaderText="Course Number" />
        <asp:BoundField DataField="Credit" HeaderText="Credit" />
        <asp:BoundField DataField="CourseName" HeaderText="Course Name" />
        <asp:BoundField DataField="Capacity" HeaderText="Capacity" />
        <asp:BoundField DataField="InstructorName" HeaderText="Instructor" />
        <asp:BoundField DataField="Level" HeaderText="Level" />
    </Columns>
    <FooterStyle BackColor="#CCCC99" />
    <PagerStyle BackColor="#F7F7DE" ForeColor="Black" HorizontalAlign="Right" />
    <SelectedRowStyle BackColor="#9E51CF" Font-Bold="True" ForeColor="White" />
    <HeaderStyle BackColor="#564D94" Font-Bold="True" ForeColor="White" />
    <AlternatingRowStyle BackColor="White" />
</asp:GridView>

这是我绑定数据的方式:

protected void BClassSearch_Click(object sender, EventArgs e)
{
        SqlConnection con = new SqlConnection();
        con.ConnectionString = Userfunctions.GetConnectionString();
        con.Open();
        string selected = lbCourseListBox.SelectedValue;

       if(selected!="" && Tcoursenumber.Text!="")
       {
           string query="";
           if(MyGlobals.student.getLevel()=="Undergraduate")
              query = "select [CRN],[CourseCode],[CourseNumber],[Credit],[CourseName],[Capacity],[InstructorName],[Level] from CourseTable where CourseCode='" + lbCourseListBox.SelectedValue+"' and CourseNumber = '" + Tcoursenumber.Text+"'" + "' and Level='Undergraduate";
           else
               query="select [CRN],[CourseCode],[CourseNumber],[Credit],[CourseName],[Capacity],[InstructorName],[Level] from CourseTable where CourseCode='" + lbCourseListBox.SelectedValue+"' and CourseNumber = '" + Tcoursenumber.Text+"'";

            SqlDataAdapter adap = new SqlDataAdapter(query, con);

            DataTable tab = new DataTable();

            adap.Fill(tab);

            searchResults.DataSource = tab;
            searchResults.DataBind();
       }
       else if (selected != "" && Tcoursenumber.Text == "")
       {
           string query = "";
           if (MyGlobals.student.getLevel() == "Undergraduate") 
              query = "select [CRN],[CourseCode],[CourseNumber],[Credit],[CourseName],[Capacity],[InstructorName],[Level] from CourseTable where CourseCode='" + lbCourseListBox.SelectedValue+"' and Level='Undergraduate'";
           else
               query = "select [CRN],[CourseCode],[CourseNumber],[Credit],[CourseName],[Capacity],[InstructorName],[Level] from CourseTable where CourseCode='" + lbCourseListBox.SelectedValue + "'";

           SqlDataAdapter adap = new SqlDataAdapter(query, con);

           DataTable tab = new DataTable();

           adap.Fill(tab);

           searchResults.DataSource = tab;
           searchResults.DataBind();
       }
       else if (selected == "" && Tcoursenumber.Text != "")
       {
           string query="";

           if(MyGlobals.student.getLevel()=="Undergraduate")
                query = "select [CRN],[CourseCode],[CourseNumber],[Credit],[CourseName],[Capacity],[InstructorName],[Level] from CourseTable where CourseNumber='" + Tcoursenumber.Text+"' and Level='Undergraduate'";
           else
               query = "select [CRN],[CourseCode],[CourseNumber],[Credit],[CourseName],[Capacity],[InstructorName],[Level] from CourseTable where CourseNumber='" + Tcoursenumber.Text + "'";
           SqlDataAdapter adap = new SqlDataAdapter(query, con);

           DataTable tab = new DataTable();

           adap.Fill(tab);

           searchResults.DataSource = tab;
           searchResults.DataBind();
       }
       else if (selected == "" && Tcoursenumber.Text == "")
       {
           string query = "";

           if(MyGlobals.student.getLevel()=="Undergraduate")
                query = "select [CRN],[CourseCode],[CourseNumber],[Credit],[CourseName],[Capacity],[InstructorName],[Level] from CourseTable where Level='Undergraduate' order by CourseCode";
           else
                query = "select [CRN],[CourseCode],[CourseNumber],[Credit],[CourseName],[Capacity],[InstructorName],[Level] from CourseTable order by CourseCode";

           SqlDataAdapter adap = new SqlDataAdapter(query, con);

           DataTable tab = new DataTable();

           adap.Fill(tab);

           searchResults.DataSource = tab;
           searchResults.DataBind();
       }
}

谁能告诉我如何解决这个问题?我很感激这里的任何帮助。谢谢。

4

1 回答 1

0

为每个项目设置宽度和高度,如下所示:

<asp:BoundField DataField="Credit" HeaderText="Credit"  HeaderStyle-Width="100" HeaderStyle-Height="20" ItemStyle-Height="20" ItemStyle-Width="100" />

或者添加 1(或 2)个 CSS 样式并为每个项目添加它们:

<asp:BoundField DataField="CourseName" HeaderText="Course Name"  ItemStyle-CssClass="style1" HeaderStyle-CssClass="style" />

如果只需要指定高度(显然),则可以只设置高度。

于 2013-06-03T14:51:00.423 回答