Rumah >pembangunan bahagian belakang >tutorial php >Memperluas Oktobercms - Membina Plugin Lembut Delete
pemaju umumnya lebih suka CMS yang mudah digunakan dan berskala. OktoberCMS mematuhi konsep kesederhanaan terlebih dahulu, membawa pengalaman yang menyenangkan kepada pemaju dan pengguna. Artikel ini menunjukkan beberapa ciri-ciri yang boleh dilanjutkan dari OktoberCMS dan memanjangkan fungsi pemalam yang lain dengan pemalam yang mudah.
mata utama
deleted_at
yang dicetuskan oleh fasih, menghalang penghapusan rekod. Sebaliknya, medan deleted_at
deleting
Pengenalan
deleted_at
Setiap CMS mempunyai sistem pemalam untuk memperluaskan fungsi platform, dan kami mengukur skalabilitasnya dengan sejauh mana kita dapat menembusi mekanisme dalaman CMS. Walau bagaimanapun, kita bercakap tentang bukan sahaja CMS itu sendiri, tetapi juga pemalam!
pemaju lain boleh mendengar acara ini untuk mengendalikan artikel yang diterbitkan.
kami akan menggunakan peristiwa untuk menyambungkan bahagian -bahagian yang berlainan dari kitaran permintaan. Mari kita mulakan dengan contoh konkrit untuk lebih memahami.
<code class="language-php">class Posts extends Controller { public function index_onPublish() { if (($checkedIds = post('checked')) && is_array($checkedIds) && count($checkedIds)) { foreach ($checkedIds as $postId) { if ((!$post = Post::find($postId)) || !$post->canEdit($this->user)) continue; $post->publish(); Event::fire('rainlab.blog.posts.published', [$post]); } Flash::success('Successfully published those posts.'); } return $this->listRefresh(); } }</code>
Rainlab Blog Plugin
<code class="language-php">Event::listen('rainlab.blog.posts.published', function($post) { User::subscribedTo($post)->each(function($user) use($post) { Mail::send('emails.notifications.post-published', ['user' => $user, 'post' => $post], function($message) use($user, $post) { $message->from('us@example.com', 'New post by ' . $user->name); $message->to($user->email); }); }); });</code>Jika anda telah menggunakan OktoberCMS untuk seketika, anda mesti tahu mengenai plugin Rainlab Blog. Ia membolehkan anda menambah artikel di backend dan melampirkannya ke kategori, dan anda boleh menggunakan komponen untuk memaparkannya di bahagian depan.
Pada halaman senarai artikel, kami boleh memadamkan artikel. Tetapi bagaimana jika kita mahu memadamkannya dengan lembut? Mari kita lihat jika kita boleh melakukan ini dan mengetahui lebih lanjut mengenai skalabiliti OktoberCMS.
Buat plugin baru untuk demo kami menggunakan perintah pembantu perancah dan kemas kini butiran plugin dalam fail plugin.php.
<code class="language-php">class Posts extends Controller { public function index_onPublish() { if (($checkedIds = post('checked')) && is_array($checkedIds) && count($checkedIds)) { foreach ($checkedIds as $postId) { if ((!$post = Post::find($postId)) || !$post->canEdit($this->user)) continue; $post->publish(); Event::fire('rainlab.blog.posts.published', [$post]); } Flash::success('Successfully published those posts.'); } return $this->listRefresh(); } }</code>
Apabila bercakap tentang pemadaman lembut, perkara pertama yang masuk ke dalam fikiran ialah lajur medan deleted_at
yang perlu wujud dalam pangkalan data.
Buat fail baru bernama blogplus/updates
di bawah folder create_posts_deleted_at_field.php
dan kemas kini fail version.yaml
.
<code class="language-php">Event::listen('rainlab.blog.posts.published', function($post) { User::subscribedTo($post)->each(function($user) use($post) { Mail::send('emails.notifications.post-published', ['user' => $user, 'post' => $post], function($message) use($user, $post) { $message->from('us@example.com', 'New post by ' . $user->name); $message->to($user->email); }); }); });</code>
<code class="language-bash">php artisan create:plugin rafie.blogplus</code>
Migrasi kelas mengubah jadual rainlab_blog_posts
dan menambah lajur deleted_at
kami, yang mungkir ke NULL. Jangan lupa untuk menjalankan perintah php artisan plugin:refresh rafie.blogplus
untuk membuat perubahan berkuatkuasa.
<code class="language-yaml"># updates/version.yaml 1.0.1: - First version of blogplus. - create_posts_deleted_at_field.php</code>Nota: Kod di atas harus diletakkan dalam kaedah
. Plugin@boot
untuk memadam mana -mana lajur yang ada. Semak dokumentasi untuk senarai pilihan lajur yang tersedia. removeColumn
Penapis lanjutan
Anda boleh membaca lebih lanjut mengenai penapis senarai dalam dokumentasi. Kod di atas agak mudah dan hanya mengandungi beberapa pilihan. Walau bagaimanapun, atribut
<code class="language-php"># updates/create_posts_deleted_at_field.php use Illuminate\Database\Migrations\Migration; use Illuminate\Database\Schema\Blueprint; use Illuminate\Support\Facades\Schema; class CreatePostsDeletedAtField extends Migration { public function up() { Schema::table('rainlab_blog_posts', function (Blueprint $table) { $table->timestamp('deleted_at')->nullable()->default(null); }); } public function down() { Schema::table('rainlab_blog_posts', function (Blueprint $table) { $table->dropColumn('deleted_at'); }); } }</code>hendaklah menjadi nama kaedah skop pertanyaan yang ditakrifkan dalam contoh model
. scope
Models\Post
kelas extensible
Kaedah untuk melanjutkan kelas sedia ada dengan menambahkan kaedah baru, atribut, tingkah laku, dll. Dalam contoh kami, kami perlu menambah kaedah baru kepada model artikel untuk mengendalikan penapis skop kami.
kita boleh melakukan perkara yang sama untuk<code class="language-php">// plugin.php 在Plugin类的boot方法中 Event::listen('backend.list.extendColumns', function ($widget) { if (!($widget->getController() instanceof \Rainlab\Blog\Controllers\Posts)) { return; } $widget->addColumns([ 'deleted_at' => [ 'label' => 'Deleted', 'type' => 'date', ], ]); });</code>,
, dll. Mari menyegarkan senarai artikel kami untuk melihat apakah perubahan kami berfungsi. addDynamicProperty
asExtension
Sudah tentu, kita tidak mempunyai artikel yang dipadam lagi, kerana kita perlu melengkapkan bahagian terakhir: memintas operasi penghapusan artikel, dan hanya mengemas kini lajur
. Petua: Daripada menggunakan harta
<code class="language-php">class Posts extends Controller { public function index_onPublish() { if (($checkedIds = post('checked')) && is_array($checkedIds) && count($checkedIds)) { foreach ($checkedIds as $postId) { if ((!$post = Post::find($postId)) || !$post->canEdit($this->user)) continue; $post->publish(); Event::fire('rainlab.blog.posts.published', [$post]); } Flash::success('Successfully published those posts.'); } return $this->listRefresh(); } }</code>peristiwa eloquent
Apabila memadam rekod, acara
dicetuskan sebelum operasi penghapusan sebenar dilakukan, dan acara dicetuskan selepas itu. Jika anda kembali palsu dalam acara deleting
, operasi akan dibatalkan. deleted
deleting
<code class="language-php">Event::listen('rainlab.blog.posts.published', function($post) { User::subscribedTo($post)->each(function($user) use($post) { Mail::send('emails.notifications.post-published', ['user' => $user, 'post' => $post], function($message) use($user, $post) { $message->from('us@example.com', 'New post by ' . $user->name); $message->to($user->email); }); }); });</code>
Kesimpulan
Soalan Lazim Mengenai Memperluaskan OktoberCMS dan Membina Plugin Padam Soft
deleted_at
Bagaimana perbezaan antara penghapusan lembut dan penghapusan keras?
Bagaimana untuk melaksanakan fungsi padam lembut pada bulan Oktobercms?
. Anda kemudian boleh menggunakan kaedah deleted_at
pada model untuk memadamkan rekod dengan lembut dan menggunakan kaedah SoftDeletes
untuk memulihkannya. delete
restore
Bagaimana untuk menguji fungsi padam lembut pada Oktobercms?
Bolehkah saya menggunakan fungsi padam lembut dengan rekod sedia ada?
yang menunjukkan bahawa mereka belum dipadamkan. deleted_at
Untuk memulihkan rekod yang dipadam lembut, anda boleh menggunakan kaedah restore
pada model. Ini akan menghilangkan timestamp deleted_at
dari rekod, dengan berkesan "undelete" itu.
Ya, anda boleh memadam rekod yang dipadam lembut secara kekal menggunakan kaedah forceDelete
pada model. Ini akan memadam rekod dari pangkalan data seperti penghapusan keras.
Untuk melihat semua rekod, termasuk rekod yang dipadam lembut, anda boleh menggunakan kaedah withTrashed
pada model. Ini akan mengembalikan semua rekod, sama ada mereka telah dipadam lembut atau tidak.
deleted_at
di OktoberCMS? Ya, anda boleh menyesuaikan nama lajur getDeletedAtColumn
dengan menimpa kaedah deleted_at
dalam model. Jika deleted_at
tidak sesuai untuk keperluan anda, ini membolehkan anda menggunakan nama lajur yang berbeza.
Ya, anda boleh melumpuhkan Soft Delete untuk beberapa rekod menggunakan kaedah withoutGlobalScope
pada model. Ini membolehkan anda mengecualikan rekod tertentu dari ciri Padam Lembut.
Atas ialah kandungan terperinci Memperluas Oktobercms - Membina Plugin Lembut Delete. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!