Categories: Yii框架教程

Yii-HTML表单

当表单基于模型时,在Yii中创建此表单的常用方法是通过yii \ widgets \ ActiveForm类。在大多数情况下,表单具有用于数据验证的相应模型。如果模型表示来自数据库的数据,则该模型应从ActiveRecord类派生。如果模型捕获任意输入,则应从yii \ base \ Model类派生。

让我们创建一个注册表。

步骤1-models文件夹内,使用以下代码创建一个名为RegistrationForm.php的文件。

<?php
   namespace app\models;
   use Yii;
   use yii\base\Model;
   class RegistrationForm extends Model {
      public $username;
      public $password;
      public $email;
      public $subscriptions;
      public $photos;
      /**
      * @return array customized attribute labels
      */      public function attributeLabels() {
         return [
            'username' => 'Username',
            'password' => 'Password',
            'email' => 'Email',
            'subscriptions' => 'Subscriptions',
            'photos' => 'Photos',
         ];
      }
   }
?>

我们已经为注册表单声明了一个模型,该模型具有五个属性-用户名,密码,电子邮件,订阅和照片。

步骤2-要显示此表单,请将actionRegistration方法添加到SiteController

public function actionRegistration() {
   $mRegistration = new RegistrationForm();
   return $this->render('registration', ['model' => $mRegistration]);
}

我们创建RegistrationForm的实例,并将其传递到注册视图。现在,该创建视图了。

步骤3-在views / site文件夹内,添加带有以下代码的文件registration.php

<?php
   use yii\bootstrap\ActiveForm;
   use yii\bootstrap\Html;
?>
<div class = "row">
   <div class = "col-lg-5">
      <?php $form = ActiveForm::begin(['id' => 'registration-form']); ?>
      <?= $form->field($model, 'username') ?>
      <?= $form->field($model, 'password')->passwordInput() ?>
      <?= $form->field($model, 'email')->input('email') ?>
      <?= $form->field($model, 'photos[]')->fileInput(['multiple'=>'multiple']) ?>
      <?= $form->field($model, 'subscriptions[]')->checkboxList(['a' => 'Item A',
         'b' => 'Item B', 'c' => 'Item C']) ?>
      <div class = "form-group">
         <?= Html::submitButton('Submit', ['class' => 'btn btn-primary',
            'name' => 'registration-button']) ?>
      </div>
      <?php ActiveForm::end(); ?>
   </div>
</div>

我们观察到以下内容-

  • 的ActiveForm ::开始()函数标记形式的开始。ActiveForm :: begin()ActiveForm :: end()函数之间的所有代码都将包装在form标记内。
  • 要在表单中创建一个字段,您应该调用ActiveForm :: field()方法。它创建所有输入和标签标签。输入名称是自动确定的。
  • 例如,密码属性将为RegistrationForm [password]。如果希望属性采用数组,则应在属性名称后附加[]。

步骤4-如果您转到Web浏览器的地址栏,然后输入http:// localhost:8080 / index.php?r = site / registration,您将看到我们的表格。

terry

这个人很懒,什么都没有留下~

Share
Published by
terry

Recent Posts

在 Chrome 中删除、允许和管理 Cookie

您可以选择删除现有 Cooki…

18 小时 ago

自定义指令:聊聊vue中的自定义指令应用法则

今天我们来聊聊vue中的自定义…

1 周 ago

聊聊Vue中@click.stop和@click.prevent

一起来学下聊聊Vue中@cli…

2 周 ago

Nginx 基本操作:启动、停止、重启命令。

我们来学习Nginx基础操作:…

2 周 ago

Vue3:手动清理keep-alive组件缓存的方法

Vue3中手动清理keep-a…

3 周 ago

聊聊React和Vue组件更新的实现及区别

React 和 Vue 都是当…

4 周 ago