簡體   English   中英

為什么我的GridView不顯示?

[英]Why doesn't my GridView show up?

編輯:我忘了綁定數據表(哎呀),現在已修復。 該程序現在崩潰了,為什么我也感到困惑。

我正在制作一個網站,我想在該網站上顯示其行和列切換的數據表。 我寫了一些C#來做到這一點。 我的代碼可以編譯並運行而不會崩潰,但是我放置這些數據的gridview從未顯示出來。 如果我刪除將數據綁定到gridview的代碼,而是使用sql源連接,它將顯示(但顯然不會翻轉)。

為什么我的gridview不顯示,我該如何解決?

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 MachineUpdateFrontEnd
{
    public partial class NewUpdate : System.Web.UI.Page
    {
        DataSet input;
        DataSet output;

        protected void Page_Load(object sender, EventArgs e)
        {
            DataSet temp = pullData(UpdateSqlDataSource.ConnectionString);
            input = SwitchRows(temp);
            GridView1.DataSource = input.Tables[0];
        }

        private DataSet pullData(string ConStr) {
            DataSet ds = new DataSet();
            SqlDataAdapter adp = new SqlDataAdapter("select * from MachineUpdate", ConStr);
            adp.Fill(ds, "MachineUpdate");
            return ds;
        }

        private void pushData() {
            output = SwitchRows(input);
        }

        private DataSet SwitchRows(DataSet input)
        {
            DataSet ds = new DataSet();

            foreach (DataTable dt in input.Tables) {
                DataTable inputTable = new DataTable();
                for (int i = 0; i < dt.Rows.Count; i++) {
                    inputTable.Columns.Add(Convert.ToString(i));
                }
                DataRow r;
                for (int j = 0; j < dt.Columns.Count; j++) {
                    r = inputTable.NewRow();
                    r[0] = dt.Columns[j].ToString();
                    for (int k = 1; k < dt.Rows.Count; k++) {
                        r[k] = dt.Rows[k - 1][j];
                    }
                    inputTable.Rows.Add(r);
                }
                ds.Tables.Add(inputTable);
            }
            return ds;
        }
    }
}

ASP:

<%@ Page Title="" Language="C#" MasterPageFile="~/Master.Master" AutoEventWireup="true" CodeBehind="NewUpdate.aspx.cs" Inherits="MachineUpdateFrontEnd.NewUpdate" %>
<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="server">
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="body" runat="server">
    <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="True" DataKeyNames="UpdateID" style="margin-top: 0px" ShowHeaderWhenEmpty ="true">
        <Columns>
            <asp:BoundField DataField="UpdateID" HeaderText="UpdateID" InsertVisible="False" ReadOnly="True" SortExpression="UpdateID" />
            <asp:BoundField DataField="MachineID" HeaderText="MachineID" SortExpression="MachineID" />
        </Columns>
    </asp:GridView>
    <asp:SqlDataSource ID ="UpdateSqlDataSource" runat ="server" ConnectionString="<%$ ConnectionStrings:MachineUpdateDataBaseConnectionString %>" SelectCommand="SELECT * FROM [MachineUpdate MQ]">

    </asp:SqlDataSource>
</asp:Content>

整個項目:

https://github.com/Darokrithia/MachineUpdateFrontEnd

我看不到您正在將GridView與數據源綁定

GridView1.DataSource = input.Tables[0];
GridView1.DataBind();   //missing data binding

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM