[英]Laravel & vue.js values to array
我在Laravel中使用vue.js。
我有3张桌子。
Article
Location
article_location (pivot table)
如果我想将位置信息转换为json,以便可以将其传递给vue,我该怎么做?
<div class="container">
Location->article //all articles of a location to json
<template id="ln-data">
<ul>
<li v-for="value in list">
@{{ value.name }}
</li>
</ul>
</template>
<script>
Vue.config.debug = true;
Vue.component('data', {
template: '#ln-data',
props:['list'],
created() {
this.list = JSON.parse(this.list);
}
})
new Vue({
el: 'body'
});
</script>
我该怎么办?
编辑-
控制器:
$location = location::all();
return view('locationproducts')->with('location',$location);
视图:
<div class="container">
<data list="{{ $location->article()->toJson() }}"></data>
</div>
位置模型:
public function article()
{
return $this->belongsToMany('App\article','article_location');
}
错误:
Macroable.php第81行中的ErrorException:方法文章不存在。 (查看:/home/vagrant/Code/project/resources/views/locationproducts.blade.php)
您可以使用toJson()
方法将模型转换为JSON,也可以使用toJson
方法。 与toArray
一样, toJson
方法是递归的,因此所有属性和关系都将转换为JSON:
$location->articles()->toJson();
希望这可以帮助。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.