laravel-admin解决表单select联动时,编辑默认没选上的问题
2019-09-30 17:22
3311 查看
今天在开发公司一个功能时,公司开发环境用的是laravel-admin,因为需要用上select联动,所以根据文档说明进行开发,并成功的使用上了,代码我就不重复,大家可以去参考laravel-admin官网的说明。
首先我们找到select的js,路径:跟目录/vendor/encore/laravel-admin/src/Form/Field下的Select.php文件,找到下面代码:
$script = <<<EOT $(document).on('change', "{$this->getElementClassSelector()}", function () { var target = $(this).closest('.fields-group').find(".$class"); $.get("$sourceUrl?q="+this.value, function (data) { target.find("option").remove(); $(target).select2({ data: $.map(data, function (d) { d.id = d.$idField; d.text = d.$textField; return d; }) }).trigger('change'); }); }); EOT;
并修改成以下代码:
$script = <<<EOT $(document).on('change', "{$this->getElementClassSelector()}", function () { var target = $(this).closest('.fields-group').find(".$class"); $.get("$sourceUrl?q="+this.value, function (data) { target.find("option").remove(); $(target).select2({ data: $.map(data, function (d) { d.id = d.$idField; d.text = d.$textField; return d; }) }).trigger('change'); }); }); $('{$this->getElementClassSelector()}').trigger('change'); EOT;
我们在原有代码中加入这句:
$('{$this->getElementClassSelector()}').trigger('change');
作用就是在初始化的时候触发一次联动。
然后在我们的表单中,我们再来定义编辑初始时候的值,代码如下:
$form->select('hezuo', "合作模式")->options(function () { $record = request()->route()->parameters(); $record = $record["chanpin"]; $data = ChanpinModel::where('id', $record)->first(); $hezuoList = array( "1" => '测试1', "2" => '测试2', "3" => '测试3', ); $hezuo = $data->hezuo; return [$hezuo => $hezuoList[$hezuo]]; });
这段代码是根据当前记录的值,去获取对应所属那个选项,这样便使select联动编辑时,能够默认选上我们的值。
以上这篇laravel-admin解决表单select联动时,编辑默认没选上的问题就是小编分享给大家的全部内容了,希望能给大家一个参考
您可能感兴趣的文章:
相关文章推荐
- laravel-admin解决表单SELECT联动时,编辑默认没选上
- 堆表的在执行Select语句时的默认排序问题——解决问题
- layer表单元素 三级联动 省市县选择框动态渲染问题解决
- 解决“Replace wireless configuration ”默认被选上的问题
- 关于enter不触发默认的表单提交问题的解决
- 织梦自定义表单用js代替联动地区解决联动地区选择问题
- 解决表单乱码问题之一,修改tomcat默认编码格式
- laravel-admin php artisan admin:install报错问题解决办法
- 参数表单下拉数据集多选联动问题及解决办法
- bootstrap-select默认选中问题解决
- 解决input表单元素在ios系统上默认圆角的问题?
- dedecms自定义表单用js代替联动类型解决联动问题
- 解决ligerui不校验select表单,以及ie678下不校验所有表单问题
- 解决使用layui的时候form表单中的select等不能渲染的问题
- select2表单带出编辑,多选赋值问题
- 解决chrome浏览器对于自动填充的input表单添加的默认的淡黄色背景问题 && 一般的浏览器input和button的高度不一致问题
- JSP表单select多级联动问题
- 解决layui的使用以及针对select、radio等表单组件不显示的问题
- 解决IE浏览器下select下拉框默认样式问题