AngularJS之ng-options指令

1.基本下拉效果(lable for value in array)

  其中select标签中的ng-model属性必须有,其值为选中的对象或属性值。

  

    <div ng-controller="ngselect">
        <p>usage:label for value in array</p>
        <p>选项,{{selected}}</p>
        <select ng-model="selected" ng-options="o.id for o in optData">
            <option value="">-- 请选择 --</option>
        </select>
    </div>
    m1.controller("ngselect",[‘$scope‘,function($sc){
        $sc.selected = ‘‘;
        $sc.optData = [{
            id: 10001,
            MainCategory: ‘男‘,
            ProductName: ‘水洗T恤‘,
            ProductColor: ‘白‘
        },{
            id: 10002,
            MainCategory: ‘女‘,
            ProductName: ‘圓領短袖‘,
            ProductColor: ‘黃‘
        },{
            id: 10003,
            MainCategory: ‘女‘,
            ProductName: ‘圓領短袖‘,
            ProductColor: ‘黃‘
        }];
    }]);

2.自定义下拉显示名称(label for value in array)

label可以根据需要拼接出不同的字符串

  

    <div ng-controller="ngselect2">
        <p>usage:label for value in array(label可以根据需求拼接出不同的字符串)</p>
        <p>选项,{{selected}}</p>
        <select ng-model="selected" ng-options="(o.ProductColor+‘-‘+o.ProductName) for o in optData">
            <option value="">-- 请选择 --</option>
        </select>
    </div>
    m1.controller("ngselect2",[‘$scope‘,function($sc){
        $sc.selected = ‘‘;
        $sc.optData = [{
            id: 10001,
            MainCategory: ‘男‘,
            ProductName: ‘水洗T恤‘,
            ProductColor: ‘白‘
        },{
            id: 10002,
            MainCategory: ‘女‘,
            ProductName: ‘圓領短袖‘,
            ProductColor: ‘黃‘
        },{
            id: 10003,
            MainCategory: ‘女‘,
            ProductName: ‘圓領短袖‘,
            ProductColor: ‘黃‘
        }];
    }]);

3.ng-options 选项分组

group by分组项

  

    <div ng-controller="ngselect3">
        <p>usage:label group by groupName for value in array</p>
        <p>选项,{{selected}}</p>
        <select ng-model="selected" ng-options="(o.ProductColor+‘-‘+o.ProductName) group by o.MainCategory for o in optData">
            <option value="">-- 请选择 --</option>
        </select>
    </div>
    m1.controller("ngselect3",[‘$scope‘,function($sc){
        $sc.selected = ‘‘;
        $sc.optData = [{
            id: 10001,
            MainCategory: ‘男‘,
            ProductName: ‘水洗T恤‘,
            ProductColor: ‘白‘
        },{
            id: 10002,
            MainCategory: ‘女‘,
            ProductName: ‘圓領长袖‘,
            ProductColor: ‘黃‘
        },{
            id: 10003,
            MainCategory: ‘女‘,
            ProductName: ‘圓領短袖‘,
            ProductColor: ‘黃‘
        }];
    }]);

4.ng-options 自定义ngModel的绑定

下面selected的值为optData的id 效果 http://sandbox.runjs.cn/show/nhi8ubrb

  

    <div ng-controller="ngselect4">
        <p>usage:select as label for value in array</p>
        <p>选项,{{selected}}</p>
        <select ng-model="selected" ng-options="o.id as o.ProductName for o in optData">
            <option value="">-- 请选择 --</option>
        </select>
    </div>
    m1.controller("ngselect4",[‘$scope‘,function($sc){
        $sc.selected = ‘‘;
        $sc.optData = [{
            id: 10001,
            MainCategory: ‘男‘,
            ProductName: ‘水洗T恤‘,
            ProductColor: ‘白‘
        },{
            id: 10002,
            MainCategory: ‘女‘,
            ProductName: ‘圓領长袖‘,
            ProductColor: ‘黃‘
        },{
            id: 10003,
            MainCategory: ‘女‘,
            ProductName: ‘圓領短袖‘,
            ProductColor: ‘黃‘
        }];
    }]);

效果:http://runjs.cn/detail/nhi8ubrb

时间: 2024-08-29 08:41:23

AngularJS之ng-options指令的相关文章

转走进AngularJs(八) ng的路由机制

