ng-options和ng-checked在表单中的高级运用(推荐)


Posted in Javascript onJanuary 21, 2017

AngularJS是当前非常的流行的前端框架,它的语法糖非常多,也极大的方便了前端开发者,但是有着用法还是需要去琢磨一下的。

ng-options

在select表单控件中,总结一下目前的几种写法。

普通写法

<select>
  <option value="test1">test1</option>
  <option value="test1">test1</option>
  <option value="test1">test1</option>
  <option value="test1">test1</option>
</select>

优点:简单

缺点:

  • 代码很不简洁,如果选项较多就会很乱
  • 不方便渲染,如果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

这里使用一个年级、班级的选项来作为例子:即选择年级之后再显示对应的可选班级。

<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>

注:

“请选择"的option需要有value,不然会报错

如果要设置默认选择值,比如一开始就选择"高一",则需要设置modal在数组里的对象。

$scope.modal.grade = $scope.modal.grades[2];//高一在数组的位置角标为2

优点:

  • 代码简洁,易于维护
  • 有默认显示
  • 可以使用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的用法同理。

以上所述是小编给大家介绍的ng-options和ng-checked在表单中的高级运用,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
超级强大的表单验证
Jun 26 Javascript
JavaScript 类的定义和引用 JavaScript高级培训 自定义对象
Apr 27 Javascript
漂亮的jquery提示效果(仿腾讯弹出层)
Feb 05 Javascript
jquery实现页面百叶窗走马灯式翻滚显示效果的方法
Mar 12 Javascript
js实现的动画导航菜单效果代码
Sep 10 Javascript
根据user-agent判断蜘蛛代码黑帽跳转代码(js版与php版本)
Sep 14 Javascript
Bootstrap modal 多弹窗之叠加显示不出弹窗问题的解决方案
Feb 23 Javascript
vue-cli结合Element-ui基于cropper.js封装vue实现图片裁剪组件功能
Mar 01 Javascript
解决循环中setTimeout执行顺序的问题
Jun 20 Javascript
JS实现数组去重,显示重复元素及个数的方法示例
Jan 21 Javascript
JS中的算法与数据结构之队列(Queue)实例详解
Aug 20 Javascript
javascript canvas API内容整理
Feb 16 Javascript
vue实现添加标签demo示例代码
Jan 21 #Javascript
微信小程序 数据交互与渲染实例详解
Jan 21 #Javascript
前端编码规范(3)JavaScript 开发规范
Jan 21 #Javascript
Bootstrap框架安装使用详解
Jan 21 #Javascript
AngularJS ng-repeat指令中使用track by子语句解决重复数据遍历错误问题
Jan 21 #Javascript
微信小程序 九宫格实例代码
Jan 21 #Javascript
AngularJS的ng-repeat指令与scope继承关系实例详解
Jan 21 #Javascript
You might like
生成ubuntu自动切换壁纸xml文件的php代码
2010/07/17 PHP
thinkphp文件引用与分支结构用法实例
2014/11/26 PHP
php与c 实现按行读取文件实例代码
2017/01/03 PHP
Laravel 在views中加载公共页面的实现代码
2019/10/22 PHP
js以对象为索引的关联数组
2010/07/04 Javascript
js+css在交互上的应用
2010/07/18 Javascript
js实现简单的星级选择器提交效果适用于评论等
2013/10/18 Javascript
快速解决jQuery与其他库冲突的方法介绍
2014/01/02 Javascript
js和jquery如何获取图片真实的宽度和高度
2014/09/28 Javascript
js查找节点的方法小结
2015/01/13 Javascript
JS中使用apply、bind实现为函数或者类传入动态个数的参数
2016/04/26 Javascript
JS简单实现禁止访问某个页面的方法
2016/09/13 Javascript
JS禁止查看网页源代码的实现方法
2016/10/12 Javascript
bootstrap flask登录页面编写实例
2016/11/01 Javascript
JS定时器实现数值从0到10来回变化
2016/12/09 Javascript
node.js环境搭建图文详解
2018/09/19 Javascript
js拖动滑块和点击水波纹效果实例代码
2018/10/16 Javascript
javascript中函数的写法实例代码详解
2018/10/28 Javascript
跟老齐学Python之网站的结构
2014/10/24 Python
Python paramiko模块的使用示例
2018/04/11 Python
python numpy 显示图像阵列的实例
2018/07/02 Python
Python实现计算对象的内存大小示例
2019/07/10 Python
Python实现UDP程序通信过程图解
2020/05/15 Python
python3.x中安装web.py步骤方法
2020/06/23 Python
Python 实现劳拉游戏的实例代码(四连环、重力四子棋)
2021/03/03 Python
马德里竞技官方网上商店:Atletico Madrid Shop
2019/03/31 全球购物
Cocopanda波兰:购买化妆品、护肤品、护发和香水
2020/05/25 全球购物
公职人员索取回扣检举信
2014/04/04 职场文书
《棉鞋里的阳光》教学反思
2014/04/24 职场文书
幼儿园六一儿童节演讲稿
2015/03/19 职场文书
微信早安问候语
2015/11/10 职场文书
学生会2016感恩节活动小结
2016/04/01 职场文书
2016年推广普通话宣传周活动总结
2016/04/06 职场文书
Python-typing: 类型标注与支持 Any类型详解
2021/05/10 Python
「魔法少女伊莉雅」美游粘土人开订
2022/03/21 日漫
MySQL的prepare使用以及遇到的bug
2022/05/11 MySQL