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 相关文章推荐
把JS与CSS写在同一个文件里的书写方法
Jun 02 Javascript
JavaScript 事件参考手册
Dec 24 Javascript
javascript-简单的日历实现及Date对象语法介绍(附图)
May 30 Javascript
alert和confirm功能介绍
May 21 Javascript
JavaScript作用域链示例分享
May 27 Javascript
微信小程序 Record API详解及实例代码
Sep 30 Javascript
Bootstrap 3 进度条的实现
Feb 22 Javascript
vue组件watch属性实例讲解
Nov 07 Javascript
p5.js临摹旋转爱心
Oct 23 Javascript
Vue-cli打包后如何本地查看的操作
Sep 02 Javascript
JavaScript实现网页计算器功能
Oct 29 Javascript
JavaScript实现简单的音乐播放器
Aug 14 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
农民C键的运用技巧
2020/03/04 星际争霸
PHP学习之PHP变量
2006/10/09 PHP
如何开发一个虚拟域名系统
2006/10/09 PHP
php adodb连接带密码access数据库实例,测试成功
2008/05/14 PHP
PHP Global变量定义当前页面的全局变量实现探讨
2013/06/05 PHP
解密ThinkPHP3.1.2版本之模块和操作映射
2014/06/19 PHP
xmlHTTP实例
2006/10/24 Javascript
jquery必须知道的一些常用特效方法及使用示例(整理)
2013/06/24 Javascript
js脚本实现数据去重
2014/11/27 Javascript
JavaScript实现动画打开半透明提示层的方法
2015/04/21 Javascript
javascript实现多栏闭合展开式广告位菜单效果实例
2015/08/05 Javascript
jQuery实现向下滑出的二级菜单效果实例
2015/08/22 Javascript
基于Bootstrap实现的下拉菜单手机端不能选择菜单项的原因附解决办法
2016/07/22 Javascript
Bootstrap优化站点资源、响应式图片、传送带使用详解3
2016/10/14 Javascript
JavaScript获取键盘按键的键码(参照表)
2017/01/10 Javascript
canvas绘制万花筒效果(代码分享)
2017/01/20 Javascript
AngularJS 防止页面闪烁的方法
2017/03/09 Javascript
nodejs实现大文件(在线视频)的读取
2020/10/16 NodeJs
p5.js临摹旋转爱心
2019/10/23 Javascript
JavaScript 中的无穷数(Infinity)详解
2020/02/13 Javascript
使用SAE部署Python运行环境的教程
2015/05/05 Python
Python打印“菱形”星号代码方法
2018/02/05 Python
Python多进程multiprocessing.Pool类详解
2018/04/27 Python
pycharm 设置项目的根目录教程
2020/02/12 Python
python中的socket实现ftp客户端和服务器收发文件及md5加密文件
2020/04/01 Python
让IE支持HTML5的方法
2012/12/11 HTML / CSS
html5实现的便签特效(实战分享)
2013/11/29 HTML / CSS
ONLY德国官方在线商店:购买时尚女装
2017/09/21 全球购物
DHC美国官网:日本通信销售第一的化妆品品牌
2017/11/12 全球购物
总经理文秘岗位职责
2014/02/03 职场文书
高校优秀辅导员事迹材料
2014/05/07 职场文书
商场开业庆典策划方案
2014/06/02 职场文书
关于迟到的检讨书
2015/05/06 职场文书
商务英语邮件开头问候语
2015/11/10 职场文书
CSS3新特性详解(五):多列columns column-count和flex布局
2021/04/30 HTML / CSS
MySQL时间设置注意事项的深入总结
2021/05/06 MySQL