-1

ボタンを押すと、page2 のコントロールから page1 の GridView コントロールにデータを転送する必要があります。(データベースを使用せずに)

データを格納するために DataTable を使用して、それらを列/行に配置しようとしました。

しかし、ボタンをクリックすると、「オブジェクト参照がオブジェクトのインスタンスに設定されていません」という例外が発生します。58 行目 --> DataRow dr = dt.NewRow();

ページ 2 の c# コード:

public partial class WebForm1 : System.Web.UI.Page
{
    //Lastnosti
    public string IDizposoje
    {
        get { return TextBox3.Text; }
    }

    public string Ime
    {
        get { return TextBox1.Text; }
    }

    public string Priimek
    {
        get { return TextBox2.Text; }
    }

    public string DatumIzposoje
    {
        get { return Calendar1.SelectedDate.ToString(); }
    }

    public string DatumVrnitve
    {
        get { return Calendar2.SelectedDate.ToString(); }
    }

    public string VrstaAvtomobila
    {
        get { return ListBox1.SelectedItem.Text; }
    }

    //Koda, ki se izvrši ob zagonu
    protected void Page_Load(object sender, EventArgs e, DataTable dt)
    {         
    }

    //Ob kliku na gumb "Prekliči" zapremo stran
    protected void Button2_Click(object sender, EventArgs e)
    {
        //Response.Redirect("~/Default.aspx");
        this.ClientScript.RegisterClientScriptBlock(this.GetType(), "Close", "window.close()", true);
    }

    //Napolnimo tabelo s podatki
    public void NapolniTabelo(DataTable dt)
    {
        DataRow dr = dt.NewRow();

        dr["ID"] = TextBox3.Text;
        dr["Ime"] = TextBox1.Text;
        dr["Priimek"] = TextBox2.Text;
        dr["Datum izposoje"] = Calendar1.SelectedDate.ToString();
        dr["Datum vrnitve"] = Calendar2.SelectedDate.ToString();
        dr["Vrsta avtomobila"] = ListBox1.SelectedValue.ToString();

        dt.Rows.Add(dr);
    }

    protected void Button1_Click(object sender, EventArgs e)
    {
        NapolniTabelo((DataTable)Session["tabela"]);
        /*Session["ID"] = TextBox3.Text;
        Session["Ime"] = TextBox1.Text;
        Session["Priimek"] = TextBox2.Text;
        Session["Datum izposoje"] = Calendar1.SelectedDate.ToString();
        Session["Datum vrnitve"] = Calendar2.SelectedDate.ToString();
        Session["Vrsta avtomobila"] = ListBox1.SelectedValue.ToString();*/
        Response.Redirect("Default.aspx");
    }

    //Ponastavimo gradnike
    protected void Button3_Click(object sender, EventArgs e)
    {
        TextBox1.Text = "";
        TextBox2.Text = "";
        TextBox3.Text = "";
        Calendar1.SelectedDate = DateTime.Now;
        Calendar2.SelectedDate = DateTime.Now;
        ListBox1.SelectedIndex = 0;
    }
}

ページ 1 の c# コード:

public partial class _Default : System.Web.UI.Page
{
    private DataTable UstvariTabelo()
    {
        DataTable dt = new DataTable();

        dt.Columns.Add(new DataColumn("ID", typeof(string)));
        dt.Columns.Add(new DataColumn("Ime", typeof(string)));
        dt.Columns.Add(new DataColumn("Priimek", typeof(string)));
        dt.Columns.Add(new DataColumn("Datum izposoje", typeof(string)));
        dt.Columns.Add(new DataColumn("Datum vrnitve", typeof(string)));
        dt.Columns.Add(new DataColumn("Vrsta vozila", typeof(string)));

        return dt;
    }

    protected void Page_Load(object sender, EventArgs e)
    {
        WebForm1 druga = new WebForm1();
        DataTable tabela = UstvariTabelo();

        druga.NapolniTabelo(tabela);

        this.GridView1.Visible = true;
        this.GridView1.DataSource = ((DataTable)Session["tabela"]);
        this.GridView1.DataBind();
    }
}

どこで私は間違えましたか?

4

2 に答える 2

2

Session["tabela"] が空であるため、エラーが発生しています。したがって、このコードを挿入します:

(DataTable)Session["tabela"]

常に安全なプロパティを使用します:

public DataTable tabela
{

   get
   {
      if(HttpContext.Current.Session["tabela"] == null)
      {
           HttpContext.Current.Session["tabela"] = new DataTable ("tableName");
      }
      return HttpContext.Current.Session["tabela"] as DataTable;
   }
   set
   {
      HttpContext.Current.Session["tabela"] = value;
   }
}

したがって、null DataTable を取得することはありません。

于 2012-12-01T18:42:10.683 に答える
0
DataRow dr = dt.NewRow(); 

データテーブル オブジェクト (dt) がメモリ内になく、アクセスしようとしているため、例外が発生しています。2 つのページにわたって永続化するには、セッション変数を使用できます。例:

1ページ目:

DataTable dt =  UstvariTabelo(); //I think this method is returning data table in page 1
//load data into dt
Session["test"]  = dt; //save it into a session variable

2 ページ目では、保存されたセッション値を取得できます。

if(Session["test"]!=null)
{
  DataTable dt = (DataTable) Session["test"];
}

また、ページ 1 のコードでは、ページ 2 で取得する前にセッション変数を割り当てていません。

protected void Page_Load(object sender, EventArgs e)
    {
        WebForm1 druga = new WebForm1();
        DataTable tabela = UstvariTabelo();

        druga.NapolniTabelo(tabela);

        this.GridView1.Visible = true;
        Session["tabela"] = tabela;//<--------assign it to session
        this.GridView1.DataSource = tabela;
        this.GridView1.DataBind();
    }
于 2012-12-01T18:33:28.807 に答える