Telerik RadGrid с различными типами элементов управления для редактирования - PullRequest
4 голосов
/ 16 августа 2010

Я должен отобразить список полей. Некоторые из них доступны для редактирования, а некоторые нет. Это могут быть разные типы, такие как текстовые поля, даты, время или логическое значение. Я использую Telerik RadGrid. Смотрите снимок экрана с тестовым проектом, который я сделал.

Вопросы: В обработчике созданного элемента, почему есть 4 ячейки? Мне пришлось заполнить ячейки [2] и ячейки [3] для отображения значений. Я установил для AutoGenerateColumns значение false, и у меня есть только два определения GridTemplateColumn.

Почему item.RowIndex увеличивается на два и достигает двадцати? Когда у меня 10 рядов.

Есть ли лучший способ сделать это?

Вот как я объявил сетку:

        <telerik:RadGrid runat="server" ID="Grid1" Width="100%" Height="500px" GridLines="None" AutoGenerateColumns="false"
        OnItemCreated="OnGridItemCreated"
        OnNeedDataSource="OnGridNeedDataSource">
        <ItemStyle Wrap="true" />
        <AlternatingItemStyle Wrap="true" />
        <ClientSettings>                    
            <Selecting AllowRowSelect="false" />
            <Scrolling AllowScroll="true" UseStaticHeaders="true" />
            <Resizing AllowColumnResize="true" ClipCellContentOnResize="true" ResizeGridOnColumnResize="true" EnableRealTimeResize="true" />
        </ClientSettings>
        <MasterTableView>
            <NoRecordsTemplate>
                <asp:Label ID="lblNorec1" runat="server" Text="No records"></asp:Label>
            </NoRecordsTemplate>
            <Columns>
                <telerik:GridTemplateColumn UniqueName="FieldDisplayName" HeaderText="Field Name">
                    <ItemTemplate>
                    </ItemTemplate>
                </telerik:GridTemplateColumn>
                <telerik:GridTemplateColumn UniqueName="FieldValue" HeaderText="Value">
                    <ItemTemplate>
                    </ItemTemplate>
                </telerik:GridTemplateColumn>
            </Columns>
        </MasterTableView>
    </telerik:RadGrid>

/

/ grid needs datasource
    protected void OnGridNeedDataSource(object source, GridNeedDataSourceEventArgs e)
    {
        // create a DataSource
        DataSet ds = new DataSet();
        DataTable dt = new DataTable();
        dt.Columns.Add(new DataColumn("Field_Display_Name"));
        dt.Columns.Add(new DataColumn("Field_Value"));

    for (int i = 0; i < 10; ++i)
    {
        DataRow dr = dt.NewRow();
        dr["Field_Display_Name"] = "Item Id" + i.ToString();
        dr["Field_Value"] = "Value" + i.ToString();
        dt.Rows.Add(dr);
    }

    ds.Tables.Add(dt);
    Grid1.DataSource = ds;
}

// grid item is created
protected void OnGridItemCreated(object sender, GridItemEventArgs e)
{
    if (e.Item is GridDataItem)
    {
        GridDataItem item = (GridDataItem)e.Item;

       // fill in cells 2 and 3. Why are there 4?

        Label lbl = new Label();
        lbl.Text = "Field " +  item.RowIndex;
        item.Cells[2].Controls.Add(lbl);

        switch (item.RowIndex)
        {
            case 2:
            case 8:
                RadTextBox txt = new RadTextBox();
                txt.ID = "RadTextBox1";
                txt.Text = "hello " + item.RowIndex;
                item.Cells[3].Controls.Add(txt);
                break;
            case 4:
            case 10:
                RadDatePicker dp = new RadDatePicker();
                dp.ID = "RadDatePicker1";
                dp.SelectedDate = DateTime.Now;
                item.Cells[3].Controls.Add(dp);
                break;
            case 6:
            case 12:
                CheckBox cb = new CheckBox();
                item.Cells[3].Controls.Add(cb);
                break;
            default:
                Label lbl2 = new Label();
                lbl2.Text = "Value " +  item.RowIndex;
                item.Cells[3].Controls.Add(lbl2);
                break;
        }
    }
}

альтернативный текст http://img193.imageshack.us/img193/1254/customgrid.png

1 Ответ

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

Если сетка отражает ваши реальные потребности, я бы посоветовал вам перейти с таблицей HTML внутри ASP FormView. Вы можете отобразить большинство вещей, которые вы показали здесь, прямо в HTML. Существует множество учебных пособий по FormView, и похоже, что это решение для того, что вам нужно. Не позволяйте сложностям втиснуть эти вещи в радгрид, чтобы вы пошли в неверном направлении.

Если вы хотите показывать, скажем, 10 записей за один раз, вот где gridview / radgrid пригодится, если это только одна запись за раз, посмотрите на представление формы.

РЕДАКТИРОВАТЬ: Я только заметил, что это спросили, как год назад. Я надеюсь, что вы все еще не ждете ответа на этот вопрос!

...