1. 모델 생성
a. 기본 클래스 추가
yii/base/Model 사용
b. 클래스 상속 자체 기반 클래스
c. 필수 변수를 생성합니다
e. 규칙을 정의합니다
f. 🎜> 예:
이 클래스는 일반적으로 데이터를 표현하는 데 사용되는 Yii에서 제공하는 기본 클래스 [[yiibaseModel]]를 상속합니다<?<span>php namespace app\models; </span><span>use</span><span> yii\base\Model; </span><span>class</span> EntryForm <span>extends</span><span> Model { </span><span>public</span> <span>$name</span><span>; </span><span>public</span> <span>$email</span><span>; </span><span>public</span> <span>function</span><span> rules() { </span><span>return</span><span> [ [[</span>'name', 'email'], 'required'],<span> [</span>'email', 'email'],<span> ]; } }</span>로그인 후 복사보충: [[yiibaseModel]]은 일반 모델 클래스의 상위 클래스로 사용되며 데이터 테이블과 관련이 없습니다. [[yiidbActiveRecord]]는 일반적으로 일반 모델 클래스의 상위 클래스이지만 데이터 테이블과 관련되어 있습니다. (번역: [[yiidbActiveRecord]] 클래스는 실제로 [[yiibaseModel]]에서 상속되어 데이터베이스 처리를 추가합니다.)클래스에는 사용자가 입력한 데이터를 저장하는 데 사용되는 두 개의 공개 멤버
및
EntryForm
가 포함되어 있습니다. 또한 데이터 유효성 검사 규칙 모음을 반환하는name
이라는 메서드도 포함되어 있습니다. 위에서 선언된 유효성 검사 규칙은 다음을 의미합니다.rules()
및
개체가 있는 경우 해당 [[yiibaseModel::validate()|validate()]] 메서드를 호출하여 데이터 유효성 검사를 트리거할 수 있습니다. 데이터 검증이 실패하면 [[yiibaseModel::hasErrors|hasErrors]] 속성이 true로 설정됩니다. 어떤 오류가 발생했는지 알고 싶다면 [[yiibaseModel::getErrors|getErrors]]를 호출하세요.- 값이 모두 필수입니다.
name
- 사용자가 제출한 데이터를 처리하는
EntryForm
2. 생성 작업<?<span>php </span><span>$model</span> = <span>new</span><span> EntryForm(); </span><span>$model</span>->name = 'Qiang'<span>; </span><span>$model</span>->email = 'bad'<span>; </span><span>if</span> (<span>$model</span>-><span>validate()) { </span><span>//</span><span> 验证成功!</span> } <span>else</span><span> { </span><span>//</span><span> 失败! // 使用 $model->getErrors() 获取错误详情</span> }로그인 후 복사다음으로 새 모델에 대한
컨트롤러에서작업을 만들어야 합니다. 액션의 생성과 사용은 Say hello 섹션에서 설명되었습니다.
site
entry
이 작업은 먼저 객체를 생성합니다. 그런 다음 Yii의 [[yiiwebRequest::post()]] 메소드를 통해 수집되는<?<span>php namespace app\controllers; </span><span>use</span><span> Yii; </span><span>use</span><span> yii\web\Controller; </span><span>use</span><span> app\models\EntryForm; </span><span>class</span> SiteController <span>extends</span><span> Controller { </span><span>//</span><span> ...其它代码...</span> <span>public</span> <span>function</span><span> actionEntry() { </span><span>$model</span> = <span>new</span><span> EntryForm; </span><span>if</span> (<span>$model</span>->load(Yii::<span>$app</span>->request->post()) && <span>$model</span>-><span>validate()) { </span><span>//</span><span> 验证 $model 收到的数据 // 做些有意义的事 ...</span> <span>return</span> <span>$this</span>->render('entry-confirm', ['model' => <span>$model</span><span>]); } </span><span>else</span><span> { </span><span>//</span><span> 无论是初始化显示还是数据验证错误</span> <span>return</span> <span>$this</span>->render('entry', ['model' => <span>$model</span><span>]); } } }</span>로그인 후 복사에서 사용자가 제출한 데이터를 수집해 보세요. 모델이 데이터로 성공적으로 채워지면(즉, 사용자가 HTML 양식을 제출한 경우) 작업은 [[yiibaseModel::validate()|validate()]]를 호출하여 사용자가 유효한 데이터를 제출했는지 확인합니다.
EntryForm
$_POST
보충:이라는 뷰를 렌더링합니다. 양식을 작성하지 않고 제출하거나 데이터에 오류가 있는 경우(번역기: 이메일 형식이 올바르지 않은 등)표현식은 전역적으로 액세스 가능한 싱글톤인
사용자가 양식을 제출한 후 작업은 사용자가 입력한 데이터를 확인하기 위해Yii::$app
애플리케이션 인스턴스를 나타냅니다. 동시에 , , 및 기타 특정 기능을 갖춘 구성 요소를 제공할 수 있는 서비스 로케이터request
이기도 합니다. 위 코드에서response
구성 요소는 애플리케이션 인스턴스가 수신한db
데이터에 액세스하는 데 사용됩니다.request
$_POST
보기는 양식 및 유효성 검사 오류 세부정보와 함께 출력을 렌더링합니다.
entry-confirm
entry
참고: 이 간단한 예에서는 유효한 데이터가 있는 확인 페이지만 표시합니다. 실제로는 반복되는 양식 제출 문제를3. 뷰 만들기피하려면 [[yiiwebController::refresh()|refresh()]] 또는 [[yiiwebController::redirect()|redirect()]] 사용을 고려해야 합니다. .
마지막으로 두 개의 보기 파일
과을 만듭니다. 방금 생성된
entry-confirm
액션에 의해 렌더링됩니다.entry
entry
보기에는 제출된 이름과 이메일 데이터가 표시됩니다. 보기 파일은에 저장됩니다.
entry-confirm
views/site/entry-confirm.php
<?<span>php </span><span>use</span><span> yii\helpers\Html; </span>?> <p>You have entered the following information:</p> <ul> <li><label>Name</label>: <?= Html::encode(<span>$model</span>->name) ?></li> <li><label>Email</label>: <?= Html::encode(<span>$model</span>->email) ?></li> </ul>로그인 후 복사보기에는 HTML 양식이 표시됩니다. 보기 파일은
entry
에 저장됩니다.views/site/entry.php
이 보기는 강력한 위젯 [[yiiwidgetsActiveForm|ActiveForm]]을 사용하여 HTML 양식을 생성합니다.<?<span>php </span><span>use</span><span> yii\helpers\Html; </span><span>use</span><span> yii\widgets\ActiveForm; </span>?> <?php <span>$form</span> = ActiveForm::begin(); ?> <?= <span>$form</span>->field(<span>$model</span>, 'name') ?> <?= <span>$form</span>->field(<span>$model</span>, 'email') ?> <div <span>class</span>="form-group"> <?= Html::submitButton('Submit', ['class' => 'btn btn-primary']) ?> </div> <?php ActiveForm::<span>end</span>(); ?>로그인 후 복사및은 각각 양식의 여는 태그와 닫는 태그를 렌더링하는 데 사용됩니다. [[yiiwidgetsActiveForm::field()|field()]] 메서드는 입력 상자를 생성하기 위해 이 두 메서드 사이에 사용됩니다. 첫 번째 입력 상자는 "이름"이고 두 번째 입력 상자는 "이메일"입니다. 그런 다음 [[yiihelpersHtml::submitButton()]] 메서드를 사용하여 제출 버튼을 생성합니다.
begin()
end()
위젯을 사용하는 것을 잊지 말고 이 두 가지를 소개해야 합니다<span>use</span><span> yii\helpers\Html; </span><span>use</span> yii\wigets\ActiveForm;로그인 후 복사위 내용은 내용의 측면을 포함하여 Yii의 Forms 사용을 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.