ng-options和ng-checked在表单中的高级运用

AngularJS是当前很是的流行的前端框架,它的语法糖很是多,也极大的方便了前端开发者,可是有着用法仍是须要去琢磨一下的javascript

ng-options

在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

  • 代码很不简洁,若是选项较多就会很乱
  • 不方便渲染,若是option在变须要使用js动态加载
  • 不方便存储对象

使用ng-repeat

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>

优势:前端框架

  • 代码简介
  • 可存储对象,取值方便

缺点:框架

  • 没有默认显示!,在有些界面需求中,select多是须要placeholder同样的显示提示效果的,那么使用这个方式显示效果默认是空白
  • 没法经过ng-model来获取当前选择的值

使用ng-options

这里使用一个年级、班级的选项来做为例子:即选择年级以后再显示对应的可选班级。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

  • “请选择"的option须要有value,否则会报错
  • 若是要设置默认选择值,好比一开始就选择"高一",则须要设置modal在数组里的对象。
$scope.modal.grade = $scope.modal.grades[2];//高一在数组的位置角标为2

优势:htm

  • 代码简洁,易于维护
  • 有默认显示
  • 可使用ng-modal准确获取当前选择的对象

ng-checked

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的用法同理。

相关文章
相关标签/搜索