質問

iには、行選択リンクを持つasp.net 2.0のデータバインドされたGridViewがあります。行を選択したら、別のグリッドなどをネストするために、選択した行の下にテーブル行をプログラムで追加します。

私はクライアントと記事のためにこれを研究していますが、私のgoogle-fuは今夜は強くないと思います。提案はありますか?

編集:実際には有効なソリューションがありましたが、Visual Studioはなんとか動転しました。 VSを閉じて再度開き、すべてを再構築すると問題が解決しました;-)

私の解決策を以下に掲載します。可能であれば改善する方法を教えてください。ありがとう!

役に立ちましたか?

解決

私はそれを理解したと思います。これがうまくいくように見える解決策です。ユーザーコントロールを使用して改善することもできますが、これは骨子です:

protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
{
    if (e.Row.RowType == DataControlRowType.DataRow && 
        (e.Row.RowState & DataControlRowState.Selected) > 0)
    {
        Table tbl = (Table)e.Row.Parent;
        GridViewRow tr = new GridViewRow(e.Row.RowIndex + 1, -1,
            DataControlRowType.EmptyDataRow, DataControlRowState.Normal);
        TableCell tc = new TableCell();
        tc.ColumnSpan = GridView1.Columns.Count;
        tc.Controls.Add(
            makeChildGrid(Convert.ToInt32(
                ((DataRowView)e.Row.DataItem)["ROW_ID_FIELD"])));
        tr.Cells.Add(tc);
        tbl.Rows.Add(tr);
    }
}

protected GridView makeChildGrid(int id)
{
    GridView gv = new GridView();
    SqlDataSource sqlds = new SqlDataSource();
    sqlds.DataSourceMode = SqlDataSourceMode.DataSet;
    sqlds.ConnectionString = SqlDataSource1.ConnectionString;
    sqlds.SelectCommand = "SELECT * from MY_TABLE_NAME " +
        "WHERE KEY_FIELD = " + id.ToString();
    DataView dv = (DataView)sqlds.Select(DataSourceSelectArguments.Empty);
    gv.DataSource = dv;
    gv.DataBind();    //not sure this is necessary...?
    return gv;
}

他のヒント

このコードを共有していただきありがとうございます。

同じこと(ネストされたグリッドビューの作成)を試みていますが、実際には、グリッドビューを自分で作成する必要はありません。代わりに、タグ内でコントロールをラップできます。 ここで http://www.codeprojectの例を見てきました。 com / KB / aspnet / EditNestedGridView.aspx?msg = 3089755#xx3089755xx

開発者は、2番目のgridviewコントロールをタグ内にラップするだけで、gvコントロールをネストしていることがわかります。

コードで彼がしていることをできるなら、それはより効率的です。選択したすべてのフィールドを表示する必要はありません!!さらに、視覚的に子グリッドビューにいくつかのコントロールを追加できます。

コードをvbに変換し、完全に機能しました。

ありがとう

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top