關于laravel自定義模板指令-tojs

下面由laravel教程欄目給大家介紹laravel自定義模板指令-tojs? ,希望對需要的朋友有所幫助!

Blade 允許你自定義命令,你可以使用 directive 方法注冊命令。當 Blade 編譯器遇到該命令時,它將會帶參數調用提供的回調函數。blade模板可以通過directive方法來自定義模板指定,tojs指令主要用于PHP自定義一些數據轉換為js對象方便js調用

1.創建ToJsServiceProvider

<?php  namespace AppProviders;  use AppHelpersToJsToJs; use IlluminateSupportFacadesBlade; use IlluminateSupportServiceProvider;  class ToJsServiceProvider extends ServiceProvider {     /**      * Bootstrap the application services.      *      * @return void      */     public function boot()     {         //     }      /**      * Register the application services.      *      * @return void      */     public function register()     {         $this->app->singleton('tojs', function () {             return new ToJs();         });          /*         * The block of code inside this directive indicates         * the chosen javascript variables.         */         Blade::directive('tojs', function () {             return '<script> window.Laravel = ' . json_encode(app('tojs')->get()) . '</script>';         });     } }

2. ToJs方法主要是對數組的一些操作

<?php  namespace AppHelpersToJs;  use IlluminateSupportArr;  class ToJs {     protected $data = [];      public function put(array $data)     {         foreach ($data as $key => $value) {             $this->data[$key] = value($value);         }          return $this;     }      public function get($key = null, $default = null)     {         if (!$key) return $this->data;          return Arr::get($this->data, $key, $default);     }      public function forget($keys)     {         Arr::forget($this->data, $keys);          return $this;     } }

3.聲明facade

namespace AppHelpersToJsFacades;  use IlluminateSupportFacadesFacade;   class ToJsFacade extends Facade {     /**      * Get the registered name of the component.      *      * @return string      */     protected static function getFacadeAccessor()     {         return 'tojs';     } }

4.在config數組添加serviceProvider

providers 添加
appproviderstojsserviceprovider::class

aliases 添加
‘ToJs’ => AppHelpersToJsFacadesToJsFacade::class,

5.為了方便調用可以在寫一個helper方法

if (!function_exists('to_js')) {     /**      * Access the javascript helper.      */     function to_js($key = null, $default = null)     {         if (is_null($key)) {             return app('tojs');         }          if (is_array($key)) {             return app('tojs')->put($key);         }          return app('tojs')->get($key, $default);     } }

在PHP代碼需要的地方調用 to_js([‘username’=>’test’]);

blade模板直接通過 @tojs 就可以在頁面渲染出
<script> window.Laravel = {"username":"test"}</script>

以上就是關于

? 版權聲明
THE END
喜歡就支持一下吧
點贊7 分享