Флажок Angularjs выбранные значения не определены - PullRequest
0 голосов
/ 04 января 2019

Привет, этот вопрос уже задан, но это не решает мою проблему.

Я передаю значения флажков контроллеру, но не могу определить, какой из них выбран.

Это мой код

HTML:

<div class="col-sm-3" ng-repeat="days in formData.businessDays">
   <input type="checkbox" ng-model="business_days.Selected" ng-change=""><span>  {{days.name}}</span>
</div>

Js:

$scope.addData = function(form)
{
    $scope.formData.days_id = [];
    angular.forEach($scope.formData.businessDays, function(businessDays){
       //console.log(businessDays);
        if (businessDays.Selected) {
            $scope.formData.days_id.push(businessDays.value);
        }
    })
}

//this days data values
$scope.formData.businessDays = [{
                    name: "Monday",
                    value: "M",
                  }, {
                    name: "Tuesday",
                    value: "T",
                  }, {
                    name: "Wednesday",
                    value: "W",
                  }, {
                    name: "Thursday",
                    value: "Th",
                  }, {
                    name: "Friday",
                    value: "F",
                  }, {
                    name: "Saturday",
                    value: "S",
                  }, {
                    name: "Sunday",
                    value: "Su",
                  }, ];

Это изображение моей консоли enter image description here

Я могуопределить, какие значения выбраны?

Ответы [ 3 ]

0 голосов
/ 04 января 2019
 <div class="col-sm-3" ng-repeat="days in formdata.businessDays">
    <input type="checkbox" ng-model="days.selected" ng-click="selected(days)"> 
    <span> {{days.name}}</span>
 </div>

и в контроллере

 $scope.selected = function(d){
    console.log(d);

}

$scope.formdata = {};
$scope.formdata.businessDays = [{
    name: "Monday",
    value: "M",
}, {
    name: "Tuesday",
    value: "T",
}, {
    name: "Wednesday",
    value: "W",
}, {
    name: "Thursday",
    value: "Th",
}, {
    name: "Friday",
    value: "F",
}, {
    name: "Saturday",
    value: "S",
}, {
    name: "Sunday",
    value: "Su",
},];
0 голосов
/ 04 января 2019
<div class="col-sm-3" ng-repeat="days in formData.businessDays">
   <input type="checkbox" ng-model="days.Selected" ng-change=")"><span>  {{days.name}}</span>
</div>


$scope.addData = function(form)
{
    $scope.formData.days_id = [];
    angular.forEach($scope.formData.businessDays, function(businessDays){
       //console.log(businessDays);
        if (businessDays.Selected) {
            $scope.formData.days_id.push(businessDays.value);
        }
    })
}
0 голосов
/ 04 января 2019

Вы должны предоставить свойство selected каждому из object в $scope.formData.businessDays, чтобы определить, выбрано ли оно, что-то вроде: -

$scope.selectedItems = [];
  $scope.formData = {};
  $scope.formData.businessDays = [{
    name: "Monday",
    value: "M",
    selected: false
  }, {
    name: "Tuesday",
    value: "T",
    selected: false
  }, {
    name: "Wednesday",
    value: "W",
    selected: false
  }, {
    name: "Thursday",
    value: "Th",
    selected: false
  }, {
    name: "Friday",
    value: "F",
    selected: false
  }, {
    name: "Saturday",
    value: "S",
    selected: false
  }, {
    name: "Sunday",
    value: "Su",
    selected: false
  }];
  $scope.changed = function(value) {
    if (value.selected) {
      $scope.selectedItems.push(value.name);
    } else {
      var theIndex = $scope.selectedItems.indexOf(value.name);
      if (theIndex != -1) {
        $scope.selectedItems.splice(theIndex, 1);
      }
    }
  }

и подпишитесь на change событие checkboxes, чтобы поддерживать свойство в актуальном состоянии

<div class="col-sm-3" ng-repeat="days in formData.businessDays">
  <input type="checkbox" ng-model="days.selected" ng-change="changed(days)"><span> {{days.name}} </span>
</div>
<div>
  <p>selected values</p>
  <label ng-repeat="item in selectedItems">{{item}} </label>
</div>
...