成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

基于Model Event模型事件的Laravel實時APP

afishhhhh / 1140人閱讀

摘要:重點是在頁面寫入新文本,頁面不能實時顯示。想要了解更多可以參考這篇文章基于驅(qū)動的事件廣播下測試實時功能刷新頁面,并觀察數(shù)據(jù)庫。測試實時創(chuàng)建功能。

說明:本文主要來源于real-time-apps-laravel-5-1-event-broadcasting

本文主要基于Laravel的Model Event介紹該框架的實時通信功能,Laravel模型的生命周期中包含事件:created、creatingsaved、saving、updated,updating、deleteddeleting、restored、restoring,同時結(jié)合了Pusher包,有關(guān)Pusher的注冊和使用相關(guān)信息可以參考:基于 Pusher 驅(qū)動的 Laravel 事件廣播(上)。同時,作者會將開發(fā)過程中的一些截圖和代碼黏上去,提高閱讀效率。
備注:Laravel對Model的CRUD操作都會觸發(fā)對應(yīng)的事件,如create操作會在創(chuàng)建前觸發(fā)creating事件,創(chuàng)建后觸發(fā)created事件,即Model Event。

Non Real-time App Laravel程序安裝

先全局安裝composer:

    curl -sS https://getcomposer.org/installer | php
    mv composer.phar /usr/local/bin/composer

新建一個空文件夾,在文件夾下,再使用composer安裝Laravel項目:

composer create-project laravel/laravel mylaravelapp --prefer-dist
寫一個TODO APP 寫路由Route

在app/Http/routes.php中寫上資源型路由:

Route::get("/", function () {
    return view("index");
});
Route::resource("items", "ItemController", ["except" => ["create", "edit"]]);//排除掉create和edit操作
寫個Model

先建個遷移文件:

php artisan make:migration create_items_table --create=items

在遷移文件database/migrations/*_create_items_table.php中寫上:

/**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create("items", function (Blueprint $table) {
            $table->increments("id");
            $table->string("title");
            $table->boolean("isCompleted")->default(false);
            $table->timestamps();
        });
    }

新建一個Eloquent Model:

php artisan make:model Item

別忘了配置下數(shù)據(jù)庫,我用的是MAMP集成環(huán)境,數(shù)據(jù)庫服務(wù)是MySQL。數(shù)據(jù)庫配置主要在config/database.php和.env文件中,在.env文件中寫上對應(yīng)的host,database,user,password:

DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_DATABASE=model_event
DB_USERNAME=root
DB_PASSWORD=model_event
寫控制器Controller

首先在項目根目錄下輸入artisan命令創(chuàng)建個ItemController:

php artisan make:controller ItemController

在ItemController中寫上增刪改查:

class ItemController extends Controller
{
    /**
     * Display a listing of the resource.
     *
     * @return Response
     */
    public function index()
    {
        $uncompletedItems = Item::where("isCompleted", 0)->get();
        $completedItems = Item::where("isCompleted", 1)->get();

        $data = ["uncompletedItems" => $uncompletedItems,
            "completedItems" => $completedItems];

        return view("item.index", $data);
    }

    /**
     * Store a newly created resource in storage.
     *
     * @return Response
     */
    public function store(Request $request)
    {
        $item = new Item;
        $item->title = $request->title;
        $item->save();
        return response()->json(["id" => $item->id]);
    }

    /**
     * Display the specified resource.
     *
     * @param  int  $id
     * @return Response
     */
    public function show($id)
    {
        $item = Item::find($id);
        return view("item.show", ["item" => $item]);
    }

    /**
     * Update the specified resource in storage.
     *
     * @param  int  $id
     * @return Response
     */
    public function update(Request $request, $id)
    {
        $item = Item::find($id);
        $item->isCompleted = (bool) $request->isCompleted;
        $item->save();
        return;
    }

    /**
     * Remove the specified resource from storage.
     *
     * @param  int  $id
     * @return Response
     */
    public function destroy($id)
    {
        $item = Item::find($id);
        $item->delete();
        return;
    }
}
寫個View視圖

建個reources/views/index.php:



  
    
    
    
    
    Todo App

    
    {{----}}
      

    
    
    
      {{----}}
    {{----}}
  
  
    

Todo App


{{----}} {{----}} {{----}}

ItemController控制器中返回兩個子視圖item.index、item.show,在resources/views/item中建兩個:

//item.index
未完成的Items
    @foreach ($uncompletedItems as $item) @include("item.show") @endforeach

完成的Items
    @foreach ($completedItems as $item) @include("item.show") @endforeach
