您好,登錄后才能下訂單哦!
這篇文章主要介紹laravel-admin與vue結合怎么用,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
由于 Laravel-admin
采用的是 pjax 的方式刷新頁面,意味著很多頁面刷新的操作,并不是刷新整個 document,而是從服務器拿到部分 document,再通過類似 $(“#pjax-container”).html(newPart)
的方式更新的。
這就造成一個問題,每次 pjax 刷新,都會破壞 vue 的 dom 映射。
所以理論上有2種方法解決:
重新綁定一下 vue 的映射關系
在某些頁面禁止 pjax
1 太難搞,而且沒啥資料,放棄。2 的話比較可行。
部分禁止 pjax
打開 public/vendor/laravel-admin/laravel-admin/laravel-admin.js
添加代碼:
// 不使用 pjax 刷新的頁面 $(document).on('pjax:beforeReplace', function (e, options) { // console.log(arguments) var freshPaths = [ /\/admin.*\/products/, ] for (let path of freshPaths) { if (path.test) { if (path.test(e.state.url)) { location.reload() return false } } else if (options.url.search(path) !== -1) { location.reload() return false } } })
使用自定義 view
很多時候我們并不需要大動干戈地建立一個全部的 view,只需要在內置 view 中稍作修改。
這時候,我們需要先自定義一個 Content 類:
use Encore\Admin\Layout\Content; class MyContent extends Content { public function render() { $items = [ 'header' => $this->header, 'description' => $this->description, 'breadcrumb' => $this->breadcrumb, 'content' => $this->build(), ]; return view('admin.content', $items)->render(); } }
然后引用它:
public function index(MyContent $content) { return $content ->header('product') ->description($this->brand) ->body($this->grid()); }
這樣一來,每次進入到 index 頁面,都會渲染 admin.content 這個 view 。
view 的內容直接 copy 自 vendor/encore/laravel-admin/resources/views/content.blade.php
在 view 里插入 vue 組件
添加2部分代碼即可。
第一部分是初始化 vue app:
<script data-exec-on-popstate> // boot up the demo $(function () { // vapp window.vapp = new Vue({ el: '#app', data () { return { status: { showGalleryEditor: false, }, store: { images: [], el: '', }, } }, components: {}, methods: { startGalleryEditing (event) { this.status.showGalleryEditor = true this.store.pk = $(event.target).parent().find('ul').data('pk') this.store.images = $(event.target).parent().find('img').toArray().map((e) => e.getAttribute('src')) window.p = $(event.target).parent().find('ul') }, }, }) }) </script>
第2部分是插入組件:
<gallery-editor :status="status" :images="store.images" :pk="store.pk"> </gallery-editor>
vue 組件單獨一個 js 文件
位置如下:
public/vendor/components/gallery-editor.js
定義如下:
Vue.component('gallery-editor', { props: { status: { showGalleryEditor: false, }, images: [], pk: 0, moveTo: [], }, data () { return {} }, watch: { images (newVal, oldVal) { this.moveTo = [] for (let src of newVal) { this.moveTo.push({ src: src, productId: this.pk, deleted: 0, }) } }, }, methods: { close () { this.status.showGalleryEditor = false }, save () { let args = {_token: LA.token} args.id = this.pk args.images = [] args.move_to = [] // console.log(JSON.stringify(this.moveTo)) for (let imgObj of this.moveTo) { if (imgObj.deleted) { continue } if (imgObj.productId === this.pk) { args.images.push(imgObj.src) } else { args.move_to.push({src: imgObj.src, product_id: imgObj.productId}) } } // console.log(JSON.stringify(args)) $.post('/admin/products/move-images', args).done(() => { toastr.success('success') this.status.showGalleryEditor = false }).fail((response) => { toastr.error(response.responseText) }) }, }, template: ` <div class="modal" tabindex="-1" role="dialog" :class="{show: status.showGalleryEditor, fade: !status.showGalleryEditor}"> <div class="modal-dialog" role="document"> <div class="modal-content"> <div class="modal-header"> <button type="button" class="close" data-dismiss="modal" aria-label="Close" @click="close"><span aria-hidden="true">×</span></button> <h5 class="modal-title">Editing images</h5> </div> <div class="modal-body"> <ul > <li v-for="(imageObj, key) in moveTo" :key="key" > <img :src="imageObj.src" alt="" > <label>Move to product: <input type="text" v-model="imageObj.productId"></label> <label>Delete:<input type="checkbox" v-model="imageObj.deleted"></label> </li> </ul> </div> <div class="modal-footer"> <button type="button" class="btn btn-default" data-dismiss="modal" @click="close">Close</button> <button type="button" class="btn btn-primary" @click="save">Save changes</button> </div> </div> </div> </div>`, })
這是一個彈出式編輯框,具體作用就不解釋了,只是個示例。
然后還需要在 Admin/bootstrap.php
中引用這個 js 文件:
Admin::js('/vendor/components/gallery-editor.js');
為什么不把組件代碼直接寫進 view 中呢?
因為 pjax 的后端邏輯似乎有 bug,template 的內容無法全部渲染到前端,導致頁面出錯。
以上是“laravel-admin與vue結合怎么用”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。