Сбор данных: динамические текстовые поля - PullRequest
1 голос
/ 09 марта 2009

Редактировать: если бы кто-то мог также предложить более разумный способ сделать то, что я пытаюсь сделать ниже, это также было бы очень ценно

Я создаю многостраничную форму, которая берет количество (продукта) из метода POST и отображает последовательность форм, основываясь на этом числе. когда пользователь переходит на следующую страницу, форма должна собирать эту информацию и отображать ее (для подтверждения), которая затем отправит эту информацию службе, которая предоставит 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.Text);
Строка 113: tempUser.Add («email», email.Text);
Строка 114: this.Users.Add (tempUser);

Ответы [ 2 ]

0 голосов
/ 13 марта 2009

Я понял это:

FindControl () работает как прямой поиск дочерних элементов вызываемого элемента управления.

когда я звонил, это было (автоматически) Page.FindControl () Я вложил создание таблицы в поле и элемент управления Table

когда я вызвал tableID.FindControl (), он нашел элементы управления точно так же, как и должен.

Спасибо за помощь, Грегори, и за все комментарии.

Матф

0 голосов
/ 11 марта 2009

Ваша проблема заключается в том, что вы каждый раз перезагружаете форму в Page_Load. Убедитесь, что вы загружаете динамические текстовые поля только один раз, и вы сможете найти их, когда они понадобятся для подтверждения. Пока Page_Load перестраивается, вы не найдете ответа и рискуете ничего не найти.

...