Laravel 将 json 传递给 vue.js


Laravel pass json to vue.js

我正在使用Laravel,我想将json传递给我的new Vue实例。我怎么能这样做。

我像这样传递员工对象:

 $employees = EmployeeModel::with('role','department.company')->get();
 return view('employees.employees')->with('employees',$employees);

然后在我的新 Vue 中,我是这样做的:

new Vue({
            el: 'body',
            data:{
                role: '',
                company: '',
                list:'{{ $employees }}',
                created() {
                    this.list = JSON.parse(this.list);
                }
            }
        });

它抛出一个错误:vue.js:983 [Vue 警告]:评估时出错 表达"公司名称"。

当我将 json 手册放入列表中时,它可以工作!所以像这样:

  new Vue({
                el: 'body',
                data:{
                    role: '',
                    company: '',
            list:[{"EmployeeId":1,"RoleId":5,"DepartmentId":6,"InternId":1,"FirstName":"Zoe","LastName":"Altenwerth","Bio":"Quidem perferendis.","email":"Kole.Bechtelar@hotmail.com","LinkedIn":"Sterling.Schowalter@example.net","Gender":0,"password":"$2y$10$bbUlDh2060RBRVHSPHoQSu05ykfkw2hGQa8ZO8nmZLFFa3Emy18gK","PlainPassword":"gr^S=Z","remember_token":"D528C0Ba1Xzq3yRV7FdNvDd8SYbrM0gAJdFUcOBq4sNEJdHEOb2xIQ0geVhZ","Address":"0593 Dallin Parkway Apt. 499'nBotsfordborough, MT 12501","Zip":"21503-","City":"East Janiston","ProfilePicture":null,"BirthDate":"2002-10-13 00:00:00","StartDate":"1995-11-09 21:42:22","EndDate":"2011-01-27","Suspended":0,"created_at":"2016-02-29 12:21:42","updated_at":"2016-03-02 11:53:58","deleted_at":null,"role":{"RoleId":5,"RoleName":"Superadministrator","Description":"Mag administrators toevoegen en bewerken","deleted_at":null,"created_at":"-0001-11-30 00:00:00","updated_at":"-0001-11-30 00:00:00"},"department":{"DepartmentId":6,"CompanyId":12,"DepartmentName":"com","Description":"Accusantium quae.","deleted_at":null,"created_at":"2016-02-29 12:21:41","updated_at":"2016-02-29 12:21:41","company":{"CompanyId":12,"CompanyName":"Dare, Bailey and Bednar","Logo":null,"Address":"85762 Tabitha Lights'nWest Jettie, AK 20878-2569","Zip":"29601","City":"Traceside","KvKNumber":"84c70661-9","EcaboNumber":"fdee61e3-a22d-3332-a","deleted_at":null,"created_at":"2016-02-29 12:21:41","updated_at":"2016-02-29 12:21:41"}}}]
                    created() {
                        this.list = JSON.parse(this.list);
                    }
                }
            });

那么如何将$employees对象传递给我的new Vue实例并使用它呢?

我的猜测是你必须将数据作为JSON发送。试试这个:

 return view('employees.employees')->with('employees',json_encode($employees));

在声明 Vue 之前,我就是这样做的。

var employees = {!!  json_encode($employees) !!};

然后

 list: employees,