Yii - นางแบบ

โมเดลคือวัตถุที่แสดงถึงตรรกะและกฎทางธุรกิจ ในการสร้างแบบจำลองคุณควรขยายไฟล์yii\base\Model คลาสหรือคลาสย่อย

คุณลักษณะ

แอตทริบิวต์แสดงถึงข้อมูลทางธุรกิจ สามารถเข้าถึงได้เช่นองค์ประกอบอาร์เรย์หรือคุณสมบัติของวัตถุ แต่ละแอตทริบิวต์เป็นคุณสมบัติที่เข้าถึงได้โดยสาธารณะของแบบจำลอง ในการระบุแอตทริบิวต์ที่โมเดลมีอยู่คุณควรแทนที่ไฟล์yii\base\Model::attributes() วิธี.

ให้เราดูที่ ContactForm รูปแบบของเทมเพลตแอปพลิเคชันพื้นฐาน

<?php
   namespace app\models;
   use Yii;
   use yii\base\Model;
   /**
   * ContactForm is the model behind the contact form.
   */
   class ContactForm extends Model {
      public $name; public $email;
      public $subject; public $body;
      public $verifyCode; /** * @return array the validation rules. */ public function rules() { return [ // name, email, subject and body are required [['name', 'email', 'subject', 'body'], 'required'], // email has to be a valid email address ['email', 'email'], // verifyCode needs to be entered correctly ['verifyCode', 'captcha'], ]; } /** * @return array customized attribute labels */ public function attributeLabels() { return [ 'verifyCode' => 'Verification Code', ]; } /** * Sends an email to the specified email address using the information collected by this model. * @param string $email the target email address
      * @return boolean whether the model passes validation
      */
      public function contact($email) { if ($this->validate()) {
            Yii::$app->mailer->compose() ->setTo($email)
               ->setFrom([$this->email => $this->name])
               ->setSubject($this->subject) ->setTextBody($this->body)
               ->send();
            return true;
         }
         return false;
      }
   }
?>

Step 1 - สร้างฟังก์ชันที่เรียกว่า actionShowContactModel ใน SiteController ด้วยรหัสต่อไปนี้

public function actionShowContactModel() { 
   $mContactForm = new \app\models\ContactForm(); $mContactForm->name = "contactForm"; 
   $mContactForm->email = "[email protected]"; $mContactForm->subject = "subject"; 
   $mContactForm->body = "body"; var_dump($mContactForm); 
}

ในโค้ดด้านบนเรากำหนดไฟล์ ContactForm โมเดลตั้งค่าคุณสมบัติและแสดงโมเดลบนหน้าจอ

Step 2 - ตอนนี้ถ้าคุณพิมพ์ http://localhost:8080/index.php?r=site/show-contact-model ในแถบที่อยู่ของเว็บเบราว์เซอร์คุณจะเห็นสิ่งต่อไปนี้

หากโมเดลของคุณขยายจาก yii\base\Modelจากนั้นตัวแปรสมาชิกทั้งหมด (สาธารณะและไม่คงที่) เป็นแอตทริบิวต์ มีห้าคุณลักษณะในไฟล์ContactForm รุ่น - ชื่อ, อีเมล, หัวเรื่อง, เนื้อหา, verifyCode และคุณสามารถเพิ่มรายการใหม่ได้อย่างง่ายดาย

ป้ายกำกับคุณสมบัติ

คุณมักจะต้องแสดงป้ายกำกับที่เกี่ยวข้องกับแอตทริบิวต์ โดยค่าเริ่มต้นป้ายกำกับแอตทริบิวต์จะถูกสร้างขึ้นโดยอัตโนมัติโดยไฟล์yii\base\Model::generateAttributeLabel()วิธี. หากต้องการประกาศป้ายกำกับแอตทริบิวต์ด้วยตนเองคุณสามารถแทนที่ไฟล์yii\base\Model::attributeLabels() วิธี.

Step 1 - หากคุณเปิด http://localhost:8080/index.php?r=site/contact, คุณจะเห็นหน้าต่อไปนี้

โปรดทราบว่าป้ายกำกับแอตทริบิวต์จะเหมือนกับชื่อ

Step 2 - ตอนนี้แก้ไขไฟล์ attributeLabels ฟังก์ชันใน ContactForm แบบจำลองด้วยวิธีต่อไปนี้

public function attributeLabels() {
   return [
      'name' => 'name overridden',
      'email' => 'email overridden',
      'subject' => 'subject overridden',
      'body' => 'body overridden',
      'verifyCode' => 'verifyCode overridden',
   ];
}

Step 3 - หากคุณเปิด http://localhost:8080/index.php?r=site/contact อีกครั้งคุณจะสังเกตเห็นว่าป้ายกำกับมีการเปลี่ยนแปลงดังที่แสดงในภาพต่อไปนี้

สถานการณ์

คุณสามารถใช้โมเดลในสถานการณ์ต่างๆ ตัวอย่างเช่นเมื่อแขกต้องการส่งแบบฟอร์มติดต่อเราต้องการแอตทริบิวต์โมเดลทั้งหมด เมื่อผู้ใช้ต้องการทำสิ่งเดียวกันเขาก็เข้าสู่ระบบแล้วดังนั้นเราจึงไม่จำเป็นต้องใช้ชื่อของเขาเพราะเราสามารถนำมาจากฐานข้อมูลได้อย่างง่ายดาย

ในการประกาศสถานการณ์เราควรลบล้างไฟล์ scenarios()ฟังก์ชัน ส่งคืนอาร์เรย์ที่มีคีย์เป็นชื่อและค่าของสถานการณ์active attributes. แอตทริบิวต์ที่ใช้งานอยู่เป็นสิ่งที่ต้องตรวจสอบ นอกจากนี้ยังสามารถmassively assigned.

Step 1 - แก้ไขไฟล์ ContactForm แบบจำลองด้วยวิธีต่อไปนี้

<?php
   namespace app\models;
   use Yii;
   use yii\base\Model;
   /**
   * ContactForm is the model behind the contact form.
   */
   class ContactForm extends Model {
      public $name; public $email;
      public $subject; public $body;
      public $verifyCode; const SCENARIO_EMAIL_FROM_GUEST = 'EMAIL_FROM_GUEST'; const SCENARIO_EMAIL_FROM_USER = 'EMAIL_FROM_USER'; public function scenarios() { return [ self::SCENARIO_EMAIL_FROM_GUEST => ['name', 'email', 'subject', 'body', 'verifyCode'], self::SCENARIO_EMAIL_FROM_USER => ['email' ,'subject', 'body', 'verifyCode'], ]; } /** * @return array the validation rules. */ public function rules() { return [ // name, email, subject and body are required [['name', 'email', 'subject', 'body'], 'required'], // email has to be a valid email address ['email', 'email'], // verifyCode needs to be entered correctly ['verifyCode', 'captcha'], ]; } /** * @return array customized attribute labels */ public function attributeLabels() { return [ 'name' => 'name overridden', 'email' => 'email overridden', 'subject' => 'subject overridden', 'body' => 'body overridden', 'verifyCode' => 'verifyCode overridden', ]; } /** * Sends an email to the specified email address using the information collected by this model. * @param string $email the target email address
      * @return boolean whether the model passes validation
      */
      public function contact($email) { if ($this -> validate()) {
            Yii::$app->mailer->compose() ->setTo($email)
               ->setFrom([$this->email => $this->name]) 
               ->setSubject($this->subject) ->setTextBody($this->body)
               ->send();
            return true;
         }
         return false;
      }
   }
?>

เราได้เพิ่มสองสถานการณ์ หนึ่งรายการสำหรับแขกและอีกรายการสำหรับผู้ใช้ที่ได้รับการพิสูจน์ตัวตน เมื่อผู้ใช้ได้รับการตรวจสอบสิทธิ์เราไม่จำเป็นต้องใช้ชื่อของเขา

Step 2 - ตอนนี้แก้ไขไฟล์ actionContact ฟังก์ชันของ SiteController.

public function actionContact() {
   $model = new ContactForm(); $model->scenario = ContactForm::SCENARIO_EMAIL_FROM_GUEST;
   if ($model->load(Yii::$app->request->post()) && $model-> contact(Yii::$app->params ['adminEmail'])) {
         Yii::$app->session->setFlash('contactFormSubmitted'); return $this->refresh();
   }
   return $this->render('contact', [ 'model' => $model,
   ]);
}

Step 3 - ประเภท http://localhost:8080/index.php?r=site/contactในเว็บเบราว์เซอร์ คุณจะสังเกตเห็นว่าปัจจุบันต้องมีแอตทริบิวต์โมเดลทั้งหมด

Step 4 - หากคุณเปลี่ยนสถานการณ์ของโมเดลในไฟล์ actionContactตามที่ระบุในรหัสต่อไปนี้คุณจะพบว่าแอตทริบิวต์ชื่อไม่จำเป็นอีกต่อไป

$model->scenario = ContactForm::SCENARIO_EMAIL_FROM_USER;

การมอบหมายงานจำนวนมาก

การกำหนดจำนวนมากเป็นวิธีที่สะดวกในการสร้างโมเดลจากแอตทริบิวต์อินพุตหลายรายการผ่านโค้ดบรรทัดเดียว

บรรทัดของรหัสคือ -

$mContactForm = new \app\models\ContactForm; 
$mContactForm->attributes = \Yii::$app->request->post('ContactForm');

บรรทัดโค้ดที่ระบุข้างต้นเทียบเท่ากับ -

$mContactForm = new \app\models\ContactForm; $postData = \Yii::$app->request->post('ContactForm', []); $mContactForm->name = isset($postData['name']) ? $postData['name'] : null; 
$mContactForm->email = isset($postData['email']) ? $postData['email'] : null; $mContactForm->subject = isset($postData['subject']) ? $postData['subject'] : null; 
$mContactForm->body = isset($postData['body']) ? $postData['body'] : null;

อดีตสะอาดกว่ามาก สังเกตว่าmassive assignment ใช้กับไฟล์ safe attributes. เป็นเพียงแอตทริบิวต์สถานการณ์ปัจจุบันที่แสดงอยู่ในไฟล์scenario() ฟังก์ชัน

การส่งออกข้อมูล

โมเดลมักจะต้องส่งออกในรูปแบบที่แตกต่างกัน ในการแปลงโมเดลเป็นอาร์เรย์ให้แก้ไขไฟล์actionShowContactModel ฟังก์ชันของ SiteController -

public function actionShowContactModel() {
   $mContactForm = new \app\models\ContactForm();
   $mContactForm->name = "contactForm"; $mContactForm->email = "[email protected]";
   $mContactForm->subject = "subject"; $mContactForm->body = "body";
   var_dump($mContactForm->attributes);
}

ประเภท http://localhost:8080/index.php?r=site/show-contact-model ในแถบที่อยู่และคุณจะเห็นสิ่งต่อไปนี้ -

ในการแปลง Model เป็น JSON แก้ไขรูปแบบ actionShowContactModel ฟังก์ชันดังต่อไปนี้ -

public function actionShowContactModel() {
   $mContactForm = new \app\models\ContactForm();
   $mContactForm->name = "contactForm"; $mContactForm->email = "[email protected]";
   $mContactForm->subject = "subject"; $mContactForm->body = "body";
   return \yii\helpers\Json::encode($mContactForm);
}

Browser output -

{
   "name":"contactForm",
   "email":"[email protected]",
   "subject":"subject",
   "body":"body ",
   "verifyCode":null
}

จุดสำคัญ

โมเดลมักจะเร็วกว่าคอนโทรลเลอร์ในแอปพลิเคชันที่ออกแบบมาอย่างดี แบบจำลองควร -

  • มีตรรกะทางธุรกิจ
  • มีกฎการตรวจสอบ
  • มีแอตทริบิวต์
  • ไม่ฝัง HTML
  • ไม่เข้าถึงคำขอโดยตรง
  • ไม่มีสถานการณ์มากเกินไป