6

I have a group of material design checkboxes and I would like to bind their values to an array in my controller.

To accomplish this I used the first method described in this SO answer. While the values are properly being added and removed from the list, the boxes no longer display as "checked" when I click on them. My code is below and I also recreated the problem in this codepen.

HTML for my checkbox

<md-checkbox 
    ng-repeat="site in websites" 
    value="{{site}}" 
    ng-checked="selection.indexOf(site) > -1" 
    ng-click="toggleSelection(site)"> 
    {{site}}
</md-checkbox>

JavaScript from Controller

  $scope.websites = ['Facebook', 'Twitter', 'Amazon'];
  $scope.selection = ['Facebook'];
  $scope.toggleSelection = function toggleSelection(site) {
    var idx = $scope.selection.indexOf(site);

    // is currently selected
    if (idx > -1) {
      $scope.selection.splice(idx, 1);
    }

    // is newly selected
    else {
      $scope.selection.push(site);
    }
  };
});
1
  • Since the v 0.9 release of Angular Material it looks like the code above now works, while @jarz code works for v0.8 and below Commented May 22, 2015 at 16:42

1 Answer 1

4

Try changing this:

ng-checked="selection.indexOf(site) > -1" 

to this:

ng-checked="{{selection.indexOf(site) > -1}}" 

Worked for me: http://codepen.io/anon/pen/xbNOmE

Sign up to request clarification or add additional context in comments.

1 Comment

Just an update of @jarz answer, as his example do not work anymore: codepen.io/bora-89/pen/GNXvWJ

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.