CakePHP - Penanganan Formulir

CakePHP menyediakan berbagai tag bawaan untuk menangani formulir HTML dengan mudah dan aman. Seperti banyak kerangka kerja PHP lainnya, elemen utama HTML juga dibuat menggunakan CakePHP. Berikut adalah berbagai fungsi yang digunakan untuk menghasilkan elemen HTML.

Fungsi berikut digunakan untuk generate select options -

Sintaksis _selectOptions (larik $ elementsarray () , larik $ parentarray () , boolean $ showParentsnull , larik $ atributesarray () )
Parameter
  • Elemen untuk diformat

  • Orang tua untuk OPTGROUP

  • Apakah akan menunjukkan kepada orang tua

  • Atribut HTML

Kembali Himpunan
Deskripsi Mengembalikan larik elemen OPTION / OPTGROUP yang diformat

Fungsi berikut digunakan to generate HTML select element.

Sintaksis pilih (string $ fieldName, array $ options array (), array $ atribut array ())
Parameter

Atribut nama dari SELECT

Array elemen OPTION (sebagai pasangan 'value' => 'Text') yang akan digunakan dalam elemen SELECT.

Kembali Elemen SELECT yang telah diformat.
Deskripsi Mengembalikan elemen SELECT yang telah diformat.

Fungsi berikut digunakan to generate button di halaman HTML.

Sintaksis

Tombol (string $ title, array $ optionsarray ())

Parameter
  • Judul tombol. Tidak secara otomatis dikodekan HTML.

  • Array opsi dan atribut HTML

Kembali Tag tombol HTML.
Deskripsi

Membuat a <button>menandai. Defaultnya adalah atribut typetype="submit". Anda dapat mengubahnya ke nilai yang berbeda dengan menggunakan$options['type'].

Fungsi berikut digunakan to generate checkbox di halaman HTML.

Sintaksis Kotak centang (string $ fieldName, array $ optionsarray ())
Parameter
  • Nama kolom, seperti ini "Modelname.fieldname"

  • Array atribut HTML. Opsi yang memungkinkan adalah nilai, dicentang, hiddenField, nonaktif, default.

Kembali Elemen input teks HTML.
Deskripsi Membuat widget masukan kotak centang.

Fungsi berikut digunakan to create form di halaman HTML.

Sintaksis buat (campuran $ modelnull , array $ optionsarray () )
Parameter
  • Nama model yang bentuknya didefinisikan. Harus menyertakan nama plugin untuk model plugin. misalnya ContactManager.Contact. Jika sebuah array dilewatkan dan argumen $ options kosong, array tersebut akan digunakan sebagai opsi. Jika salah, tidak ada model yang digunakan.

  • Larik atribut dan opsi html. Opsi yang memungkinkan adalah type, action, url, default, onsubmit, inputDefaults, encoding.

Kembali

Tag FORMULIR pembuka yang diformat.

Deskripsi Mengembalikan elemen HTML FORM.

Fungsi berikut digunakan untuk provide file uploading functionality di halaman HTML.

Sintaksis

file (string $ fieldName, array $ optionsarray ())

Parameter
  • Nama field, dalam bentuk "Modelname.fieldname"

  • Array atribut HTML.

Kembali

Input file yang dihasilkan.

Deskripsi

Membuat widget input file.

Fungsi berikut digunakan untuk membuat hidden element di halaman HTML.

Sintaksis

tersembunyi (string $ fieldName , array $ optionsarray () )

Parameter
  • Nama field, berupa "Modelname.fieldname"

  • Array atribut HTML.

Kembali

Sebuah masukan tersembunyi yang dihasilkan

Deskripsi

Membuat bidang masukan tersembunyi

Fungsi berikut digunakan untuk menghasilkan input element di halaman HTML.

Sintaksis

Masukan (string $ fieldName, array $ options array ())

Parameter
  • Ini harus menjadi "Modelname.fieldname"

  • Setiap jenis masukan mengambil opsi yang berbeda

Kembali

Widget formulir lengkap

Deskripsi

Menghasilkan elemen input formulir lengkap dengan label dan div pembungkus

Fungsi berikut digunakan untuk menghasilkan radio button di halaman HTML.

Sintaksis

Radio (string $ fieldName , larik $ optionsarray () , larik $ atributesarray () )

Parameter
  • Nama kolom, seperti ini "Modelname.fieldname"

  • Array opsi tombol radio.

  • Array atribut HTML, dan atribut khusus di atas.

Kembali Set widget radio selesai
Deskripsi Membuat satu set widget radio. Akan membuat legenda dan fieldset secara default. Gunakan $ options untuk mengontrol ini.

Fungsi berikut digunakan untuk menghasilkan submit tombol di halaman HTML.

Sintaksis Kirim (string $ caption null, array $ options array ())
Parameter
  • Label yang muncul di tombol ATAU jika string berisi: // atau ekstensi .jpg, .jpe, .jpeg, .gif, .png. Gunakan gambar jika ekstensi ada, DAN karakter pertama adalah /, gambar relatif terhadap webroot, ATAU jika karakter pertama bukan /, gambar relatif terhadap webroot / img.

  • Array opsi. Opsi yang memungkinkan adalah div, before, after, type dll.

Kembali

Tombol kirim HTML

Deskripsi Membuat elemen tombol kirim. Metode ini akan menghasilkan <input /> elemen yang dapat digunakan untuk mengirimkan, dan mengatur ulang formulir dengan menggunakan $ options. Pengiriman gambar dapat dibuat dengan menyediakan jalur gambar untuk $ caption.

Fungsi berikut digunakan to generate textarea element di halaman HTML.

Sintaksis

Textarea (string $ fieldName, array $ options array ())

Parameter
  • Nama field, dalam bentuk "Modelname.fieldname"

  • Array atribut HTML, opsi khusus seperti escape

Kembali Elemen input teks HTML yang dihasilkan
Deskripsi Membuat widget textarea

Contoh

Lakukan perubahan di config/routes.php file seperti yang ditunjukkan pada kode berikut.

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf');
   //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']);
   $builder->connect('register',['controller'=>'Registrations','action'=>'index']);
   $builder->fallbacks();
});

Membuat RegistrationsController.php mengajukan di

src/Controller/RegistrationsController.php. Salin kode berikut di file pengontrol.

src/Controller/RegistrationsController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   class RegistrationsController extends AppController{
      public function index(){
         $country = array('India','United State of America','United Kingdom');
         $this->set('country',$country);
         $gender = array('Male','Female');
         $this->set('gender',$gender);
      }
   }
?>

Buat direktori Registrations di src/Template dan di bawah direktori itu, buat file View file bernama index.php. Salin kode berikut di file itu.

src/Template/Registrations/index.php

<?php
   echo $this->Form->create(NULL,array('url'=>'/register'));
   echo '<label for="country">Country</label>';
   echo $this->Form->select('country',$country);
   echo '<label for="gender">Gender</label>';
   echo $this->Form->radio('gender ',$gender);
   echo '<label for="address">Address</label>';
   echo $this->Form->textarea('address');
   echo $this->Form->file('profilepic');
   echo '<div>'.$this->Form->checkbox('terms').
      '<label for="country">Terms ∓ Conditions</label></div>';
   echo $this->Form->button('Submit');
   echo $this->Form->end();
?>

Jalankan contoh di atas dengan mengunjungi URL berikut -

http: // localhost / cakephp4 / register

Keluaran

Setelah dieksekusi, Anda akan menerima keluaran berikut.