Yii-creating-event
Yii-イベントの作成
この章では、Yiiでイベントを作成する方法を説明します。 実行中のイベントを表示するには、データが必要です。
DBの準備
- ステップ1 *-新しいデータベースを作成します。 データベースは、次の2つの方法で準備できます。
- ターミナルで_mysql -u root –p_を実行します
- _CREATE DATABASE helloworld CHARACTER SET utf8 COLLATE utf8_general_ci; _を介して新しいデータベースを作成します
ステップ2 *- *config/db.php ファイルでデータベース接続を設定します。 次の構成は、現在使用されているシステム用です。
ステップ3 *-ルートフォルダー内で./yii migrate/create test_table *を実行します。 このコマンドは、DBを管理するためのデータベース移行を作成します。 移行ファイルは、プロジェクトルートの *migrations フォルダーに表示されます。
ステップ4 *-この方法で移行ファイル(この場合は *m160106_163154_test_table.php )を変更します。
上記の移行では、id、name、およびemailのフィールドを持つ user テーブルが作成されます。 また、いくつかのデモユーザーを追加します。
- ステップ5 *-プロジェクトのルート内で./yii migrate *を実行して、データベースに移行を適用します。
ステップ6 *-次に、 *user テーブルのモデルを作成する必要があります。 簡単にするために、 Gii コード生成ツールを使用します。 この url:http://localhost:8080/index.php?r = gii を開きます。 次に、「Model generator」ヘッダーの下にある「Start」ボタンをクリックします。 テーブル名(「ユーザー」)とモデルクラス(「MyUser」)を入力し、「プレビュー」ボタンをクリックして、最後に「生成」ボタンをクリックします。
MyUserモデルがモデルディレクトリに表示されます。
イベントを作成する
新しいユーザーがWebサイトに登録するたびに、管理者にメールを送信するとします。
ステップ1 *-このように *models/MyUser.php ファイルを変更します。
上記のコードでは、「新規ユーザー」イベントを定義しています。 次に、init()メソッドで sendMailToAdmin 関数を「new-user」イベントに添付します。 次に、このイベントをトリガーする必要があります。
ステップ2 *-SiteControllerで *actionTestEvent というメソッドを作成します。
上記のコードでは、新しいユーザーを作成し、「new-user」イベントをトリガーします。
ステップ3 *- *http://localhost:8080/index.php?r = site/test-event と入力すると、次のように表示されます。