Yii-behaviors
Yii-行動
動作は、yii \ base \ Behaviorクラスのインスタンスです。 ビヘイビアは、メソッドとプロパティをアタッチされたコンポーネントに注入します。 動作は、コンポーネントによってトリガーされたイベントに応答することもできます。
ステップ1 *-動作を定義するには、 *yii \ base \ Behavior クラスを拡張します。
namespace app\components;
use yii\base\Behavior;
class MyBehavior extends Behavior {
private $_prop1;
public function getProp1() {
return $this->_prop1;
}
public function setProp1($value) {
$this->_prop1 = $value;
}
public function myFunction() {
//...
}
}
上記のコードは、1つのプロパティ(prop1)と1つのメソッド(myFunction)で動作を定義しています。 この動作がコンポーネントに関連付けられている場合、そのコンポーネントには prop1 プロパティと myFunction メソッドもあります。
- 動作が関連付けられているコンポーネントにアクセスするには、* yii \ base \ Behavior
- $ ownerプロパティ*を使用できます。
- ステップ2 *-コンポーネントイベントに動作を応答させたい場合は、 yii \ base \ Behavior
- events()*メソッドをオーバーライドする必要があります。
namespace app\components;
use yii\db\ActiveRecord;
use yii\base\Behavior;
class MyBehavior extends Behavior {
public function events() {
return [
ActiveRecord::EVENT_AFTER_VALIDATE => 'afterValidate',
];
}
public function afterValidate($event) {
//...
}
}
ステップ3 *-ビヘイビアをアタッチするには、コンポーネントクラスの behaviors()*メソッドをオーバーライドする必要があります。
namespace app\models;
use yii\db\ActiveRecord;
use app\components\MyBehavior;
class MyUser extends ActiveRecord {
public function behaviors() {
return [
//anonymous behavior, behavior class name only
MyBehavior::className(),
//named behavior, behavior class name only
'myBehavior2' => MyBehavior::className(),
//anonymous behavior, configuration array
[
'class' => MyBehavior::className(),
'prop1' => 'value1',
'prop2' => 'value2',
'prop3' => 'value3',
],
//named behavior, configuration array
'myBehavior4' => [
'class' => MyBehavior::className(),
'prop1' => 'value1'
]
];
}
}
- *ステップ4 *-ビヘイビアーをデタッチするには、yii \ base \ Component
- detachBehavior()*メソッドを呼び出します。
$component->detachBehavior('myBehavior');
実際の動作を示すには、データが必要です。
DBの準備
- ステップ1 *-新しいデータベースを作成します。 データベースは、次の2つの方法で準備できます。
- ターミナルで_mysql -u root –p_を実行します。
- _CREATE DATABASE helloworld CHARACTER SET utf8 COLLATE utf8_general_ci; _を介して新しいデータベースを作成します
ステップ2 *- *config/db.php ファイルでデータベース接続を設定します。 次の構成は、現在使用されているシステム用です。
<?php
return [
'class' => 'yii\db\Connection',
'dsn' => 'mysql:host = localhost;dbname = helloworld',
'username' => 'vladimir',
'password' => '12345',
'charset' => 'utf8',
];
?>
ステップ3 *-ルートフォルダー内で./yii migrate/create test_table *を実行します。 このコマンドは、DBを管理するためのデータベース移行を作成します。 移行ファイルは、プロジェクトルートの *migrations フォルダーに表示されます。
ステップ4 *-この方法で移行ファイル(この場合は *m160106_163154_test_table.php )を変更します。
<?php
use yii\db\Schema;
use yii\db\Migration;
class m160106_163154_test_table extends Migration {
public function safeUp() {
$this->createTable("user", [
"id" => Schema::TYPE_PK,
"name" => Schema::TYPE_STRING,
"email" => Schema::TYPE_STRING,
]);
$this->batchInsert("user", ["name", "email"], [
["User1", "[email protected]"],
["User2", "[email protected]"],
["User3", "[email protected]"],
["User4", "[email protected]"],
["User5", "[email protected]"],
["User6", "[email protected]"],
["User7", "[email protected]"],
["User8", "[email protected]"],
["User9", "[email protected]"],
["User10", "[email protected]"],
["User11", "[email protected]"],
]);
}
public function safeDown() {
$this->dropTable('user');
}
}
?>
上記の移行では、id、name、およびemailのフィールドを持つ user テーブルが作成されます。 また、いくつかのデモユーザーを追加します。
ステップ5 *-プロジェクトルート *run。/yii migrate 内で、データベースに移行を適用します。
ステップ6 *-次に、*ユーザーテーブル*のモデルを作成する必要があります。 簡単にするために、 *Gii コード生成ツールを使用します。 この url:http://localhost:8080/index.php?r = gii を開きます。 次に、「Model generator」ヘッダーの下にある「Start」ボタンをクリックします。 テーブル名(「ユーザー」)とモデルクラス(「MyUser」)を入力し、「プレビュー」ボタンをクリックして、最後に「生成」ボタンをクリックします。
MyUserモデルがモデルディレクトリに表示されます。