• 締切済み

2年目プログラマスキルレベルをチェックしてください

VB2年目の新米プログラマです。 (1)グリッドの先頭行に新規データを追加する (2)グリッドチェックボックス項目のカラムの行全てにチェックをつける (3)グリッドチェックボックス項目のカラムの行全てにチェックをはずす (4)グリッドで選択した行を全てグリッドから削除する グリッドへのデータ追加や削除、グリッドのチェックボックスのちょっとした 処理をちょっとの時間考えたり解らない所をネットでちょっと調べたりして 問題なくサクサクと書けるようになりました。 2年目のプログラマとしてこの様な部品アルゴリズムを問題なくかけるので 2年目プログラマとして順調に成長していると言えるでしょうか。 会社ではもうちょっと複雑なsql文やVBコードの部品をいくつもつくり プロジェクトととして完成させ1000行から2000行のプログラムを 2日間位で作れるようになりました。 Public Class Form2 Private Sub initialize() fgdList.Cols(1).TextAlignFixed = TextAlignEnum.CenterCenter fgdList.Cols(2).TextAlignFixed = TextAlignEnum.CenterCenter fgdList.Cols(1).TextAlign = TextAlignEnum.CenterCenter fgdList.Cols(2).TextAlign = TextAlignEnum.LeftCenter fgdList.Cols(1).Name = "code" fgdList.Cols(2).Name = "name" '列エディタを起動してDataTypeプロパティをBooleanにするとチェックボックスで表示される(開発時) fgdList.Cols(3).Name = "select" fgdList.Cols(1).DataType = GetType(Decimal) fgdList.Cols(2).DataType = GetType(String) 'Boolean型にするとチェックボックスになる fgdList.Cols(3).DataType = GetType(Boolean) fgdList.Cols(1).Format = "000" fgdList.AllowEditing = False fgdList.Cols(4).Width = 1 'これによってグリッド行を選択する事が出来る(この場合複数行選択) 'グリッドの画面のプロパティでSelectionModeを設定してもいい fgdList.SelectionMode = SelectionModeEnum.ListBox fgdList.Rows.Count = 1 End Sub 'グリッドの先頭行に新規データを追加する Private Sub AddGrid() Dim introwcount As Integer = fgdList.Rows.Count '最終行に1行、行を追加する fgdList.Rows.Add() '行を1行ずつ下へ移動させる For intIndex As Integer = fgdList.Rows.Count - 1 To 1 Step -1 fgdList(intIndex, "code") = fgdList(intIndex - 1, "code") fgdList(intIndex, "name") = fgdList(intIndex - 1, "name") Next '一番先頭行に新規データを追加する fgdList(1, "code") = CType(introwcount, Decimal) fgdList(1, "name") = CType("NAME" & introwcount, String) End Sub Private Sub btnAdd_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnAdd.Click AddGrid() btnAllClear.Enabled = True btnAllSelect.Enabled = True btnDelete.Enabled = True End Sub Private Sub Form2_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load initialize() btnAllClear.Enabled = False btnAllSelect.Enabled = False btnDelete.Enabled = False End Sub 'グリッドチェックボックス項目のカラムの行全てにチェックをつける Private Sub btnAllSelect_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnAllSelect.Click For intIndex As Integer = 1 To fgdList.Rows.Count - 1 fgdList(intIndex, "select") = True Next End Sub 'グリッドチェックボックス項目のカラムの行全てにチェックをはずす Private Sub btnAllClear_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnAllClear.Click For intIndex As Integer = 1 To fgdList.Rows.Count - 1 fgdList(intIndex, "select") = False Next End Sub 'グリッドで選択した行を全てグリッドから削除する Private Sub btnDelete_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnDelete.Click 'グリッドの最終行から削除していかないとダメ For intIndex As Integer = fgdList.Rows.Count - 1 To 1 Step -1 If fgdList.Rows(intIndex).Selected = True Then fgdList.Rows.Remove(intIndex) End If Next If fgdList.Rows.Count = 1 Then btnAllClear.Enabled = False btnAllSelect.Enabled = False btnDelete.Enabled = False End If End Sub End Class

みんなの回答

回答No.2

詳細な回答は、前の回答者さんが記述されていると思うので割愛します。 私の回答ですが、もし私があなたの先輩・上司であったら、このプログラムを見て10秒で突き返します。 理由は1つ、例外処理が1つも書かれていません。 なぜこのような質問をされたのか分かりませんが、単に自慢したいだけでしょうか。

回答No.1

・「グリッド」というのは何ですか。 普通に考えれば,System.Windows.Forms.DataGridView と思われますが,この「標準の」グリッドコントロールには存在しないプロパティが書かれています。 伝えるためには,ちゃんと型の完全修飾名を書くなりすべきかと思います。 # そもそも,DataGridView ならデータバインドするものかと。 ・「initialize」メソッドの役割は何でしょうか。また,メソッド名に Pascal Case を使うのではなく,Camel Case を使っている意図は何でしょうか。 initialize というメソッドがあるのは,危険な香りがします。 本来,コンストラクタがやるべき役割が分散しているだけのように感じられるからです。 また,.NET Framework ではメソッド名は Pascal Case で書きます。 これを逸脱する意図が読み取れません。 # Camel Case はフィールドと変数くらいかと。 ・そこら中にシステムハンガリアンによる名称がありますが,これの意図は何ですか。 .NET Framework では,システムハンガリアンは使わないことが推奨されています。 また,intIndex というような変数名は無駄に長いだけで,意味がありません。 せめて row か,いっそ i でよいと思います。 # 行だから row,「単なるループ変数」を意味するために i。 ・コントロールに対して 1-origin で書いていますが,この理由は何ですか。 .NET Framework は基本的に 0-origin で書くようになっています。 # 例外: COM ・根本的なところですが,Model はどこにありますか。 View と Model を分離する,というのは GUI の基本だと思います。 どのレベルを要求するかによるとは思いますが, ・「グリッド」が何かを説明していない ・標準の作法から外れた書き方がなされている (ref: http://msdn.microsoft.com/ja-jp/library/ms229043(v=vs.90) ) あたりから,私は少なくともレベルは「高くない」とみなします。

関連するQ&A

専門家に質問してみよう