我有一个关于yii2 kartik-v widget select 2的问题。
小部件附加到我视图中的字段
<?=
$form->field($model, 'address')->widget(Select2::className(), [
'options' => ['placeholder' => 'Inserta an address '],
'pluginOptions' => [
'allowClear' => true,
'minimumInputLength' => 3,
'ajax' => [
'url' => Url::to(['register/addresses']),
'dataType' => 'json',
'data' => new JsExpression('function(params) { return {q:params.term}; }')
],
'escapeMarkup' => new JsExpression('function (markup) { return markup; }'),
'templateResult' => new JsExpression('function(address) { return address.name; }'),
'templateSelection' => new JsExpression('function (address) { return address.name; }'),
],
'pluginEvents' => [
"select2:select" => "function(e) {
// some function
}",
],
]);
?>
如果在我的控制器中我想将此字段设置为值
喜欢:$model->address = "Some Value";
在视图上该字段保持空白
我能做什么?
更新<!/强>
正如文档所说我可以使用选项:'initValueText'如果我使用此插件的ajax版本。所以我试图设置'initValueText' => $model->address,
,但结果是相同的
答案 0 :(得分:1)
问题在于:
public function actionAddresses($q = NULL, $id = NULL)
{
Yii::$app->response->format = Response::FORMAT_JSON;
$results = array();
if (!is_null($q)) {
$geocoder = new GeocodingClient();
$request = $geocoder->lookup(['address' => $q]);
$counter = 1;
foreach ($request['results'] as $key => $value) {
$results['results'][] = [
'id' => $counter,
'text' => $value['formatted_address'], // Instead of 'name'
'coordinate' => $value['geometry']['location']
];
$counter++;
}
}
return $results;
}
似乎这个插件需要键'templateResult'和'templateSelection'的特定返回。
我使用address.text(而不是adress.name)修改了JsExpression返回值作为指导示例:Link。
然后我还修改了返回结果的PHP方法:
{{1}}
我希望这可以帮助有类似问题的人。
答案 1 :(得分:1)
它有点迟了..但我也有同样的问题..我通过赋值
来解决它 <?=
$form->field($model, 'address')->widget(Select2::className(), [
'initValueText' => $model->address,
'value' => $model->address,
'options' => ['placeholder' => 'Inserta an address '],
'pluginOptions' => [
'allowClear' => true,
'minimumInputLength' => 3,
'ajax' => [
'url' => Url::to(['register/addresses']),
'dataType' => 'json',
'data' => new JsExpression('function(params) { return {q:params.term}; }')
],
'escapeMarkup' => new JsExpression('function (markup) { return markup; }'),
'templateResult' => new JsExpression('function(address) { return address.name; }'),
'templateSelection' => new JsExpression('function (address) { return address.name; }'),
],
'pluginEvents' => [
"select2:select" => "function(e) {
// some function
}",
],
]);
?>
答案 2 :(得分:1)
<?php
$product = $model->product_id ? Product::findOne($model->product_id)->name : 'select ....';
echo $form->field($model, 'product_id')->widget(Select2::classname(), [
'initValueText' => $product, // set the initial display text
// 'options' => ['placeholder' => 'select ....'],
'pluginOptions' => [
'allowClear' => true,
'minimumInputLength' => 3,
'ajax' => [
'url' => Url::to(['list']),
'dataType' => 'json',
'data' => new JsExpression('function(params) { return {q:params.term}; }')
],
'escapeMarkup' => new JsExpression('function (markup) { return markup; }'),
'templateResult' => new JsExpression('function(product_id) { return product_id.name; }'),
'templateSelection' => new JsExpression('function (product_id) { return product_id.name; }'),
],
]);?>
如果模型是新的'select ....',则显示产品的名称 因为“选项”也没有做太多 希望这对某人有希望
答案 3 :(得分:0)
你使用kartik select2,在控制器中你已经为&#39; initValueText&#39;
设置了一个值(id / ids)和名称值$model->id = 1; // or if arrays [1,3,4,5]
$username = User::find()->select('name')->where('id' => $model->id)->scalar();
并查看kartik select2
$form->field($model, 'username')->widget(Select2::className(), [
'initValueText' => $username;
...
答案 4 :(得分:0)
我通过使用触发功能来解决此解决方案。在下面的方法中,我们可以在kartik select2小部件中设置默认值。
$('#id').val(11).trigger('change'); //in val() mention the hash value of your select2 list
答案 5 :(得分:0)
我遇到了同样的问题。然后我在选项中尝试了 value key 并且它起作用了。
<?php
echo $form->field($model, 'test')->widget(Select2::classname(), [
//'data' => ['test', 'test2'],
'initValueText'=>['test','test2'],
'options' => ['multiple' => true, 'value'=>['1','2']],
'pluginOptions' => [
'multiple' => true,
'allowClear' => true,
'minimumInputLength' => 1,
'language' => [
'errorLoading' => new JsExpression("function () { return 'Waiting for results...'; }"),
],
'ajax' => [
'url' => '...',
'dataType' => 'json',
'data' => new JsExpression('function(params) { return {q:params.term}; }')
],
'escapeMarkup' => new JsExpression('function (m) { return m; }')
?>
希望对大家有所帮助。