
Pada artikel kali ini saya akan membuat serial tentang pemrograman dengan framework Yii. Seri ini akan disusun untuk membuat program sederhana yang menggunakan fitur-fitur umum yang mungkin digunakan dalam banyak kasus. Artikel ini akan menggunakan template Yii2 Basic (yang menurut saya sedikit lebih sulit digunakan dibandingkan template Yii2 advanced).
Secara umum (dan kemungkinan akan bertambah sesuai kebutuhan) garis besar rangkaian artikel ini terdiri dari berikut ini.
- Pra-instalasi
- Instalasi YiiFramework 2.0
- Login
- Masuk dengan database di Yii2
- Bekerja dengan G.I
- Modul di Yii2
- Tata letak dan manipulasi dasar di Yii2
- Aset Kustom dan Paket Aset di Yii2
- alias Yii2
- Bekerja dengan formulir
- Stempel waktu, Perilaku yang Dapat Disalahkan dan Dapat Dicela di Yii2
- Menggunakan input dan opsi teks kaya CkEditor di Yii2
- GridView dan ListView
- URL ramah SEO dengan siput
- Skenario model Yii2
- Ambil data di Yii2
- Hubungan database di Yii2
- Menggunakan Bootstrap4
- Widget Kartik dan Tampilan Grid Kartik
- Pilih dengan ekstensi Karthik
- Dropdown bergantung pada Yii2
- Bekerja dengan Modal
- Buat templat pakaian untuk GI
- Mengunggah berkas
- Mengunggah file dengan widget Karthik
- GridView atau DataTable?
- Sesi dan Cookie di Yii2
- Menggunakan AdminLTE di Yii2
- Membuat tema di Yii2
- Menggunakan API GoogleMaps di Yii2
- Menggunakan Socket.io di Yii2
- Kesalahan penanganan
- Bekerja dengan AuthClient
- Menggunakan Amazon S3 di Yii2
- Mengirim Email dengan Swiftmailer di Yii2
- Middleware di Yii2
- Mengenal RBAC di Yii2
- Implementasi RBAC di Yii2
- Notifikasi Waktu Nyata dengan Socket.io di Yii2
Anda dapat mengunduh dan memantau perkembangan seri ini melalui repositori Github Belajararief-yii2series. Silakan memberi bintang untuk dapat memantau perkembangan repositori dengan lebih mudah
persyaratan
Untuk memudahkan Anda memahami petunjuk ini, sebaiknya perhatikan beberapa hal:
- Sistem operasi yang saya gunakan adalah Windows 10 64bit menggunakan terminal Powershell dengan terminal (beberapa perintah seperti cd mungkin berbeda dari command prompt biasa), tetapi saya akan mencoba yang terbaik untuk memberikan contoh perintah pada sistem operasi lain jika memungkinkan.
- Stack yang digunakan adalah Wamp Server (Apache 2.2, MySQL, PHP 7).
- Yii yang digunakan adalah Yii 2.0 dengan catatan jquery yang digunakan bukan jquery3. Beberapa perintah jquery akan berbeda di jquery3, dan beberapa ekstensi yang saya gunakan tidak mendukung jquery3
Gi
Yii2 dilengkapi dengan code generator berbasis GUI yang menurut saya membedakan Yii2 dengan framework lainnya. Proses pembuatan prototipe dapat dilakukan lebih cepat dengan GI Menangani perubahan Saat memberikan demo menjadi mudah. Tapi apakah GI hanya untuk pembuatan prototipe? Tentu saja tidak. Jika banyak menu di aplikasi Anda memiliki pola tampilan yang sama, Anda dapat dengan mudah memperluas Gii untuk membuat template Anda sendiri. Bagaimana? Mari kita mencobanya.
Pada artikel ini kita akan membangun Gii sehingga dapat menyediakan AJAX Crud seperti yang kita buat sebelumnya. Kami akan membuat menu untuk mengelola bagian blog melalui GI yang dimodifikasi.
Duplikasi template CRUD generator default Yii2
Dalam contoh ini kita akan mengganti generator CRUD bawaan Yii2 dengan fungsi Ajax CRUD yang lebih menyenangkan. Untuk alasan ini, kami akan menyalin semua template default di direktori vendor/yiisoft/yii2-gii/src/generators/crud/default Setelah itu kita copy ke folder tersebut templates/modalcrud. Kami akan memberi nama template GI baru ini modalcrude.
Selanjutnya kita akan memodifikasi file yang diperlukan untuk menjalankan Ajax CRUD. Dokumen pertama yang akan kita modifikasi templates/modalcrud/controller.php Sehingga menjadi seperti di bawah ini.
<?php
/**
* This is the template for generating a CRUD controller class file.
*/
use yii\db\ActiveRecordInterface;
use yii\helpers\StringHelper;
/* @var $this yii\web\View */
/* @var $generator yii\gii\generators\crud\Generator */
$controllerClass = StringHelper::basename($generator->controllerClass);
$modelClass = StringHelper::basename($generator->modelClass);
$searchModelClass = StringHelper::basename($generator->searchModelClass);
if ($modelClass === $searchModelClass) {
$searchModelAlias = $searchModelClass . 'Search';
}
/* @var $class ActiveRecordInterface */
$class = $generator->modelClass;
$pks = $class::primaryKey();
$urlParams = $generator->generateUrlParams();
$actionParams = $generator->generateActionParams();
$actionParamComments = $generator->generateActionParamComments();
echo "<?php\n";
?>
namespace <?= StringHelper::dirname(ltrim($generator->controllerClass, '\\')) ?>;
use Yii;
use <?= ltrim($generator->modelClass, '\\') ?>;
<?php if (!empty($generator->searchModelClass)): ?>
use <?= ltrim($generator->searchModelClass, '\\') . (isset($searchModelAlias) ? " as $searchModelAlias" : "") ?>;
<?php else: ?>
use yii\data\ActiveDataProvider;
<?php endif; ?>
use <?= ltrim($generator->baseControllerClass, '\\') ?>;
use yii\web\NotFoundHttpException;
use yii\filters\VerbFilter;
/**
* <?= $controllerClass ?> implements the CRUD actions for <?= $modelClass ?> model.
*/
class <?= $controllerClass ?> extends <?= StringHelper::basename($generator->baseControllerClass) . "\n" ?>
{
/**
* @inheritdoc
*/
public function behaviors()
{
return [
'verbs' => [
'class' => VerbFilter::className(),
'actions' => [
'delete' => ['POST'],
],
],
];
}
/**
* Lists all <?= $modelClass ?> models.
* @return mixed
*/
public function actionIndex()
{
<?php if (!empty($generator->searchModelClass)): ?>
$searchModel = new <?= isset($searchModelAlias) ? $searchModelAlias : $searchModelClass ?>();
$dataProvider = $searchModel->search(Yii::$app->request->queryParams);
return $this->render('index', [
'searchModel' => $searchModel,
'dataProvider' => $dataProvider,
]);
<?php else: ?>
$dataProvider = new ActiveDataProvider([
'query' => <?= $modelClass ?>::find(),
]);
return $this->render('index', [
'dataProvider' => $dataProvider,
]);
<?php endif; ?>
}
/**
* Displays a single <?= $modelClass ?> model.
* <?= implode("\n * ", $actionParamComments) . "\n" ?>
* @return mixed
*/
public function actionView(<?= $actionParams ?>)
{
return $this->renderAjax('view', [
'model' => $this->findModel(<?= $actionParams ?>),
]);
}
/**
* Creates a new <?= $modelClass ?> model.
* If creation is successful, the browser will be redirected to the 'view' page.
* @return mixed
*/
public function actionCreate()
{
$model = new <?= $modelClass ?>();
if ($model->load(Yii::$app->request->post())) {
if ($model->save()){
return 1;
} else {
return 0;
}
} else {
return $this->renderAjax('_form', [
'model' => $model,
]);
}
}
/**
* Updates an existing <?= $modelClass ?> model.
* If update is successful, the browser will be redirected to the 'view' page.
* <?= implode("\n * ", $actionParamComments) . "\n" ?>
* @return mixed
*/
public function actionUpdate(<?= $actionParams ?>)
{
$model = $this->findModel(<?= $actionParams ?>);
if ($model->load(Yii::$app->request->post())) {
if ($model->save()){
return 1;
} else {
return 0;
}
} else {
return $this->renderAjax('_form', [
'model' => $model,
]);
}
}
/**
* Deletes an existing <?= $modelClass ?> model.
* If deletion is successful, the browser will be redirected to the 'index' page.
* <?= implode("\n * ", $actionParamComments) . "\n" ?>
* @return mixed
*/
public function actionDelete(<?= $actionParams ?>)
{
$this->findModel(<?= $actionParams ?>)->delete();
return $this->redirect(Yii::$app->request->referrer);
}
/**
* Finds the <?= $modelClass ?> model based on its primary key value.
* If the model is not found, a 404 HTTP exception will be thrown.
* <?= implode("\n * ", $actionParamComments) . "\n" ?>
* @return <?= $modelClass ?> the loaded model
* @throws NotFoundHttpException if the model cannot be found
*/
protected function findModel(<?= $actionParams ?>)
{
<?php
if (count($pks) === 1) {
$condition = '$id';
} else {
$condition = [];
foreach ($pks as $pk) {
$condition[] = "'$pk' => \$$pk";
}
$condition = '[' . implode(', ', $condition) . ']';
}
?>
if (($model = <?= $modelClass ?>::findOne(<?= $condition ?>)) !== null) {
return $model;
} else {
throw new NotFoundHttpException('The requested page does not exist.');
}
}
}
Selanjutnya kita akan memodifikasi file indeks templates/modalcrud/views/index.php Sehingga menjadi seperti di bawah ini.
<?php
use yii\helpers\Inflector;
use yii\helpers\StringHelper;
/* @var $this yii\web\View */
/* @var $generator yii\gii\generators\crud\Generator */
$urlParams = $generator->generateUrlParams();
$nameAttribute = $generator->getNameAttribute();
echo "<?php\n";
?>
use yii\helpers\Html;
use <?= $generator->indexWidgetType === 'grid' ? "kartik\\grid\\GridView" : "yii\\widgets\\ListView" ?>;
<?= $generator->enablePjax ? 'use yii\widgets\Pjax;' : '' ?>
use yii\bootstrap4\Modal;
/* @var $this yii\web\View */
<?= !empty($generator->searchModelClass) ? "/* @var \$searchModel " . ltrim($generator->searchModelClass, '\\') . " */\n" : '' ?>
/* @var $dataProvider yii\data\ActiveDataProvider */
$this->title = <?= $generator->generateString(Inflector::pluralize(Inflector::camel2words(StringHelper::basename($generator->modelClass)))) ?>;
$this->params['breadcrumbs'][] = $this->title;
?>
<div class="<?= Inflector::camel2id(StringHelper::basename($generator->modelClass)) ?>-index">
<h1><?= "<?= " ?>Html::encode($this->title) ?></h1>
<?php if(!empty($generator->searchModelClass)): ?>
<?= " <?php " . ($generator->indexWidgetType === 'grid' ? "// " : "") ?>echo $this->render('_search', ['model' => $searchModel]); ?>
<?php endif; ?>
<p>
<?= "<?= " ?>Html::a(<?= $generator->generateString('Tambah ' . Inflector::camel2words(StringHelper::basename($generator->modelClass))) ?>, ['create'], [
'class' => 'btn btn-xs btn-success',
'data-toggle'=>"modal",
'data-target'=>"#myModal",
'data-title'=> <?= $generator->generateString("Tambah " . Inflector::camel2words(StringHelper::basename($generator->modelClass))) ?>,
]) ?>
</p>
<?php if ($generator->indexWidgetType === 'grid'): ?>
<?= "<?= " ?>GridView::widget([
'id' => '<?= Inflector::camel2id(StringHelper::basename($generator->modelClass)) ?>',
'dataProvider' => $dataProvider,
'export' => true,
'responsive'=>true,
'hover'=>true,
'resizableColumns'=>true,
'panel'=>['type'=>'primary', 'heading'=>$this->title],
'responsiveWrap' => false,
'toolbar' => [
[
'content' => '{export}{toggleData}' // $this->render('_search', ['model' => $searchModel]),
],
],
// set export properties
'export' => [
'fontAwesome' => true
],
'pager' => [
'firstPageLabel' => 'Awal',
'lastPageLabel' => 'Akhir'
],
'pjax'=>true,
'pjaxSettings'=>[
'options' => ['id' => '<?= Inflector::camel2id(StringHelper::basename($generator->modelClass)) ?>-pjax', 'timeout' => 5000],
],
<?= !empty($generator->searchModelClass) ? "'filterModel' => \$searchModel,\n 'columns' => [\n" : "'columns' => [\n"; ?>
['class' => 'yii\grid\SerialColumn'],
<?php
$count = 0;
if (($tableSchema = $generator->getTableSchema()) === false) {
foreach ($generator->getColumnNames() as $name) {
if (++$count < 6) {
echo " '" . $name . "',\n";
} else {
echo " // '" . $name . "',\n";
}
}
} else {
foreach ($tableSchema->columns as $column) {
$format = $generator->generateColumnFormat($column);
if (++$count < 6) {
echo " '" . $column->name . ($format === 'text' ? "" : ":" . $format) . "',\n";
} else {
echo " // '" . $column->name . ($format === 'text' ? "" : ":" . $format) . "',\n";
}
}
}
?>
[
'class' => 'kartik\grid\ActionColumn',
'template' => '{view} {update} {delete}',
'noWrap' => true,
'vAlign'=>'top',
'buttons' => [
'update' => function ($url, $model) {
return Html::a('<span class="fas fa-edit"></span>', $url,
[
'title' => Yii::t('yii', 'ubah'),
'data-toggle'=>"modal",
'data-target'=>"#myModal",
'data-title'=> "Ubah",
// 'data-confirm' => "Yakin menghapus ini?",
// 'data-method' => 'POST',
// 'data-pjax' => 1
]);
},
'view' => function ($url, $model) {
return Html::a('<span class="fas fa-eye"></span>', $url,
[
'title' => Yii::t('yii', 'lihat'),
'data-toggle'=>"modal",
'data-target'=>"#myModal",
'data-title'=> "Lihat",
]);
},
]
],
],
]); ?>
<?php else: ?>
<?= "<?= " ?>ListView::widget([
'dataProvider' => $dataProvider,
'itemOptions' => ['class' => 'item'],
'itemView' => function ($model, $key, $index, $widget) {
return Html::a(Html::encode($model-><?= $nameAttribute ?>), ['view', <?= $urlParams ?>]);
},
]) ?>
<?php endif; ?>
</div>
<?= "<?php " ?>
Modal::begin([
'id' => 'myModal',
'title' => 'Lihat lebih...',
'options' => [
'tabindex' => false // important for Select2 to work properly
],
]);
echo '...';
Modal::end();
$this->registerJs("
$('#myModal').on('show.bs.modal', function (event) {
var button = $(event.relatedTarget)
var modal = $(this)
var title = button.data('title')
var href = button.attr('href')
modal.find('.modal-title').html(title)
modal.find('.modal-body').html('<i class=\"fa fa-spinner fa-spin\"></i>')
$.post(href)
.done(function( data ) {
modal.find('.modal-body').html(data)
});
})
");
?>
Selanjutnya kita akan memodifikasi file form templates/modalcrud/views/_form.php Sehingga menjadi seperti di bawah ini.
<?php
use yii\helpers\Inflector;
use yii\helpers\StringHelper;
/* @var $this yii\web\View */
/* @var $generator yii\gii\generators\crud\Generator */
/* @var $model \yii\db\ActiveRecord */
$model = new $generator->modelClass();
$safeAttributes = $model->safeAttributes();
if (empty($safeAttributes)) {
$safeAttributes = $model->attributes();
}
echo "<?php\n";
?>
use yii\helpers\Html;
use yii\widgets\ActiveForm;
/* @var $this yii\web\View */
/* @var $model <?= ltrim($generator->modelClass, '\\') ?> */
/* @var $form yii\widgets\ActiveForm */
?>
<div class="<?= Inflector::camel2id(StringHelper::basename($generator->modelClass)) ?>-form">
<?= "<?php " ?>$form = ActiveForm::begin(['id' => $model->formName()]); ?>
<?php foreach ($generator->getColumnNames() as $attribute) {
if (in_array($attribute, $safeAttributes)) {
echo " <?= " . $generator->generateActiveField($attribute) . " ?>\n\n";
}
} ?>
<div class="form-group">
<?= "<?= " ?>Html::submitButton($model->isNewRecord ? <?= $generator->generateString('Create') ?> : <?= $generator->generateString('Update') ?>, ['class' => $model->isNewRecord ? 'btn btn-success' : 'btn btn-primary']) ?>
</div>
<?= "<?php " ?>ActiveForm::end(); ?>
</div>
<?= "<?php " ?>
$script = <<<JS
$('form#{$model->formName()}').on('beforeSubmit',function(e)
{
var \$form = $(this);
$.post(
\$form.attr("action"), //serialize Yii2 form
\$form.serialize()
)
.done(function(result){
if(result == 1)
{
$("#myModal").modal('hide'); //hide modal after submit
//$(\$form).trigger("reset"); //reset form to reuse it to input
$.pjax.reload({container:'#<?= Inflector::camel2id(StringHelper::basename($generator->modelClass)) ?>-pjax'});
}else
{
$("#message").html(result);
}
}).fail(function(){
console.log("server error");
});
return false;
});
JS;
$this->registerJs($script);
?>
Ubah konfigurasi dengan menambahkan templat tambahan
Selanjutnya kita akan memodifikasi konfigurasi Gii untuk menambahkan modalcrud ke opsi template Gii CRUD kita. perubahan berkas config/web.php Sehingga bagian GI menjadi seperti di bawah ini.
if (YII_ENV_DEV) {
// configuration adjustments for 'dev' environment
$config['bootstrap'][] = 'debug';
$config['modules']['debug'] = [
'class' => 'yii\debug\Module',
// uncomment the following to add your IP if you are not connecting from localhost.
//'allowedIPs' => ['127.0.0.1', '::1'],
];
$config['bootstrap'][] = 'gii';
$config['modules']['gii'] = [
'class' => 'yii\gii\Module',
// uncomment the following to add your IP if you are not connecting from localhost.
//'allowedIPs' => ['127.0.0.1', '::1'],
'generators' => [
'crud' => [
'class' => 'yii\gii\generators\crud\Generator',
'templates' => ['modalcrud' => '@app/templates/modalcrud']
]
]
];
}
Buat CRUD dan menu untuk mengelola bagian blog
Setelah template dan setting dibuat, saatnya membuat template Ajax CRUD untuk tabel kategori menggunakan GI yang telah dimodifikasi. Akses Gii lalu pilih Crud Generator. Selanjutnya isi informasi seperti dibawah ini.
Pada contoh di atas kita menggunakan template kode ModalCrude yang kita buat sebelumnya. tekan pratinjau Setelah itu tekan membuat.
Setelah kita membuat CRUD, jangan lupa menambahkan menu untuk mengakses kategori. perubahan berkas views/layouts/main.php dan memodifikasi bagian tersebut Nav::widget() Sehingga menjadi seperti di bawah ini.
echo Nav::widget([
'options' => ['class' => 'navbar-nav ml-auto'],
'items' => [
['label' => 'Home', 'url' => ['/site/index']],
['label' => 'About', 'url' => ['/site/about']],
['label' => 'Contact', 'url' => ['/site/contact']],
['label' => 'Blog', 'url' => ['/administrator/blog'], 'visible' => !Yii::$app->user->isGuest, 'items' => [
['label' => 'Manajemen', 'url' => ['/administrator/blog']],
['label' => 'Statistik', 'url' => ['/administrator/statistik']],
['label' => 'Kategori', 'url' => ['/administrator/category']],
]],
['label' => 'Register', 'url' => ['/site/signup'], 'visible' => Yii::$app->user->isGuest],
Yii::$app->user->isGuest ? (
['label' => 'Login', 'url' => ['/site/login']]
) : (
'<li>'
. Html::beginForm(['/site/logout'], 'post')
. Html::submitButton(
'Logout (' . Yii::$app->user->identity->username . ')',
['class' => 'btn btn-outline-success my-2 my-sm-0'] // logout btn-link
)
. Html::endForm()
. '</li>'
)
],
]);
Sekian artikel kali ini, semoga bermanfaat dan selamat coding!
Berita Terkini
Berita Terbaru
Daftar Terbaru
News
Jasa Impor China
Berita Terbaru
Flash News
RuangJP
Pemilu
Berita Terkini
Prediksi Bola
Technology
Otomotif
Berita Terbaru
Teknologi
Berita terkini
Berita Pemilu
Berita Teknologi
Hiburan
master Slote
Berita Terkini
Pendidikan
Resep
Jasa Backlink
Slot gacor terpercaya
Anime Batch
