私は本当に奇妙な状況です。 私は新しいaspxページを作成しました。カスタムロジックオブジェクト(ビジュアルスタジオウィザードで作成されたものすべて)を使用せずにsqldatasourceからグリッドビューを作成しようとしました。空のgridview sqldatasourceに値があります
データはストアドプロシージャから取得され、デフォルト値を持つ単一パラメータが使用されます。スキーマをリフレッシュするか「テストクエリ」をクリックすると、結果行が表示され、GridViewsフィールドがcorectly作成されます。しかし、私がページを実行するとグリッドビューは表示されません(EmptyDataTemplateを追加すると表示されます)。私はカスタム(空の)関数とDataBind、DataBinded、RowCretedイベントを追加しましたが、databindイベントとdatavoundイベントのみが起動されます(ただし、デフォルトパラメータの戻り値を持つストアドプロシージャと.netはデザインモード)
手順に「派手な」ものは何もありません。私はこれを何度も問題なく実行しました。私は別のストアドプロシージャのウィッヒは、当社の生産ENVで動作しようとしたし、まだここに同じemtyのGridViewの
を持って、私は見ていないコード
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="TEST.aspx.cs" Inherits="site.TEST" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>Untitled Page</title>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:GridView ID="GridView1" runat="server" DataSourceID="SqlDataSource1"
AllowSorting="True" OnDataBinding="GridView1_DataBinding" OnDataBound="GridView1_DataBound"
OnRowCreated="GridView1_RowCreated">
<EmptyDataTemplate>
No Data Available
</EmptyDataTemplate>
</asp:GridView>
<asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:myConnectionString %>"
SelectCommand="myStoredProcedure" SelectCommandType="StoredProcedure">
<SelectParameters>
<asp:Parameter DefaultValue="val1" Name="par1" Type="String" />
<asp:Parameter Name="val2" Type="Int32" />
</SelectParameters>
</asp:SqlDataSource>
</div>
</form>
</body>
</html>
と分離コード
using System;
using System.Collections;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;
namespace site
{
public partial class TEST : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{//brake here
}
protected void GridView1_RowCreated(object sender, GridViewRowEventArgs e)
{//brake here
}
protected void GridView1_DataBinding(object sender, EventArgs e)
{//brake here
}
protected void GridView1_DataBound(object sender, EventArgs e)
{//brake here
}
}
}
私は感謝していません:) – SimSimY
+1あなたは私を数時間節約しました! :) – meda
ありがとう。 6年後、あなたは私を助けました:-) MSが混乱を生むためにそれをデフォルトで行うのはなぜか分かりません。 –