我想在模型与Form::label
和Form::text
的关系中使用属性值。从Laravel中删除了Form
帮助程序,因此我改为使用'Form' => 'Collective\Html\FormFacade'
。
以下是Order
模型中的关系:
<?php namespace App\Models;
use Illuminate\Database\Eloquent\SoftDeletes;
class Order extends \Eloquent
{
use SoftDeletes;
public function account_number()
{
return $this->belongsTo('\App\Models\Account_number', 'product_id', 'id');
}
}
这是带有Form
的Blade模板。 account_number
<td>
中的文字会显示:
{"id":4,"user_id":52,"account_type":"alipay","account_no":"xxxxxx","account_name":"xxxxxx","phone":"xxxxxx","created_at":"2017-11-15 14:43:51","updated_at":"2017-11-15 14:43:51","deleted_at":null}
{!! Form::model($order, array('files' => true)) !!}
<table border="1">
<tr>
<td>{!! Form::label('out_trade_no', 'out_trade_no: ') !!}</td>
<td>{!! Form::text('out_trade_no')!!}</td>
</tr>
<tr>
<td>{!! Form::label('account_number', 'account_number: ') !!}</td>
<td>{!! Form::text('account_number')!!}</td>
</tr>
</table>
但我想分别显示每个account_number
属性的输入,而不是JSON字符串。
我尝试过:
<tr>
<td>{!! Form::label('account_number.id', 'account_number: ') !!}</td>
<td>{!! Form::text('account_number.id')!!}</td>
</tr>
或
<tr>
<td>{!! Form::label('account_number->id', 'account_number: ') !!}</td>
<td>{!! Form::text('account_number->id')!!}</td>
</tr>
或
<tr>
<td>{!! Form::label('account_number', 'account_number: ') !!}</td>
<td>{!! Form::text('account_number["id"]')!!}</td>
</tr>
......但这些都不起作用。他们都将此<td>
留空。
答案 0 :(得分:3)
要使用FormBuilder
tools提供的Laravel Collective为模型的关系创建输入控件,请使用以下语法:
{!! Form::model($order, ...) !!}
...
{!! Form::label('account_number[id]', 'account number: ') !!}
{!! Form::text('account_number[id]') !!}
...
{!! Form::close() !!}
请注意id
周围缺少引号。问题中的示例包含相关模型的id
属性的引号,这打破了这种魔力。上面的代码使用id
模型Order
关系中account_number
属性的值呈现以下输入元素:
<input name="account_number[id]" type="text" value="4">
输入元素name
属性中显示的格式使PHP能够将POST数据解析为数组。我们可以获取提交给控制器方法的值,如下例所示:
public function save(Request $request)
{
$accountNumber = $request->get('account_number');
echo $accountNumber['id']; // '4'
...
}
此功能非常重要 - FormBuilder
生成输入元素,旨在与PHP自动将请求数据分组到数组中。如果我们在表单上为模型的关系提交多个输入元素,Laravel可以很容易地保存结果:
public function update(Request $request, $orderId)
{
Order::with('account_number')->find($orderId)
->fill($request->all())
->account_number->fill($request->account_number)
->push();
}
答案 1 :(得分:2)
让我们做一些更深入的了解。
在生成文本输入元素时,FormBuilder将在会话中查找旧输入数据中的值,然后如果设置了一个,它将在模型实例中查找。否则它只会使用空
在获得适当的值之前,它将转换我们指定的密钥,例如account_number.id
,account_number->id
,account_number["id"]
。专注于transformKey功能
protected function transformKey($key)
{
return str_replace(['.', '[]', '[', ']'], ['_', '', '.', ''], $key);
}
让我们用你一个一个指定的键来调用它:
account_number.id
=&gt; account_number_id
account_number->id
=&gt; account_number->id
account_number["id"]
=&gt; account_number."id"
然后它将按.
分割密钥,返回数组$keys
。并检查是否存在嵌套模型$keys[0]
,否则返回主模型的值与转换键。 getFormValue()
无论是否存在嵌套模型,它都会通过data_get()函数获取值。
显然,您指定的第一个键和第二个键不起作用。第三个account_number."id"
,它会成功找到嵌套模型,但不会通过$nestedModel->{"id"}
的方式检索属性。请改用account_number[id]
,效果很好。
<td>{!! Form::text('account_number[id]')!!}</td>
答案 2 :(得分:1)
您通过模型绑定使用LaravelCollective的FirmBuilder的方式是错误的。 假设您有以下订单中的数据:
{
id: 1,
....., // some other fields
account_number: {
"id":4,
"user_id":52,
"account_type":"alipay",
"account_no":"xxxxxx",
"account_name":"xxxxxx",
"phone":"xxxxxx",
"created_at":"2017-11-15 14:43:51",
"updated_at":"2017-11-15 14:43:51",
"deleted_at":null
}
}
现在,如果您想在textfield中显示account_number id
,那么您可以用这种方式编写表单构建器:
{!! Form::model($order, ...) !!}
...
<tr>
<td>{!! Form::label('account_number', 'account number: ') !!}</td>
<td>{!! Form::text('account_number', $order->account_number->id) !!}</td>
</tr>
...
{!! Form::close() !!}
或
<td>{!! Form::text('account_number[id]') !!}</td>
但在第二个回答中,您在提交表单时会遇到问题。因为除了获得您想要的值之外,该行代码还会重命名您的输入名称属性&#39;价值为account_number[id]
而不是account_number
。所以最好的选择是使用第一个解决方案。以下是LaravelCollective中表单模型绑定的链接:https://laravelcollective.com/docs/master/html#form-model-binding
答案 3 :(得分:1)
尝试在我自己的环境上实施后,我的结论 -
{!! Form::model($order, array('files' => true)) !!}
<table border="1">
<tr>
<td>{!! Form::label('out_trade_no', 'out_trade_no: ') !!}</td>
<td>{!! Form::text('out_trade_no')!!}</td>
</tr>
<tr>
<td>{!! Form::label('account_number', 'account_number: ') !!}</td>
<td>{!! Form::text('account_number[id]')!!}</td>
</tr>
</table>