質問するログイン新規登録

回答編集履歴

2

補足

2019/04/04 15:13

投稿

tanat
tanat

スコア18778

answer CHANGED
@@ -1,3 +1,60 @@
1
1
  書籍とソースを読まずに、ブラウザ上で動いている現物とリファレンスを読みながら同じ仕様の掲示板を作ってみる
2
2
 
3
- と言うことをお勧めします。
3
+ と言うことをお勧めします。
4
+
5
+ [追記]
6
+ ポイントは
7
+ - 作る前に出来る限り仕様を明確にすること
8
+ - 困ったらまずリファレンスを読み/検索して、コピペでは無く自分でソースを書く事
9
+ を出来るだけ心がけることです。
10
+ (あくまで「出来るだけ心がける」であんまり悩み過ぎて手が止まってしまうようなら、先に実装をしてしまってもいいとは思います。)
11
+
12
+ ---
13
+ [補足]
14
+ ポイント「仕様を明確にすること」は「仕様書をきれいに書くこと」では無く、何を作るのかをアウトプットすることです。
15
+ 手書きのノートでも何でもいいので、何を何のために作るかを可能な限り作る前に決めてみる、なんとなく作らないという事です。
16
+
17
+ 例えば掲示板で書き込み機能があった場合
18
+
19
+ - 書き込みをしたい
20
+ という要求があり、
21
+
22
+ 実装としては
23
+ - 本文をDBに記録する
24
+ - 書き込み日時をDBに記録する
25
+ - その他入力項目を記録する
26
+ という実装がされると思います。
27
+
28
+ 絵にするとこんな感じ
29
+ ![イメージ説明](0ffae7c0639099e04cfde22950975a5c.png)
30
+
31
+ 「実装」はソースコードで実現されていることです。
32
+ これを実装前に書き出すだけでも結構大変なので、
33
+ 最初は実装を書き出したらそれに沿って作ってみるという事を目標にしてみても良いと思います。
34
+
35
+ ---
36
+
37
+ それに慣れてきたら次は、「実装」が何故存在するかを明確にすることにチャレンジしてみると良いです。
38
+ 「実装」には全て何らかの実現しなければならない事(要件)が存在するはずで、
39
+ それが決まると、実装が正しいかどうか、足りない実装は無いか、と言った判断が出来る様になります。
40
+
41
+ 例えば、上記の図だと
42
+ 「書き込みたい」だけなら「日時を記録する」という実装は必要無いハズです。
43
+
44
+ ではなぜ書き込み日時を記録するのか?というと、
45
+ 1. `一覧表示をする時に日時順で並べたい`とか、`個別に表示するときに書き込み日時を表示したい`という他のやりたい事がある
46
+ 2. そのためには`書き込み日時が記録されている事`という要件が必要になる
47
+ 3. 結果として`書き込みのタイミングで日時を記録する`という実装が行われる
48
+
49
+ という感じの背景が存在するはずです。
50
+ 絵にするとこんな感じ
51
+ ![イメージ説明](e01c4be74cda79c9ad8ffa1a60429e0a.png)
52
+
53
+ という感じで、
54
+ 思いつく限り色々書き込んでいくと、
55
+ サンプルをそのまま作るだけでは気づかなかった点について様々な気付きがあり、
56
+ 自分で新機能を追加するときも整理がしやすくなります。
57
+
58
+ ---
59
+
60
+ フォーマットは分かりやすければそれでいいので、一か月後の自分に説明するつもりで書いてみて下さい。

1

補足

2019/04/04 15:13

投稿

tanat
tanat

スコア18778

answer CHANGED
File without changes