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 相关文章推荐
Tab页界面 用jQuery及Ajax技术实现(php后台)
Oct 12 Javascript
javascript中this做事件参数相关问题解答
Mar 17 Javascript
jquery 按键盘上的enter事件
May 11 Javascript
js获取IP地址的方法小结
Jul 01 Javascript
Jquery设置attr的disabled属性控制某行显示或者隐藏
Sep 25 Javascript
2014最热门的JavaScript代码高亮插件推荐
Nov 25 Javascript
js+html5操作sqlite数据库的方法
Feb 02 Javascript
jQuery Validate验证框架详解(推荐)
Dec 17 Javascript
node.js(express)中使用Jcrop进行图片剪切上传功能
Apr 21 Javascript
vue之浏览器存储方法封装实例
Mar 15 Javascript
JavaScript实现滚动加载更多
Dec 27 Javascript
js加减乘除精确运算方法实例代码
Jan 17 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
动态网站web开发 PHP、ASP还是ASP.NET
2006/10/09 PHP
深入apache host的配置详解
2013/06/09 PHP
解析php多线程下载远程多个文件
2013/06/25 PHP
遍历echsop的region表形成缓存的程序实例代码
2016/11/01 PHP
PHP设计模式之PHP迭代器模式讲解
2019/03/22 PHP
[原创]js与自动伸缩图片 自动缩小图片的多浏览器兼容的方法总结
2007/03/12 Javascript
javascript 有用的脚本函数
2009/05/07 Javascript
eclipse如何忽略js文件报错(附图)
2013/10/30 Javascript
用jquery获取自定义的标签属性的值简单实例
2016/09/17 Javascript
JS如何生成一个不重复的ID的函数
2016/12/25 Javascript
mpvue构建小程序的方法(步骤+地址)
2018/05/22 Javascript
通过vue写一个瀑布流插件代码实例
2019/09/07 Javascript
jquery将json转为数据字典的实例代码
2019/10/11 jQuery
[01:09:20]NB vs NAVI Supermajor小组赛A组 BO3 第二场 6.2
2018/06/03 DOTA
Python算法应用实战之栈详解
2017/02/04 Python
python中利用Future对象回调别的函数示例代码
2017/09/07 Python
python ---lambda匿名函数介绍
2019/03/13 Python
Python Django框架实现应用添加logging日志操作示例
2019/05/17 Python
HTML5实现分享到微信好友朋友圈QQ好友QQ空间微博二维码功能
2018/01/03 HTML / CSS
物流仓储实习自我鉴定
2013/09/25 职场文书
会计自我鉴定范文
2013/10/06 职场文书
大学校庆邀请函
2014/01/11 职场文书
教师绩效考核方案
2014/01/21 职场文书
会计电算化学生个人的自我评价
2014/02/08 职场文书
行政助理工作职责范本
2014/03/04 职场文书
中学生国旗下讲话稿
2014/04/26 职场文书
技能比武方案
2014/05/21 职场文书
会计试用期自我评价
2014/09/19 职场文书
社区六一儿童节活动总结
2015/02/11 职场文书
消防安全月活动总结
2015/05/08 职场文书
教师继续教育反思周记
2015/06/25 职场文书
2015年董事长秘书工作总结
2015/07/23 职场文书
2015年全民创业工作总结
2015/07/23 职场文书
2016年中学法制宣传日活动总结
2016/04/01 职场文书
Oracle设置DB、监听和EM开机启动的方法
2021/04/25 Oracle
vue组件vue-esign实现电子签名
2022/04/21 Vue.js