質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

3回答

4190閲覧

php @propertyってどのように使うのでしょうか。

Pccla

総合スコア35

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

1クリップ

投稿2017/10/12 01:22

phpでの実装時、phpdocに、「@property string $hoge」とかって書くと思うんですが、これはどのように使用するのでしょうか。
__get() や __set() などのマジックメソッドを使ってるクラスに@propertyタグを使うみたいなことが書いてあったんですが、仕事で見たソースにはマジックメソッドがなくて、あまり腑に落ちませんでした。

マジックメソッドじゃなくて、public function getHoge()のようなメソッドならありました。
これでも良いということでしょうか...

また、どのような点が便利なのかイマイチわからないのでご教示いただけると嬉しいです。

何卒よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

ベストアンサー

例えば、下記の様なソースを書きたかったとします。

PHP

1<?php 2class hoge{ 3 public $id; 4 /** 5 * IDを取得する 6 * @return Integer 7 */ 8 public function getId(){ 9 return $this->id; 10 } 11 /** 12 * IDを設定する 13 * @param Integer $id 14 */ 15 public function setId(Integer $id){ 16 $this->id = $id; 17 } 18} 19/** 20 * @property integer $id IDパラメータ 21 * @method integer getId() IDを取得する 22 * @method void setId(Integer $id) IDを設定する 23 */ 24class fuga extends hoge{ 25 26} 27 28$fuga = new fuga(); 29$fuga->id = 999; 30echo $fuga->getId();

この時に、fugaクラスには@propertyを記載しています。
するとIDE(この場合は、netbeans)では下記の様にヘルプを出してくれます。
イメージ説明

ところが、PHPDocを書かなかった場合には下記の様になってしまいます。つまり、どの様なメソッドやプロパティを使えるのかがパッと見て分からなくなってしまうんですね…
イメージ説明

こういう時の為に書く、PHPDocなのだと思いますよ。

投稿2017/10/12 02:35

motuo

総合スコア3027

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Pccla

2017/10/12 04:17

皆様の回答とてもわかりやすかったんですが、IDEでの具体的使い方までキャプチャ付きで詳細につけていただいてとてもわかりやすかったので、ベストアンサーつけさせていただきます。ありがとうございます! こういうふうに使うんですね。勉強になりました。
guest

0

それは、PHPDocと呼ばれるコメントです。

定型的に付けたコメントを、IDEなどのツールが読み取って、ヒントとして表示してくれたりします。もちろんコメントなので、コード自体の実行に影響はありません。

投稿2017/10/12 01:30

maisumakun

総合スコア145184

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Pccla

2017/10/12 04:19

回答ありがとうございました!
guest

0

コメント自体についてはmaisumakunさんのご回答の通りです。

これの何が嬉しいかというと、phpDocumentorというツールを使って 、クラスドキュメントの自動生成ができることです。
サンプルは下記のようなものになりますが、例えばご質問の@propertyをきちんとメソッドのコメントに書いておくと、メソッドの引数説明のところにコメントに記載した内容(想定している値は何であるか等)を出力してくれます。

http://demo.phpdoc.org/Clean/classes/phpDocumentor.Application.html

このような仕組みはjavadocなど他の言語にもあるもので、PHPでも用意されているということになります。

投稿2017/10/12 01:51

編集2017/10/12 02:10
退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Pccla

2017/10/12 04:19

回答ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問