DataGridView内にコンボボックスのカラムを設定しました。
下記のサイトを参考にしました。
http://dobon.net/vb/dotnet/datagridview/combobox …
入力した内容をカラム単位ではなく、セル単位で追加したかったため、
CellValidatingメソッドを下記の通り一部変更しました。
//CellValidatingイベントハンドラ
private void DataGridView_CellValidating(object sender,
DataGridViewCellValidatingEventArgs e)
{
DataGridView dgv = (DataGridView)sender;
//該当する列か調べる
if (dgv.Columns[e.ColumnIndex].Name == "sComboColumn" &&
dgv.Columns[e.ColumnIndex] is DataGridViewComboBoxColumn)
{
//DataGridViewComboBoxColumn cbc =
// (DataGridViewComboBoxColumn)dgv.Columns[e.ColumnIndex];
//
// ↓cellへ変更
//
DataGridViewComboBoxCell cbc =
(DataGridViewComboBoxCell)dgv.Rows[e.RowIndex].Cells[e.ColumnIndex];
//コンボボックスの項目に追加する
if (!cbc.Items.Contains(e.FormattedValue))
{
cbc.Items.Add(e.FormattedValue);
}
//セルの値を設定しないと、元に戻ってしまう
dgv[e.ColumnIndex, e.RowIndex].Value = e.FormattedValue;
}
}
コンボボックスに入力し、EnterやTabを押したタイミングでコンボボックスのリストに、
入力した文字列が追加されます。また、入力した文字列がセルに表示された状態になります。
しかし、その後同じセルに文字列を入力した場合、リストに文字列が追加されますが、
セルに表示される文字列はその前に入力された文字列のままです。
どのようにすれば入力後のセルの内容を設定できるかご存じの方がいれば
ご教授いただきたいです。
No.1ベストアンサー
- 回答日時:
お示しのURLのコメントにあるように ComboBoxにアイテムを追加したので DataGridViewのセルステータスが変更されてしまっているのが原因のようですよ
//コンボボックスの項目に追加する
if (!cbc.Items.Contains(e.FormattedValue))
{
cbc.Items.Add(e.FormattedValue);
// ここでDataGridViewのIsCurrentCellDirtyがTrueになってしまうのでFalseにするために
dgv.CommitEdit(DataGridViewDataErrorContexts.Commit);
}
といった具合の処理が必要です
これはDataGridViewComboBoxColumnの場合でも一緒です
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
10代と話して驚いたこと
先日10代の知り合いと話した際、フロッピーディスクの実物を見たことがない、と言われて驚きました。今後もこういうことが増えてくるのかと思うと不思議な気持ちです。
-
これ何て呼びますか
あなたのお住いの地域で、これ、何て呼びますか?
-
CDの保有枚数を教えてください
ひとむかし前はCDを買ったり借りたりが主流でしたが、サブスクで簡単に音楽が聴ける今、CDを手に取ることも減ってきたかと思います。皆さんは2024年現在、何枚くらいCDをお持ちですか?
-
この人頭いいなと思ったエピソード
一緒にいたときに「この人頭いいな」と思ったエピソードを教えてください
-
ギリギリ行けるお一人様のライン
おひとり様需要が増えているというニュースも耳にしますが、 あなたが「ギリギリ一人でも行ける!」という場所や行為を教えてください
-
DataGridViewのコンボボックスの初期値について
Visual Basic(VBA)
-
DataGridViewでセルクリックイベントを発生させるには
Visual Basic(VBA)
-
DataGridViewのセル編集完了後に値を設定するには
Visual Basic(VBA)
-
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ExcelVBAを使って、値...
-
i=cells(Rows.Count, 1)とi=cel...
-
Excel vbaで特定の文字以外が入...
-
Excelのプルダウンで2列分の情...
-
Excelで指定した日付から過去の...
-
VBAの間違い教えて下さい
-
VBA実行後に元のセルに戻りたい
-
特定の文字を条件に行挿入とそ...
-
EXCELで変数をペーストしたい
-
【VBA】指定したセルと同じ値で...
-
VBA初心者です。結合セルを保持...
-
VBからEXCELのセルの値を取得す...
-
Excel2003 複数セル1列の入力済...
-
連続する複数のセル値がすべて0...
-
Application.Matchで特定行の検索
-
Google Apps Script:Googleスプ...
-
【Excel VBA】セルの色によって...
-
VBAでセルをクリックする回...
-
VBA ユーザーフォーム ボタンク...
-
HTMLでVLOOKUP関数のようなこと...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ExcelVBAを使って、値...
-
i=cells(Rows.Count, 1)とi=cel...
-
特定のセルが空白だったら、そ...
-
Excelで指定した日付から過去の...
-
Excelのプルダウンで2列分の情...
-
【Excel VBA】指定行以降をクリ...
-
特定の文字を条件に行挿入とそ...
-
EXCELで変数をペーストしたい
-
エクセルVBAでコピーして順...
-
TODAY()で設定したセルの日付...
-
VBAでセルをクリックする回...
-
セル色なしの行一括削除
-
VBA実行後に元のセルに戻りたい
-
【Excel】指定したセルの名前で...
-
”戻り値”が変化したときに、マ...
-
Excel vbaで特定の文字以外が入...
-
EXCELのVBA-フィルタ抽出後の...
-
VBA初心者です。結合セルを保持...
-
指定した条件で行セルを非表示...
-
ExcelのVBAで数字と文字列をマ...
おすすめ情報