web-dev-qa-db-ja.com

文字列にキャストされたプルID(整数)Laravel

データベースから取得しているときに、idを文字列として取得します。

$alphabets = new Alphabet();
return $alphabets->pluck('name', 'id');

出力

{
    "1": "Apple",
    "2": "Ball",
    "3": "Cat"
}

期待される

{
    1: "Apple",
    2: "Ball",
    3: "Cat"
}

しかし、IDnameを逆にすると、

return $alphabets->pluck('id', 'name');

Idを整数として取得します。

{
    "Apple": 1,
    "Ball": 2,
    "Cat": 3
}

舞台裏で何が起こっているのかわかりません。しかし、どうすれば整数でIDを取得できますか?実際、FormCollectiveの1 vs "1"のため、古いフラッシュセッションは値を設定しません。

{!! Form::select('alphabet', $alphabets, null, ['class' => 'form-control', 'multiple' => true]) !!}
9
Sagar Chamling

私はここで答えを見つけたと思います。

https://laracasts.com/discuss/channels/laravel/pluck-id-integer-cast-to-string

ここで、JSONではキー名のみを文字列にすることができます。

数値を「インデックス」として使用(JSON)

{
    "1": "Apple",
    "2": "Ball",
    "3": "Cat"
}

実はForm Collectiveで実現したいです。これはバグであり、PRは現在マージされています。

https://github.com/LaravelCollective/html/pull/368#pullrequestreview-4682042

3
Sagar Chamling

このコードを試してください

$alphabets = new Alphabet();
return $alphabets->all()->pluck('name', 'id');

Alphabet.php

このように列をキャストする必要があります。

  protected $casts = [
    'id' => 'integer',
    'name' => 'string' 
  ];
5

また、キーをintに変換します

 $alphabets = new Alphabet();
    $alphaArr =$alphabets->pluck('name', 'id');
    foreach($array as $key => $value) {
       $newArray[(int) $key] = $value;
    }
1

この行を追加すると、LaravelCollective/Htmlの古いセッションの問題が修正されます。

|| in_array((string) $value, $selected, true)

/**
 * Determine if the value is selected.
 *
 * @param  string $value
 * @param  string $selected
 *
 * @return null|string
 */
protected function getSelectedValue($value, $selected)
{
    if (is_array($selected)) {
        return in_array($value, $selected, true) || in_array((string) $value, $selected, true) ? 'selected' : null;
    } elseif ($selected instanceof Collection) {
        return $selected->contains($value) ? 'selected' : null;
    }
    return ((string) $value == (string) $selected) ? 'selected' : null;
}
0
Sagar Chamling

通常、pluck()メソッドは、文字列値の値の連想配列を提供します。

したがって、次のようなselectステートメントを使用してみてください。

$data = Alphabet::select('id','name')->get()->toArray();

これにより、次の結果が得られます。

array:3 [▼
  0 => array:2 [▼
    "id" => 1
    "name" => "Apple"
  ]
  1 => array:2 [▼
    "id" => 2
    "name" => "Ball"
  ]
  2 => array:2 [▼
    "id" => 3
    "name" => "Cat"
  ]
]

これで、単純なループを使用して、期待される配列を取得できます。

$expected = array();

foreach($data as $d){
    $expected[$d['name']] = $d['id'];
}

dd($expected);
0
Sagar Gautam