//item.show
  • 一切準備就OK了,我的在MAMP環(huán)境輸入路由:http://laravelmodelevent.app:...,新開AB兩個頁面,然后在輸入框里提交文本后:

    A頁面輸入后B頁面只有刷新才能看到最新輸入的文本,不能實時顯示,當(dāng)然,輸入的文本已經(jīng)保存在model_event.items表里了:

    頁面里改變每一個item的checkbox后,該item的狀態(tài)將會互換,在UI上顯示也是上下位置互換,具體邏輯可以看views/index.blade.php的JS邏輯,這不是本文的重點,故不詳述。

    重點是:在A頁面寫入新文本,B頁面不能實時顯示。這還不是個實時APP。

    Real-time App 創(chuàng)建三個廣播事件

    創(chuàng)建三個廣播事件:

    ItemCreated:當(dāng)新建一個item完成時觸發(fā)

    ItemUpdated:當(dāng)更新一個item完成時觸發(fā)(isCompleted=0或1)

    ItemDeleted:當(dāng)刪除一個item完成時觸發(fā)

    在項目根目錄依次輸入:

    php artisan make:event ItemCreated
    php artisan make:event ItemUpdated
    php artisan make:event ItemDeleted

    Laravel事件廣播需要實現(xiàn)ShouldBroadcast接口并且在broadcastOn()方法中寫上廣播頻道:

    class ItemCreated extends Event implements ShouldBroadcast
    {
        use SerializesModels;
    
        public $id;
        /**
         * Create a new event instance.
         *
         * @return void
         */
        public function __construct(Item $item)
        {
            $this->id = $item->id;
        }
    
        /**
         * Get the channels the event should be broadcast on.
         *
         * @return array
         */
        public function broadcastOn()
        {
            return ["itemAction"];
        }
    }
    class ItemDeleted extends Event implements ShouldBroadcast
    {
        use SerializesModels;
    
        public $id;
        /**
         * Create a new event instance.
         *
         * @return void
         */
        public function __construct(Item $item)
        {
            $this->id = $item->id;
        }
    
        /**
         * Get the channels the event should be broadcast on.
         *
         * @return array
         */
        public function broadcastOn()
        {
            return ["itemAction"];
        }
    }
    class ItemUpdated extends Event implements ShouldBroadcast
    {
        use SerializesModels;
    
        public $id;
        public $isCompleted;
        /**
         * Create a new event instance.
         *
         * @return void
         */
        public function __construct(Item $item)
        {
            $this->id          = $item->id;
            $this->isCompleted = (bool)$item->isCompleted;
        }
    
        /**
         * Get the channels the event should be broadcast on.
         *
         * @return array
         */
        public function broadcastOn()
        {
            return ["itemAction"];
        }
    }
    創(chuàng)建Model Event

    Laravel的Eloquent每一CRUD操作都會觸發(fā)Model事件,可以在service provider里監(jiān)聽這些事件從而觸發(fā)新建的三個廣播事件,在AppServiceProvider中:

    class AppServiceProvider extends ServiceProvider
    {
        /**
         * Bootstrap any application services.
         *
         * @return void
         */
        public function boot()
        {
            Item::created(function($item){
                event(new ItemCreated($item));
            });
            Item::deleted(function($item){
                event(new ItemDeleted($item));
            });
            Item::updated(function($item){
                event(new ItemUpdated($item));
            });
        }
    
        /**
         * Register any application services.
         *
         * @return void
         */
        public function register()
        {
            //
        }
    }
    使用Pusher

    Pusher的作用、注冊和安裝可參考:基于 Pusher 驅(qū)動的 Laravel 事件廣播(上)
    注冊安裝也比較簡單,總之使用Pusher能做個實時APP。
    更新resources/views/index.blade.php文件:

    ...
        Todo App
          
        
        //引入pusherJS文件
               
    ...
            $.post( "/items", $(this).serialize(), function( data ) {
    //                    addItem(data.id, false);//注銷掉
                        $( "#title" ).val("");
                    });
    ...
           $.ajax("/items/" + id, {//進入ItemController::update(),更細下item狀態(tài)
                        data: {"isCompleted": isCompleted},
                        method: "PATCH",
                        success: function() {//根據(jù)狀態(tài)變化刪除增加item
    //                        removeItem(id);//注銷掉
    //                        addItem(id, isCompleted);//注銷掉
                        }
                    });
    ...                
            $(document).on("click", ".deleteItem", function() {
                    var id = $(this).closest("li").data("id");
                    $.ajax("/items/" + id, {//進入ItemController::destroy()刪除數(shù)據(jù)庫中item
                        method: "DELETE",
                        success: function() {//UI刪除該item
    //                        removeItem(id);//注銷掉
                        }
                    });
                });
            })(jQuery, addItem, removeItem);
    
        //新加代碼
            var pusher            = new Pusher("{{env("PUSHER_KEY")}}");
            var itemActionChannel = pusher.subscribe("itemAction");
            itemActionChannel.bind("AppEventsItemCreated", function (data) {
                console.log(data.id);
               addItem(data.id, false);
            });
            itemActionChannel.bind("AppEventsItemDeleted", function (data) {
                console.log(data.id);
               removeItem(data.id);
            });
            itemActionChannel.bind("AppEventsItemUpdated", function (data) {
                removeItem(data.id);
                addItem(data.id, data.isCompleted);
            });     
          
          

    新加代碼主要用pusher對象注冊三個事件廣播的頻道"itemAction",并分別綁定三個事件,成功后回調(diào)執(zhí)行對應(yīng)的UI操作。想要了解更多可以參考這篇文章:基于 Pusher 驅(qū)動的 Laravel 事件廣播(下)

    測試實時功能

    刷新AB頁面,并觀察數(shù)據(jù)庫model_event.items。

    測試實時創(chuàng)建功能。A頁面輸入文本后發(fā)現(xiàn)B頁面不用刷新就實時顯示對應(yīng)內(nèi)容,且數(shù)據(jù)庫已經(jīng)保存剛剛創(chuàng)建的文本:

    測試實時更新功能。B頁面點擊狀態(tài)更新checkbox后,A頁面該item狀態(tài)也實時更新,且數(shù)據(jù)庫isCompleted字段變?yōu)?:

    測試實時刪除功能。A頁面點擊刪除按鈕后,B頁面也實時刪除對應(yīng)的item,且數(shù)據(jù)庫該item也刪除:

    OK,It is working!!!

    總結(jié):本節(jié)主要利用Laravel的Model Event來創(chuàng)建一個實時WEB APP,挺好玩的,可以玩一玩哦。有問題可留言。嘛,過兩天還想結(jié)合Laravel的Container Event容器事件新開篇文章,到時見。

    歡迎關(guān)注Laravel-China。

    RightCapital招聘Laravel DevOps

    文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

    轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/21530.html

    相關(guān)文章

    • [Laravel 5.3] Notification 個人理解,及 BearyChat Channe

      摘要:提供了一種全新的發(fā)送通知的方式。個人理解是可以基于某事件操作觸發(fā)一系列的通知任務(wù),而通知方式由通知渠道接管,這樣使得通知或推送邏輯更抽象,更易于管理和重構(gòu)。在之前,我是利用的來完成這一系列通知。使用的配置文件還是原來的,無需重新配置。 Laravel Notification Laravel 5.3 提供了一種全新的發(fā)送通知的方式:Notification 。個人理解是可以基于某事件(...

      Yang_River 評論0 收藏0
    • Laravel學(xué)習(xí)筆記之Model Observer模型觀察者

      摘要:說明本文主要學(xué)習(xí)下的模型觀察者,把一點點經(jīng)驗分享出來希望對別人能有幫助。模型觀察者這個功能能做很多事情,比如模型更新時發(fā)個通知??偨Y(jié)本篇文章主要學(xué)了下的模型觀察者,發(fā)現(xiàn)這個功能也能使代碼結(jié)構(gòu)更清晰,覺得挺好的。 說明:本文主要學(xué)習(xí)下Laravel的Model Observer模型觀察者,把一點點經(jīng)驗分享出來希望對別人能有幫助。同時,作者會將開發(fā)過程中的一些截圖和代碼黏上去,提高閱讀效率...

      Crazy_Coder 評論0 收藏0
    • Laravel學(xué)習(xí)筆記之Redis保存頁面瀏覽量

      摘要:說明本文主要講述使用作為緩存加快頁面訪問速度。何不用來做緩存,等到該達到一定瀏覽頁面后再刷新下,效率也很高。可作緩存系統(tǒng)隊列系統(tǒng)。 說明:本文主要講述使用Redis作為緩存加快頁面訪問速度。同時,作者會將開發(fā)過程中的一些截圖和代碼黏上去,提高閱讀效率。 備注:作者最近在學(xué)習(xí)github上別人的源碼時,發(fā)現(xiàn)好多在計算一篇博客頁面訪問量view_count時都是這么做的:利用Laravel...

      z2xy 評論0 收藏0
    • laravel 模型事件幾種用法

      摘要:一簡單粗魯用于本地測試路由中定義測試一下修改事件二生成事件和監(jiān)聽器在定義對應(yīng)關(guān)系生成文件中注入要操作的類中方法注入對應(yīng)事件類測試一下修改事件最后在模型中添加屬性三利用框架的方法直接在相關(guān)中定義測試一下修改事件四定義如果想對多個模型的或事件進 一 、簡單粗魯(用于本地測試) 路由中定義: Event::listen(eloquent.updated: AppPost,function ...

      KavenFan 評論0 收藏0

    發(fā)表評論

    0條評論

    最新活動
    閱讀需要支付1元查看
    <