Angularjs trigger country state dependency

后端 未结 4 2021
[愿得一人]
[愿得一人] 2021-01-05 13:03

Can someone please help me make my example of Country/State drop down dependency work?

I intentionally created JSON in this way because I want the dependency to be g

相关标签:
4条回答
  • 2021-01-05 13:36

    The easiest way to fix is to refer the currentCountry in the 2nd select and no need to use the $watch to achieve your requirement.

    <select data-ng-model="currentCountry" data-ng-options="country.name for country in Countries.items">
    
    <select data-ng-model="currentItem" data-ng-options="item.id as item.name for item in States.StateGroups[currentCountry.StateGroupID].items">
    

    Demo

    0 讨论(0)
  • 2021-01-05 13:40

    angular-country-picker bower install angular-country-picker (or) npm install angular-country-picker

    <script src="bower_components/angular-country-picker/country-picker.js"></script>
    <script src="node_modules/angular-country-picker/country-picker.js"></script>
    
           angular.module('webApp', ['puigcerber.countryPicker']);
    
           <select ng-model="selectedCountry" pvp-country-picker="name"></select>
    
           angular.module('myApp', ['puigcerber.countryPicker'])
           .config(function(pvpCountriesProvider) {
            pvpCountriesProvider.setCountries([
            { name: 'Abkhazia', alpha2: 'AB'},
            { name: 'Kosovo', alpha2: 'XK'},
            { name: 'Nagorno-Karabakh', alpha2: 'NK'},
            { name: 'Northern Cyprus', alpha2: 'KK'},
            { name: 'Somaliland', alpha2: 'JS'},
            { name: 'South Ossetia', alpha2: 'XI'},
            { name: 'Transnistria', alpha2: 'PF'}
          ]);
        });
    
    0 讨论(0)
  • 2021-01-05 13:41

    I suggest you a bit of refactoring to your data model - it seems tangled. Let's store counties and states in two arrays:

    $scope.countries = [{
        "name": "USA",
        "id": 1
      },{
        "name": "Canada",
        "id": 2
    }];
    $scope.states = [{
        "name": "Alabama",
        "id": 1,
        "countryId": 1
      }, {
        "name": "Alaska",
        "id": 2,
        "countryId": 1
      }, {
        "name": "Arizona",
        "id": 3,
        "countryId": 1
      }, {
        "name": "Alberta",
        "id": 4,
        "countryId": 2
      }, {
        "name": "British columbia",
        "id": 5,
        "countryId": 2
    }];
    

    Having this, we can write selects for data:

    <select data-ng-model="country" data-ng-options="country.name for country in countries" data-ng-change="updateCountry()">
      <option value="">Select country</option>
    </select>
    <select data-ng-model="state" data-ng-options="state.name for state in availableStates">
      <option value="">Select state</option>
    </select>
    

    It's a pity we cannot use if expressions in selectors - if we can, we do not need a single line of JS! But we need:

    $scope.updateCountry = function(){
      $scope.availableStates = [];
    
      angular.forEach($scope.states, function(value){
        if(value.countryId == $scope.country.id){
          $scope.availableStates.push(value);
        }
      });
    }
    

    And that's all. Here is a working plunk for you.

    0 讨论(0)
  • 2021-01-05 14:01

    first, I think there is a little mistake in your JSON, you should have one "items" before the Canadian states

              {"items": [{  "id": "201",
                        "name": "Alberta"
                       }, .....
    

    After doing this, I would modify your HTML in order to have 2 different model names (the way you did, at the first click you overwrite the list of countries). Then I'll use a different syntax for the ng-repeat, in order to force the value to the StateGroupId

     <select data-ng-model="selectedCountry">
                <option ng-repeat='country in Countries.items' value='{{country.StateGroupID}}'>{{country.name}}</option>          
            </select>
    

    Doing this allows you to create a function to get the states of the selected group ID :

     $scope.getStates=function(){
        console.log($scope.selectedCountry)
         return $scope.backupStates.StateGroups[$scope.selectedCountry].items;
    }
    

    Then you can use this function to display them using ng-repeat

                <select data-ng-model="selectedState" >
                  <option value="">Please select a state</option>
                  <option ng-repeat='state in getStates()'>{{state.name}}</option>
                </select>
    

    I modified your fiddle here : http://jsfiddle.net/DotDotDot/TsxTU/14/ , I hope this is the kind of behavior you wanted :)

    0 讨论(0)
提交回复
热议问题