Fastadmin Selectpage下拉列表实现二级联动,多级联动

fastadmin input实现2级联动 多级联动
添加add页面如下效果。

add.html

 

<div class="form-group">
        <label class="control-label col-xs-12 col-sm-2">{:__('水厂')}:</label>
        <div class="col-xs-12 col-sm-8">
            <input id="c-waterworks_id" data-rule="required" data-field="waterworks_name" data-source="waterworks/index" class="form-control selectpage" name="row[waterworks_id]" type="text" value="">
        </div>
    </div>
    <div class="form-group">
        <label class="control-label col-xs-12 col-sm-2">{:__('设备间')}:</label>
        <div class="col-xs-12 col-sm-8">
            <input id="c-waterworks_type_id" data-rule="required" data-field="device_name" data-source="waterworks_device/index" class="form-control selectpage" name="row[device_id]" type="text" value="">
        </div>
    </div>


 
关联的控制器都有 waterworks/index ;waterworks_device/index;
waterworks/index这个控制器方法不用动。
waterworks_device/index这个控制器里的方法如下

 

$param1 = $this->request->param();
if(!empty($param1['custom'])){
    $where1['waterworks_id'] = $param1['custom']['waterworks_id'];
}else{
    $where1 = "id > 0";
}
$list = $this->model
    ->where($where)
    ->where($where1)
    ->order($sort, $order)
    ->limit($offset, $limit)
    ->select();


 
js中的代码:

 

add: function () {
            $("#c-waterworks_type_id").data("params", function(){
                return {custom: {waterworks_id: $("#c-waterworks_id").val()}};
            });
            Controller.api.bindevent();
        },
        edit: function () {
            $("#c-waterworks_type_id").data("params", function(){
                return {custom: {waterworks_id: $("#c-waterworks_id").val()}};
            });
            Controller.api.bindevent();
        },


 
这样添加页面就可以实现2级联动了。3级联动也是如此。

下面是修改页面
edit.html

<div class="form-group">
        <label class="control-label col-xs-12 col-sm-2">{:__('水厂')}:</label>
        <div class="col-xs-12 col-sm-8">
            <input id="c-waterworks_id" data-rule="required" data-field="waterworks_name" data-source="waterworks/index" class="form-control selectpage" name="row[waterworks_id]" type="text" value="{$row.waterworks_id}">
        </div>
    </div>
    <div class="form-group">
        <label class="control-label col-xs-12 col-sm-2">{:__('设备间')}:</label>
        <div class="col-xs-12 col-sm-8">
            <input id="c-waterworks_type_id" data-rule="required" data-field="device_name" data-source="waterworks_device/index" class="form-control selectpage" name="row[device_id]" type="text" value="{$row.device_id}">
        </div>
    </div>


 
主要是判断 有没有这个参数keyValue

以上两个控制器中写判断
waterworks.php/index
waterworks_device.php/index
两个控制器分别写上如下代码,根据自己需求修改你的字段。

 

foreach($list as $key=>$value){
                    $list[$key]['parent_id']=db('admin')->where('id',$value['parent_id'])->value('nickname');//所属客户
                    $list[$key]['operate_id']=db('admin')->where('id',$value['operate_id'])->value('nickname');//运维人员
                if($this->request->request("keyValue") && $this->request->request("keyValue") == $value['id']){
                    return ['total'=>1, 'list'=>[
                        ['id'=>$value['id'], 'waterworks_name'=>$value['waterworks_name']]
                    ]
                    ];
                }
            }


 
之后,修改页面的也实现了。
 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现二级联动下拉列表,可以通过以下步骤进行: 1. 在HTML中,创建两个下拉列表,一个作为主要的下拉列表,另一个作为次要的下拉列表,例如: ``` <select id="mainList"> <option value="">请选择</option> <option value="1">选项1</option> <option value="2">选项2</option> <option value="3">选项3</option> </select> <select id="subList" disabled> <option value="">请选择</option> </select> ``` 2. 使用JavaScript编写代码,以根据主下拉列表的选择更新次下拉列表。例如: ``` var mainList = document.getElementById("mainList"); var subList = document.getElementById("subList"); mainList.addEventListener("change", function() { var selectedValue = mainList.value; // 清空次下拉列表 subList.innerHTML = '<option value="">请选择</option>'; if (selectedValue === "1") { // 如果选择了选项1,则更新次下拉列表的选项 subList.innerHTML += '<option value="11">选项1-1</option>'; subList.innerHTML += '<option value="12">选项1-2</option>'; } else if (selectedValue === "2") { // 如果选择了选项2,则更新次下拉列表的选项 subList.innerHTML += '<option value="21">选项2-1</option>'; subList.innerHTML += '<option value="22">选项2-2</option>'; } else if (selectedValue === "3") { // 如果选择了选项3,则更新次下拉列表的选项 subList.innerHTML += '<option value="31">选项3-1</option>'; subList.innerHTML += '<option value="32">选项3-2</option>'; } // 启用或禁用次下拉列表 if (selectedValue) { subList.disabled = false; } else { subList.disabled = true; } }); ``` 3. 上述代码将监听主下拉列表的“change”事件,并在选择更改时更新次下拉列表的选项。此外,代码还会启用或禁用次下拉列表,以防止用户在未选择主列表时进行选择。 希望这能帮助到你实现二级联动下拉列表
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值