あじちゃんのブログ。備忘録。

〜SEもOLなんですかね?

【解決】dump結果とview表示結果が異なる@Laravel 5.6

解決しました

参考リンク

解決方法

  • Modelに protected $casts = ['id' => 'string']; を追加したことで解決!!

解決までの道筋

  • dump結果とviewでの表示を見比べて、型がintegerになっているのではと推測

dump($items);
dump($items->last()->id);
echo $items->last()->id . '<br>';
return gettype($items->last()->id); // 型を返す

とかしてたら、「collectionで取得したものの型変換がおかしいんじゃない?」という気持ちになり検索

  • 検索ワードは「lalravel collection 型変換」
  • この記事を見つけてSUCCESS!!!

問題だったもの

  • モデルに定義したテーブルからとってきた値をビューに表示するだけなのに、表示結果がおかしい。
  • ModelクラスのtoStringを追うと、jsonEncodeするときに値がおかしくなっていることがわかるがそれが本当の原因かは不明。
+------------------+-------------+------+-----+---------+-------+
| Field            | Type        | Null | Key | Default | Extra |
+------------------+-------------+------+-----+---------+-------+
| id               | varchar(97) | NO   | PRI | NULL    |       |
+------------------+-------------+------+-----+---------+-------+
<?php

$query = ItemModel::query();
$items = $query
    ->orderBy('id', 'asc')
    ->get();

dump($items);
return view('test.index', ["items" => $items]);
<?php

@foreach($items as $item)
  <p>{{ $item->id }}</p>
@endforeach
<?php /* dump結果 */

"id" => "123--これはID--456"
// -> [123]が表示される
"id" => "test"
// -> [0]が表示される
"id" => "あいうえお"
// -> [0]が表示される
"id" => "3333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333"
// -> [9223372036854775807]が表示される