Режим редактирования Gridview не будет изменять свойства текстового поля - PullRequest
0 голосов
/ 18 июля 2011

Мое представление сетки привязано к SqlDataSource и заполняется динамически. Я сталкиваюсь с проблемой изменения свойств текстового поля в режиме редактирования.

protected void gvData_PreRender(object sender, EventArgs e)
{
    if (this.gvData.EditIndex != -1)
        for (int i = 1; i < gvData.Rows[gvData.EditIndex].Cells.Count; i++)
        {
            LinkButton lb = new LinkButton();
            TextBox tb = new TextBox();

            foreach (string pk in Settings.PK)
                if (lb.Text == pk)
                    tb.Enabled = false;
            try
            {
                lb = (LinkButton)gvData.HeaderRow.Cells[i].Controls[0];
                tb = (TextBox)
                    gvData.Rows[gvData.EditIndex].Cells[i].Controls[0];
            }
            catch { }

            if (lb.Text.Contains(Settings.AUTOEXP))
            {
                tb.TextMode = TextBoxMode.MultiLine;
                tb.Rows = 7;
            }

            tb.Text = Truncate.ToText(tb.Text);
            tb.CssClass = "input";
            tb.ID = lb.Text;
        }

    gvData.DataBind();
}

Здесь приложение устанавливает несколько текстовых полей для нескольких строк, и все они имеют класс «input». С gvData.DataBind (); ни одна из модификаций не применяется. Если я удаляю DataBind, он работает. Но здесь я сталкиваюсь с другой проблемой. Я использую эти значения для обновления базы данных.

protected void gvData_RowUpdating(object sender, GridViewUpdateEventArgs e)
{        
    string updateCommand = "UPDATE " + Settings.TABLE + "SET ";
    TextBox tb = new TextBox();

    for (int i = 1; i < gvData.HeaderRow.Cells.Count; i++)
    {
        LinkButton lb = new LinkButton();

        lb = (LinkButton)gvData.HeaderRow.Cells[i].Controls[0];

        try 
        {
            tb = (TextBox)gvData.Rows[e.RowIndex].Cells[i].Controls[0];

            if (tb.Text.Length > 0 && !Settings.PK.Contains(lb.Text))
                try
                {
                    Convert.ToDouble(tb.Text);
                    updateCommand += lb.Text + " = " + tb.Text + ", ";
                }
                catch { updateCommand += lb.Text + " = " + "'" + tb.Text + "', "; } 
        }
        catch { }
    }

    updateCommand = updateCommand.Remove(updateCommand.Length - 2, 2) + " WHERE";

    foreach (string pk in Settings.PK)
    {
        updateCommand += " " + pk + " = :" + pk + " AND";
        DS.UpdateParameters.Add(
            new Parameter(pk, TypeCode.String, e.Keys[pk].ToString()));
    }

    DS.UpdateCommand = updateCommand.Remove(updateCommand.Length - 4, 4);

    gvData.DataBind();
}

Здесь приложение устанавливает команду UpdateCommand для источника данных. Значения получены из текстовых полей. Если я использую gvData.DataBind (); в PreRender я могу получить значения из текстовых полей, но стилизация не работает. Если я не использую DataBind, стилизация wotks, но значения текстовых полей, будут пустыми.

У вас есть предложения? Спасибо заранее!


protected void gvData_RowDataBound(object sender, GridViewRowEventArgs e)
{
    if (e.Row.RowType == DataControlRowType.DataRow)
    {
        for (int i = 1; i < e.Row.Cells.Count; i++)
        {
            try
            {
                LinkButton lb = (LinkButton)gvData.HeaderRow.Cells[i].Controls[0];
                lb.ToolTip = select.ToolTip(lb.Text);

                if (lb.Text.Contains(Settings.AUTOEXP))
                {
                    e.Row.Cells[i].ToolTip =
                        Truncate.ToText(e.Row.Cells[i].Text);
                    e.Row.Cells[i].Text =
                        Truncate.ToText(e.Row.Cells[i].Text
                            .Substring(0, 40)) + "...";
                }

                e.Row.DataItem = lb.Text;
                e.Row.Cells[i].Wrap = false;
            }
            catch { }

        }

        if ((e.Row.RowState & DataControlRowState.Edit) > 0)
        {
            for (int i = 1; i < e.Row.Cells.Count; i++)
            {
                LinkButton lb = new LinkButton();
                TextBox tb = new TextBox();

                foreach (string pk in Settings.PK)
                    if (lb.Text == pk)
                        tb.Enabled = false;
                try
                {
                    lb = (LinkButton)gvData.HeaderRow.Cells[i].Controls[0];
                    tb = (TextBox)
                        e.Row.Cells[i].Controls[0];
                }
                catch { }

                if (lb.Text.Contains(Settings.AUTOEXP))
                {
                    tb.TextMode = TextBoxMode.MultiLine;
                    tb.Rows = 7;
                }

                tb.Text = Truncate.ToText(tb.Text);
                tb.CssClass = "input";
                tb.ID = lb.Text;
            }
        }
    }

    if (e.Row.RowType == DataControlRowType.Footer)
        PopulateFooter(e.Row);

}

Ответы [ 2 ]

1 голос
/ 19 июля 2011

Я бы предложил использовать обработчик событий onrowdatabound для обработки изменения отображения ваших текстовых полей.

0 голосов
/ 20 июля 2011

Разобрался.

Почему-то проблема была в одной строке:

tb.ID = lb.Text; 

Этот код в RowDataBounnd был ненужным.

решение:

В Page_Load добавьте

GridView.DataBind();

RowDataBound:

if ((e.Row.RowState & DataControlRowState.Edit) > 0)
   for (int i = 1; i < e.Row.Cells.Count; i++)
       try
       {
          LinkButton lb = (LinkButton)gvData.HeaderRow.Cells[i].Controls[0];
          TextBox tb = (TextBox)e.Row.Cells[i].Controls[0];

          if (lb.Text.Contains(Settings.AUTOEXP))
          {
              tb.TextMode = TextBoxMode.MultiLine;
              tb.Rows = 7;
          }

          tb.CssClass = "input";
       }
       catch { }

В RowUpdating значение доступно из TextBox.

...