走进AngularJs(八) ng的路由机制 2013-12-19 我来说两句 收藏 我要投稿 今天心情不错~,公司请了个中医来给按摩拔罐刮痧,一套下来那个爽啊~,趁着精力充沛了解了下Angular的路由机制,在此分享出来与大家共同学习. 在谈路由机制前有必要先提一下现在比较流行的单页面应用,就是所谓的single page APP.为了实现无刷新的视图切换,我们通常会用ajax请求从后台取数据,然后套上HTML模板渲染在页面上,然而ajax的一个致命缺点就是导致浏览器后退按钮失效,尽管我们可以

AngularJS:directive自定义的指令

除了 AngularJS 内置的指令外,我们还可以创建自定义指令. 你可以使用 .directive 函数来添加自定义的指令. 要调用自定义指令,HTML 元素上需要添加自定义指令名. 使用驼峰法来命名一个指令, runoobDirective, 但在使用它时需要以 - 分割, runoob-directive: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <script

angularjs入门学习【指令篇】

一.首先我们来了解下指令API 属性 含义 restrict 申明标识符在模版中作为元素,属性,类,注释或组合,如何使用 priority 设置模版中相对于其他标识符的执行顺序 Template 指定一个字符串式的内嵌模版,如果你指定了模版是一个URL,那么是不会使用的 tempateUrl 指定URL加载的模版,如果你已经指定了内嵌的模版字符串,那么它不会使用的 Replace 如果为真,替换当前元素,如果是假或未指定,拼接到当前元素 Transclude 移动一个标识符的原始字节带你到一个新

angularjs学习笔记—事件指令

angularjs学习笔记—事件指令 小俞 4.4k 3月30日 发布 推荐 4 推荐 收藏 17 收藏,11.1k 浏览 ngClick 适用标签:所有触发条件:单击 #html <div ng-controller="LearnCtrl"> <div ng-click="click()">click me</div> <button ng-click="click()">click me<

**Apache Options指令详解

http://www.365mini.com/page/apache-options-directive.htm Options指令是Apache配置文件中一个比较常见也比较重要的指令,Options指令可以在Apache服务器核心配置(server config).虚拟主机配置(virtual host).特定目录配置(directory)以及.htaccess文件中使用.Options指令的主要作用是控制特定目录将启用哪些服务器特性. Options指令常见的配置示例代码如下: <Direc

走进AngularJs(二) ng模板中常用指令的使用方式

通过使用模板,我们可以把model和controller中的数据组装起来呈现给浏览器,还可以通过数据绑定,实时更新视图,让我们的页面变成动态的.ng的模板真是让我爱不释手.学习ng道路还很漫长,从模板开始入手是个不错方式,因为这部分内容相对简单好理解,而且是视图层的东西,大家都喜欢可以立马看得见的东西嘛.本篇我将搜罗模板中的常用指令一一测试,了解其使用方法,有点像背单词的感觉,会比较枯燥.不过对于初学,这样的枯燥是必须要经历的,开始~ 一.模板中可使用的东西及表达式 模板中可以使用的东西包括以下

走进AngularJs(八) ng的路由机制

在谈路由机制前有必要先提一下现在比较流行的单页面应用,就是所谓的single page APP.为了实现无刷新的视图切换,我们通常会用ajax请求从后台取数据,然后套上HTML模板渲染在页面上,然而ajax的一个致命缺点就是导致浏览器后退按钮失效,尽管我们可以在页面上放一个大大的返回按钮,让用户点击返回来导航,但总是无法避免用户习惯性的点后退.解决此问题的一个方法是使用hash,监听hashchange事件来进行视图切换,另一个方法是用HTML5的history API,通过pushState(

Angularjs编写KindEditor,UEidtor指令

目前angularJS非常火热,本人也在项目中逐渐使用该技术,在angularJS中,指令可以说是当中非常重要的一部分,这里分享一些自己编写的指令: 注:本人项目中用了oclazyload进行部分JS文件加载 1.KindEditor angular.module('AdminApp').directive('uiKindeditor', ['uiLoad', function (uiLoad) { return { restrict: 'EA', require: '?ngModel', li

AngularJS开发之_指令

指令是什么?    指令是我们用来扩展浏览器能力的技术之一.在DOM编译期间,和HTML关联着的指令会被检测到,并且被执行.这使得指令可以为DOM指定行为,或者改变它. 1.指令的匹配模式 index.html : 1 <!doctype html> 2 <html ng-app="MyModule"> 3 <head> 4 <meta charset="utf-8"> 5 </head> 6 <bo

AngularJS(五)——指令

一.自定义指令: zhiling.html <span style="font-size:18px;"><!doctype html> <html ng-app="myApp"> <head> <script src="js/angular-1.3.0.js"></script> <script src="zhiling.js"></sc