在一个javascript数组中推送Laravel集合

时间:2017-01-10 15:52:42

标签: javascript php laravel-5.3

我是Lavarel的新手,我编写了这部分代码,将我的集合添加到javascript数组中,但它似乎无法正常工作。

$(document).ready(function() {

            var data = [];
            @foreach($products as $product )
                data.push({'{{ $product->id }}' : '{{ $product->name }}'});
            @endforeach

//            Im trying to get a variable which looks like this
//            data: [
//                {
//                    id: 'The ID goes here',
//                    text: 'Text to display'
//                },
//                // ... more data objects ...
//            ]
        });

请帮我解决这个问题

3 个答案:

答案 0 :(得分:1)

最好创建一个Laravel Collection并将其转换为json,以便javascript可以读取此内容。

var data = {{ $products->map(function ($product) { return ['id' => $product->id , 'text' => $product->name];})->toJson() }};

在控制器中生成这个json字符串会更加清晰。

答案 1 :(得分:1)

为什么不在Laravel控制器中将集合转换为JSON:

$collectionArr = Collection::all()->toJson();

然后在HTML中回声:

<script>
    var jsArray = {{$collectionArr}};
</script>

以下是Laravel网站的更多信息: https://laravel.com/docs/5.3/eloquent-serialization#serializing-to-json

答案 2 :(得分:1)

您可以简单地写一下:

$(document).ready(function() {    
    var data = {!! json_encode($products) !!}; // Note the {!! !!} to not encode html entities since we'll probably have quotes in here                 
});