1

編集:誰かが私が以下で試みていることを実現するためのより賢明な方法を提案することもできれば、それも非常にありがたいです

POSTメソッドから(製品の)数量を取得し、その番号に依存するフォームシーケンスを表示するmultiPageフォームを作成しています。ユーザーが次のページに移動すると、フォームはこの情報を収集して(確認のために)表示することになっています。この情報は、表示するURLを提供するサービスに送信されます。

言うまでもなく、私はこの作業を行うのに問題があります。これが私の(匿名化された)コードの関連部分です:

public partial class foo : System.Web.UI.Page
{
    Int quantityParam    = 3;
    ArrayList Users  = new ArrayList();
    //the information for each user is held in a hashtable the array list will be an array list of the user hashtables


protected void Page_Init(object sender, EventArgs e)
{
    if(null != Request["quantity1"])
       { 
             this.quantityParam = Request["quantity1"];
       }
}
protected void Page_Load(object sender, EventArgs e)
{
    int quantity = this.quantityParam;
    if(quantity < 1){ mviewThankYou.SetActiveView(View4Error);} 
    else 
    { //create a form for each user
        mviewThankYou.SetActiveView(View1EnterUsers);
        for(int user = 0;user < quantity; user++)
        {
            createUserForm(user);       
        }
    }   
}
protected void BtnNext1_Click(object sender, EventArgs e)
{
    if(Page.IsValid)
    {
        for(int i = 0; i < quantity; i++)
        {
            String ctrlName = "txtUser" + i.ToString();
            String ctrlEmail = "txtEmail" + i.ToString();
            TextBox name = (TextBox)FindControl(ctrlName);
            TextBox email = (TextBox)FindControl(ctrlEmail);

            /*BONUS QUESTION: How can I add the Hashtables to the Users Array without them being destroyed when I leave the function scope?

            this is where the failure occurs: 
            System.NullReferenceException: Object reference not set to an instance of an object. on: "tempUser.Add("name",name.Text); 
            */

            Hashtable tempUser = new Hashtable();
            tempUser.Add("name",name.Text);
            tempUser.Add("email",email.Text);
            this.Users.Add(tempUser);
        }
        for(int i = 0; i < quantity; i++)
        {
            v2Content.Text +="<table><tr><td>Name: </td><td>"+
            ((Hashtable)Users[i])["name"]+
            "</td></tr><tr><td>Email:</td><td>"+
            ((Hashtable)Users[i])["email"]+
            "</td></tr></table>";
        }
        mviewThankYou.SetActiveView(View2Confirm);
    }
}
private void createUserForm(int userNum){
    DataTable objDT = new DataTable();
        int rows = 2;
        int cols = 2;

    //create the title row..
    TableRow title = new TableRow();
    TableCell titleCell = new TableCell();
    formTable.Rows.Add(title);
    Label lblUser = new Label();
    lblUser.Text = "<b>User "+ (userNum+1) + "</b>";
    lblUser.ID = "lblTitle"+ userNum;
    titleCell.Controls.Add(lblUser);
    title.Cells.Add(titleCell);

    for(int i = 0; i < rows; i++)
    {
        TableRow tRow = new TableRow();     
        formTable.Rows.Add(tRow);
        for(int j = 0; j < cols; j++)
        {
            TableCell tCell = new TableCell();
            if(j == 0){
                Label lblTitle = new Label();
                if(i == 0){
                    lblTitle.Text = "User Name:";
                    lblTitle.ID = "lblUser" + userNum;
                }
                else{
                    lblTitle.Text = "User Email:";
                    lblTitle.ID = "lblEmail" + userNum;
                }
                tCell.Controls.Add(lblTitle);
            } else {
                TextBox txt = new TextBox();
                if(i==0){
                    txt.ID = "txtUser" + userNum;
                }
                else{
                    txt.ID = "txtEmail" + userNum;
                }
                RequiredFieldValidator val = new RequiredFieldValidator();
                val.ID = txt.ID + "Validator";
                val.ControlToValidate = txt.UniqueID;
                val.ErrorMessage = "(required)";

                tCell.Controls.Add(txt);
                tCell.Controls.Add(val);
            }
            tRow.Cells.Add(tCell);
        }//for(j)
    }//for(i)

    //create a blank row...
    TableRow blank = new TableRow();
    TableCell blankCell = new TableCell();
    formTable.Rows.Add(blank);
    Label blankLabel = new Label();
    blankLabel.Text = " ";
    blankLabel.ID = "blank" + userNum;
    blankCell.Controls.Add(blankLabel);
    blank.Cells.Add(blankCell);         

}//CreateUserForm(int)

(アマチュアコード)の恐ろしい量でごめんなさい。失敗した場合に私が疑うのは、FindControl()が機能していないことですが、理由がわかりません...

何か助けがあれば、私はとても素晴らしいと思います。

編集:エラーを表示すると役立つ場合があります:

エラー(112行目)例外の詳細:System.NullReferenceException:オブジェクト参照がオブジェクトのインスタンスに設定されていません。

ソースエラー:

111行目:Hashtable tempUser = new Hashtable();
112行目:tempUser.Add( "name"、name.Text);
113行目:tempUser.Add( "email"、email.Text);
114行目:this.Users.Add(tempUser);

4

2 に答える 2

0

問題は、Page_Loadで毎回フォームをリロードしているという事実にあります。動的テキストボックスをロードするのは1回だけにして、確認のために必要なときにそれらを見つけることができるようにしてください。Page_Loadが再構築されている限り、答えは見つかりません。また、何も見つからないリスクがあります。

于 2009-03-11T17:18:16.843 に答える
0

私はそれを考え出した:

FindControl()は、呼び出されたコントロールの子の直接検索として機能します。

私がそれを呼んでいたとき、それは(自動的に)Page.FindControl()フィールドとテーブルコントロール内にテーブル作成をネストしていました

tableID.FindControl()を呼び出すと、必要に応じてコントロールが見つかりました。

助けてくれてありがとう、グレゴリー、そしてみんなのコメントをありがとう。

-マット

于 2009-03-13T19:28:32.103 に答える