AngularJS是当前很是的流行的前端框架,它的语法糖很是多,也极大的方便了前端开发者,可是有着用法仍是须要去琢磨一下的javascript
在select表单控件中,总结一下目前的几种写法。html
<select> <option value="test1">test1</option> <option value="test1">test1</option> <option value="test1">test1</option> <option value="test1">test1</option> </select>
优势:简单前端
缺点:java
ng-repeat是angularJS中很是强大的一个directive,在渲染列表上极大的方便了前端开发者,那么因为有多个重复的option,固然可使用ng-repeat,用法以下:数组
<select> <option ng-repeat="option in options" value="{{option}}">{{option.name}}</option> </select> <script> $scope.options = [{id:1,name:'test1'},{id:2,name:'test2'},{id:3,name:'test3'}]; </scirpt>
优势:前端框架
缺点:框架
这里使用一个年级、班级的选项来做为例子:即选择年级以后再显示对应的可选班级。spa
<select ng-model="modal.grade" ng-change="modalChangeGrade()" ng-options="grade.gradeText for grade in modal.grades"> <option value="" disabled>请选择</option> </select> <script> $scope.modal.grades = [ {id:1,gradeText:'初一',classes:[]}, {id:2,gradeText:'初二',classes:[]}, {id:3,gradeText:'高一'},classes:[]]; $scope.modalChangeGrade = function(){ //班级的HTML片断就不在这里写了 $scope.modal.classes = $scope.modal.grade.classes; } </scirpt>
注:code
$scope.modal.grade = $scope.modal.grades[2];//高一在数组的位置角标为2
优势:htm
checkbox和radio是咱们常常使用到的表单组件,那么如何使用angularJs简洁方便的获取当前已选择对象呢?
这里只说angularJs的用法:
下面依然以年级和班级为例:
<div ng-repeat="class in grade.classes" ng-click="class.is_checked=!class.is_checked"> <input type="checkbox" value="" ng-checked="class.is_checked"> {{class.id+'班'}} </div>
最后须要查看有哪些checkbox被选中时,只须要遍历$scope.grade.classes数组查看有哪些对象的is_checked属性为true便可。
radio的用法同理。