0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

メソッドの命名規則について悩む。

Last updated at Posted at 2016-12-04

MVC(model-view-controller)についてです。

僕が若手PHPerだった2006年頃、「MVCって知ってる?」と聞かれ、
「MVC? あぁ、モジュール、ビュー、コントロール ですよね♪」
(惜しい!)

って感じでよく分かっていませんでした。
この頃はPHP4→5への移行が始まり、クラスやオブジェクト指向の学習が必要になってきた時期でもありました。

modelとcontrollerは、今でも理解できてるのか微妙ですが、
とりあえず、controller開発者がmodelの中身を見ずにメソッドを扱える事が条件(方針)だと思っています。
(現実、仕事だと役割分担がmodel開発者とcontroller開発者で分けられていない為、この方針を忘れる事は良くありますが←)

さて、本題のメソッド名です。
めんどくさがりな僕はコメントを書くのが嫌いなので、
メソッド名で全てを語ろうと命名規則を思考中です。

例えば、こんな感じのルール
{戻り値の型}{データタイプ}{テーブル名}{取得方法}

例:

->aTable_User_all(['id'=1]);

model開発者は規則通りの名前でメソッドを作り、
controller開発者は規則通りのメソッド名を呼び出すだけで良く、いちいちmodelから欲しいメソッドを探す必要がなくなると思います。

このような命名規則で、Create,Read,Update,Deleteのメソッドを作っておくのは当然として、
CRUD以外のイレギュラーなメソッドの呼び出しをmodelの中身を知らない人が出来るのか?という壁にぶち当たります。
イレギュラーな処理はcontrollerに書くしかないのか…
そのまえに、CRUDに関してはORM使えばメソッドなんて作る必要ないような…

う~ん… 何が正解かわからなくなってきた。

何か良い命名規則や開発手法がありましたらご教授ください。

0
1
2

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?