如何使用ng-model和ng-repeat在AngularJS中传递复选框值

时间:2015-11-03 16:55:24

标签: javascript jquery angularjs checkbox

我有一个页面,用户可以通过输入搜索字词来搜索文章,并在需要时过滤结果。

过滤器最初包含多个选择框,其值已从ajax调用中获取,并且所选值已使用ng-model发回。它工作正常。

现在要求将多个选择框转换为复选框,我已设法创建复选框。

当用户输入搜索查询并选中其中一个复选框时,我遇到问题,我无法在app.js中获取所选的复选框值来过滤结果。

<div class="col-lg-3">
    <h3 class="m0 pb-lg">Filters</h3>
    <div class="form-group mb-xl">
         <form method="get" ng-controller="SearchController as form" class="form-horizontal">
            <label class="control-label mb">By Type of Study</label><br><label class="checkbox-inline c-checkbox" ng-repeat="s in form.typeOfStudies">
            <input type="checkbox" ng-model="search.typeOfStudy" ng-true-value="'YES'" ng-false-value="'NO'">
                <span class="fa fa-check"></span>{{s}}</input>
            </label>
            <br>
        </form>
    </div>
</div>
</div>

app.js包含:

 $scope.getById = function (id) {
           if (id.typeOfStudy){
            $.each(id.typeOfStudy, function() {
                    if (count < id.typeOfStudy.length) {
                        count++;
                        qTypeOfStudy += "'" + this + "',";
                    }
                    else if (count == id.typeOfStudy.length) {
                        qTypeOfStudy += "'" + this + "'";
                    }
            })
        }
  }

getById已在页面上搜索栏中的主文本表单提交中传递。

1 个答案:

答案 0 :(得分:0)

我使用ng-repeat列表中的某个值作为ID,您可以在s in form.typeOfStudies中拥有一些内容。 像这样的东西:

<div ng-repeat="modelList in modelsLists">
<input type="checkbox" ng-model="selection.ids[modelList.id]" id="{{modelList.id}}"/>
</div>

在JS中初始化:

$scope.selection = {
        ids: {}
    };

并检查复选框:

if($scope.selection.ids[id]){
    // do something
}