远程下拉组件 params 动态传递参数问题


两个远程下拉组件,第二个下拉组件得数据需要根据第一个下拉组件选中的值,作为查询条件,:input-attr 中 'params':{'build_yard_id':yardId},具体的写法是什么,build_yard_id 是需要被查询的关键词,yardId是需要动态改变的值,应该怎么操作呢,纯属小白,求教!

2个回答默认排序 投票数排序
苏晓生
苏晓生
在藏经阁
1年前
error
error回复苏晓生
这家伙很懒,什么也没写~
1年前

谢谢您的回答,为什么我在formItem组件中添加了 params ,发送至后台不能正常过滤出想要的数据呢?是后台需要改代码吗?

苏晓生
苏晓生回复error
在藏经阁
1年前

你先确认参数是不是到了后台
然后跟踪一下查询的sql 是不是预期结果

error
error回复苏晓生
这家伙很懒,什么也没写~
1年前

参数可以传递过来,但是不会自动加载到 $where 中,所以手动改了代码,不知道 input-attr 在多表的情况下,怎么正确的书写了。。。

尘心
尘心
这家伙很懒,什么也没写~
1年前

请问解决了吗

error
error回复尘心
这家伙很懒,什么也没写~
1年前

目前木有办法自动将参数加载到 $where 中,所以手动改了代码,动态加载下拉列表根据 第一个下拉列表改变值,影响第二个 下拉列表解决了, 组件加 :key="你的参数" 改变参数值就可以

尘心
尘心回复error
这家伙很懒,什么也没写~
1年前

你好,前端代码能展示一下吗,


我感觉我这个有问题,

error
error回复尘心
这家伙很懒,什么也没写~
1年前

不好意思呀,我才看到。。。。


就是通过第一个select获取到值,作为查询条件传给第二个select得数据接口,后面通过更改 formItem得key来实时渲染dom。

error
error回复尘心
这家伙很懒,什么也没写~
1年前
vue 复制代码
<FormItem :label="t('build.room.build_yard_id')"
                              type="remoteSelect"
                              v-model="baTable.form.items!.build_yard_id"
                              prop="build_yard_id"
                              :input-attr="{
                                  pk: 'ba_build_yard.id',
                                  field: 'name',
                                  'remote-url': '/admin/build.Yard/index',
                                  onChange: onGetYardId
                              }"
                              :placeholder="t('Please select field', { field: t('build.room.build_yard_id') })" />
                    <FormItem :label="t('build.room.build_build_id')"
                              type="remoteSelect"
                              v-model="baTable.form.items!.build_build_id"
                              prop="build_build_id"
                              :input-attr="{
                                  pk: 'ba_build_build.id',
                                  field: 'name',
                                  'remote-url': '/admin/build.Build/index',
                                  params: {
                                      search:[{
                                          field: 'build_yard_id',
                                          val:baTable.form.items!.build_yard_id,
                                          operator:'eq',
                                      }]
                                      // 'build_yard_id': yardId
                                  },
                                  onChange: onGetBuildId
                              }"
                              :key="yardId"
                              :placeholder="t('Please select field', { field: t('build.room.build_build_id') })" />

刚刚看到一篇帖子有说到这个问题,试了一下,不需要改后台代码了。
简单的联动代码示例

请先登录
0
1
0
9