AngularJS中的MultiSelect相互依赖下拉列表

问题描述

我想在javascript / jQuery / AngularJS中有一个多选的相互依赖下拉列表。假设数据来自数据库查询,则下拉列表已预先填充。

字段:

  • Drop-down-1
  • Drop-down-2
  • Drop-down-3
  • 提交按钮

enter image description here

如果我们选择下拉列表2,则其他两个下拉列表应根据下拉列表1进行更新,反之亦然。类似于图片中的Excel功能

该怎么做?

angular.module('myApp',[])
  .controller('MyController',MyController)

function MyController($scope) {
  $scope.candidateSel = undefined;
  $scope.selecetedCompany = undefined;
  $scope.selecetdLoc = undefined;

  $scope.listData = [{
    "candidate_id": "1","candidate_name": "Name1","candidate_email": "amitsutar119@gmail.com","candidate_com": "Company1","candidate_loc": "com1_loc1","candidate_dep": "com1_loc1_dep1"
  },{
    "candidate_id": "3","candidate_name": "Name 3_title_1","candidate_email": "name3@gmail.com",{
    "candidate_id": "5","candidate_name": "Smith","candidate_email": "smith@gmail.com","candidate_com": "Company2","candidate_loc": "com2_loc2","candidate_dep": "com2_loc2_dep1"
  },{
    "candidate_id": "6","candidate_dep": "com2_loc2_dep1"
  }];

  $scope.getInfo = function() {
    if ($scope.candidateSel) {
      $scope.company = [$scope.candidateSel['candidate_com']];
      $scope.location = [$scope.candidateSel['candidate_loc']];
    }
  };

}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.6.3/angular.min.js"></script>
<div ng-app="myApp" ng-controller="MyController">

  <div>
    Names:
    <select id="names" ng-model="candidateSel" ng-options="data.candidate_name for data in listData track by data.candidate_id" ng-change="getInfo()">
      <option value=''>Select</option>
    </select>
  </div>

  <div>
    Company:
    <select id="company" ng-disabled="!candidateSel" ng-model="selecetedCompany" ng-options="cancompany for cancompany in company">
      <option value="">Select</option>
    </select>
  </div>

  <div>
    Location:
    <select id="location" ng-disabled="!selecetedCompany" ng-model="selecetdLoc" ng-options="canloc for canloc in location">
      <option value="">Select</option>
    </select>
  </div>

</div>

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...