phpを初めて使う友達。誰もがプロジェクトのやり方を学ぶためにすぐに使えるフレームワークを見つけたいと思うでしょう。一般的に、私は ThinkPHP を選択して試してみます。このフレームワークは始めるのが難しくなく、すぐにアプリケーションを開発できます。小規模ビジネスのアプリケーションに適しています。中国人が開発したものなので、中国語のサポートが充実しています。ドキュメントも比較的充実しており、公式サイトのコミュニティも比較的活発です。しかし、ある段階になると、基本的に ThinkPHP の使用に満足できなくなり、高パフォーマンスの開発フレームワークを選択します。 Yii には、MVC、DAO/ActiveRecord、I18N/L10N、キャッシュ、認証およびロールベースのアクセス制御、スキャフォールディング、テストなどを含む豊富な機能セットが付属しており、開発時間を大幅に短縮できます。ここでは、PHP 中国語 Web サイトで、yii2 フレームワークを使用してフォームを作成する方法を最初から学習します。
まず、弊社の php 中国語 Web サイトにアクセスしてオンラインで視聴できます Yii2 中国語マニュアル
また、php 中国語 Web サイトのダウンロード サイト ダウンロード: Yii 2 中国語マニュアル
yii2 フレームワークでのフォーム作成のトピックに移りましょう:
ディレクトリ
フォームの生成
フォーム内のメソッド
ActiveForm:: begin() メソッド
ActiveForm::end ( ) メソッド
getClientOptions() メソッド
その他のメソッド: errorsummary、validate、validateMultiple
フォーム内のパラメータ
フォームフォーム自身の属性 各項目(フィールド)の入力に関連する属性フォーム内のボックス
$fieldConfig
検証属性について
各フィールドコンテナスタイルの属性について
ajax 検証
フロントエンド JS イベント
フォーム内のその他の属性
<?php $form = ActiveForm::begin(['id' => 'login-form']); ?> <?= $form->field($model, 'username') ?> <?= $form->field($model, 'password')->passwordInput() ?> <?= $form->field($model, 'rememberMe')->checkbox() ?> <p style="color:#999;margin:1em 0"> If you forgot your password you can <?= Html::a('reset it', ['site/request-password-reset']) ?> </p> <p class="form-group"> <?= Html::submitButton('Login', ['class' => 'btn btn-primary', 'name' => 'login-button']) ?> </p> <?php ActiveForm::end(); ?>以下は生成されたフォーム HTML で、その中に 5 つの部分をマークしました。
1. フォーム生成
Yii では、フォームは ActiveForm とウィジェットの両方です。 上でわかるように、フォームは begin<?php $form = ActiveForm::begin(['id' => 'login-form']); ?>で始まり、最後に各項目の入力ボックスです。 end
<?php ActiveForm::end(); ?>
2. フォーム内のメソッド
ウィジェットでは、begin() メソッドが int メソッドを呼び出しますpublic function init()最後の end() メソッドが run メソッド
public function run()
を呼び出します。 :begin() メソッド
//这个是在执行 $form = ActiveForm::begin(['id' => 'login-form']); 中的begin方法的时候调用的 public function init() { //设置表单元素form的id if (!isset($this->options['id'])) { $this->options['id'] = $this->getId(); } //设置表单中间的要生成各个field的所使用的类 if (!isset($this->fieldConfig['class'])) { $this->fieldConfig['class'] = ActiveField::className(); } //这个就是输出表单的开始标签 //如:<form id="login-form" action="/lulublog/frontend/web/index.php?r=site/login" method="post"> echo Html::beginForm($this->action, $this->method, $this->options); }
2. ActiveForm::end() メソッド
//这个是在执行 ActiveForm::end(); 中的end方法的时候调用的 public function run() { //下面这个就是往视图中注册表单的js验证脚本, if (!empty($this->attributes)) { $id = $this->options['id']; $options = Json::encode($this->getClientOptions()); $attributes = Json::encode($this->attributes); $view = $this->getView(); ActiveFormAsset::register($view); /* * $attributes:为要验证的所有的field数组。它的值是在activeform中创建field的时候,在field的begin方法中给它赋值的。 * 其中每个field又是一个数组,为这个field的各个参数 * 比如username的field中的参数有 * validate、id、name、 * validateOnChange、validateOnType、validationDelay、 * container、input、error * * $options:为这个表单整体的属性,如: * errorSummary、validateOnSubmit、 * errorCssClass、successCssClass、validatingCssClass、 * ajaxParam、ajaxDataType */ $view->registerJs("jQuery('#$id').yiiActiveForm($attributes, $options);"); } //输出表单的结束标签 echo Html::endForm(); }
3. getClientOptions() メソッド
/* * 设置表单的全局的一些样式属性以及js回调事件等 */ protected function getClientOptions() { $options = [ 'errorSummary' => '.' . $this->errorSummaryCssClass, 'validateOnSubmit' => $this->validateOnSubmit, 'errorCssClass' => $this->errorCssClass, 'successCssClass' => $this->successCssClass, 'validatingCssClass' => $this->validatingCssClass, 'ajaxParam' => $this->ajaxParam, 'ajaxDataType' => $this->ajaxDataType, ]; if ($this->validationUrl !== null) { $options['validationUrl'] = Url::to($this->validationUrl); } foreach (['beforeSubmit', 'beforeValidate', 'afterValidate'] as $name) { if (($value = $this->$name) !== null) { $options[$name] = $value instanceof JsExpression ? $value : new JsExpression($value); } } return $options; }以下は、生成された
フォーム検証Js コードです
jQuery(document).ready(function () { jQuery('#login-form').yiiActiveForm( { "username":{ "validate":function (attribute, value, messages) { yii.validation.required(value, messages, {"message":"Username cannot be blank."}); }, "id":"loginform-username", "name":"username", "validateOnChange":true, "validateOnType":false, "validationDelay":200, "container":".field-loginform-username", "input":"#loginform-username", "error":".help-block"}, "password":{ "validate":function (attribute, value, messages) { yii.validation.required(value, messages, {"message":"Password cannot be blank."}); }, "id":"loginform-password", "name":"password", "validateOnChange":true, "validateOnType":false, "validationDelay":200, "container":".field-loginform-password", "input":"#loginform-password", "error":".help-block" }, "rememberMe":{ "validate":function (attribute, value, messages) { yii.validation.boolean(value, messages, { "trueValue":"1","falseValue":"0","message":"Remember Me must be either \"1\" or \"0\".","skipOnEmpty":1}); }, "id":"loginform-rememberme", "name":"rememberMe","validateOnChange":true, "validateOnType":false, "validationDelay":200, "container":".field-loginform-rememberme", "input":"#loginform-rememberme", "error":".help-block"} }, { "errorSummary":".error-summary", "validateOnSubmit":true, "errorCssClass":"has-error", "successCssClass":"has-success", "validatingCssClass":"validating", "ajaxParam":"ajax", "ajaxDataType":"json" }); });
4他のメソッド: errorsummary、validate、validateMultiple
public function errorSummary($models, $options = [])主に、モデル内のすべての
エラー メッセージを 1 つの p に要約します。
public static function validate($model, $attributes = null) public static function validateMultiple($models, $attributes = null)これら 2 つはエラー情報を取得する方法であり、比較的簡単なので詳細は説明しません。
3. フォーム内のパラメータ
1. フォーム自体のプロパティ
$action: 現在のフォーム送信の URL アドレスを設定します。空の場合は、現在の URL$method です。送信メソッド、post または get、デフォルトは post です
$option: ID などのフォームの他の属性を設定します。ID が設定されていない場合は、$autoIdPrefix をプレフィックスとして自動的に追加される ID が自動的に生成されます
//这个方法在Widget基本中 public function getId($autoGenerate = true) { if ($autoGenerate && $this->_id === null) { $this->_id = self::$autoIdPrefix . self::$counter++; } return $this->_id; }
2.
の各フィールド入力ボックスに関連するフォーム属性 Yii によって生成される各フィールドは 4 つの部分で構成されます: ① 一番外側の p は各フィールドのコンテナです。② ラベルは各フィールドのテキスト説明です。
③ input は入力要素、
④ にはエラーメッセージの p が付いています。
<p class="form-group field-loginform-username required has-error"> <label class="control-label" for="loginform-username">Username</label> <input type="text" id="loginform-username" class="form-control" name="LoginForm[username]"> <p class="help-block">Username cannot be blank.</p> </p>$fieldConfig: 全フィールドの統一設定情報により設定される属性です。つまり、フィールドクラスの属性をここで設定できます。
public function field($model, $attribute, $options = []) { //使用fieldConfig和options属性来创建field //$options会覆盖统一的fieldConfig属性值,以实现每个field的自定义 return Yii::createObject(array_merge($this->fieldConfig, $options, [ 'model' => $model, 'attribute' => $attribute, 'form' => $this, ])); }確認済みの物件について:
① $enableClientValidation:是否在客户端验证,也即是否生成前端js验证脚本(如果在form中设置了ajax验证,也会生成这个js脚本)。
② $enableAjaxValidation:是否是ajax验证
③ $validateOnChange:在输入框失去焦点并且值改变的时候验证
④ $validateOnType:正在输入的时候就进行验证
⑤ $validationDelay:验证延迟的时间,单位为毫秒
这5个属性都可以在创建每个field的时候单独设置,因为在field类中就有这5个属性。
关于每个field容器样式的属性:
$requiredCssClass:必填项的样式,默认为‘required'
$errorCssClass:验证错误的样式,默认值为‘has-error'
$successCssClass:验证正确的样式,默认值为‘has-success'
$validatingCssClass:验证过程中的样式,默认值为‘validating'
3、ajax验证
$validationUrl:ajax验证的url地方
$ajaxParam:url中的get参数,用来标明当前是ajax请求,默认值为‘ajax'
$ajaxDataType:ajax请求返回的数据格式
4、前端js事件属性
$beforeSubmit:在提交表单之前事件,如果返回false,则不会提交表单,格式为:
function ($form) { ...return false to cancel submission... }
$beforeValidate:在每个属性在验证之前触发,格式为:
function ($form, attribute, messages) { ...return false to cancel the validation... }
$afterValidate:在每个属性在验证之后触发,格式为:
function ($form, attribute, messages) { }
5、表单中的其它属性
$validateOnSubmit:提交表单的时候进行验证
$errorSummary:总的错误提示地方的样式
$attributes:这个属性比较特殊,它是在创建field的时候,在field中为这个form中的$attributes赋值的。这样可以确保通过field方法生成的输入表单都可以进行验证
相关课程推荐:
1. 视频课程: 传智播客Yii开发大型商城项目视频教程
2. 视频课程: Yii2.0框架开发实战视频教程
3. 视频课程: Yii2框架搭建完整博客系统

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

WebStorm Mac版
便利なJavaScript開発ツール

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ドリームウィーバー CS6
ビジュアル Web 開発ツール
