?php
namespace app\commands;
use YII;
use yii\console\Controller;
use yii\console\ExitCode;
use yii\helpers\Console;
//注意控制臺程序必須繼承自yii\console\Controller
class TestController extends Controller
{
public $param1;
public $param2;
public $param3;
//指定用于控制臺的選項
public function options($actionID)
{
return [
'param1',
'param2',
'param3',
];
}
//如果這些選項名稱太長,可以取個短的別名
public function optionAliases()
{
return [
'p1' => 'param1',
'p2' => 'param2',
'p3' => 'param3',
];
}
// 定義控制臺運行的方法
// yii test/test1 -p1=hello -p2=world -p3=!!!
public function actionTest1()
{
echo $this->param1, ' ', $this->param2, ' ', $this->param3, "\n";
return ExitCode::OK;
}
// 我們可以獲取控制臺傳過來的參數
// 注意,函數第一個參數,對應控制臺傳過來的第一個參數,依次類推,不要把順序搞錯了。
// yii test/test2 aa bb cc
public function actionTest2($p1 = '', $p2 = '', $p3 = '')
{
echo $p1, ' ', $p2, ' ', $p3, "\n";
return ExitCode::OK;
}
// 當然控制臺也可以一次傳多個數據過來,這就需要把函數參數聲明為一個array
// 控制臺傳參時就需要把傳遞的數據通過逗號連接起來,YII2通過處理變成數組
// yii test/test3 aa,bb,cc
public function actionTest3(array $arr)
{
echo implode('--', $arr), "\n";
return ExitCode::OK;
}
// 控制臺格式和顏色的設置
// yii test/test4
public function actionTest4()
{
//用于控制臺輸出
$this->stdout('hello', Console::FG_RED);
$this->stdout('world', Console::FG_GREEN);
$this->stdout('!!!', Console::FG_BLUE);
echo "\n";
$hello = $this->ansiFormat('hello', Console::FG_RED);
$world = $this->ansiFormat('world', Console::FG_GREEN);
$sigh = $this->ansiFormat('!!!', Console::FG_BLUE);
echo $hello, ' ', $world, ' ', $sigh, "\n";
return ExitCode::OK;
}
}
更多關于Yii相關內容感興趣的讀者可查看本站專題:《Yii框架入門及常用技巧總結》、《php優秀開發框架總結》、《smarty模板入門基礎教程》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》