AngularJS Select(选择框)
AngularJS 可以使用数组或对象创建一个下拉列表选项。
使用 ng-options 创建选择框
在 AngularJS 中我们可以使用 ng-option 指令来创建一个下拉列表,列表项通过对象和数组循环输出,如下实例:
实例
<!DOCTYPE html><html><head><meta charset="utf-8"><script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script></head><body><div ng-app="myApp" ng-controller="myCtrl"><select ng-model="selectedName" ng-options="x for x in names"></select></div><script>var app = angular.module('myApp', []);app.controller('myCtrl', function($scope) { $scope.names = ["Google", "Runoob", "Taobao"];});</script><p>该实例演示了 ng-options 指令的使用。</p></body></html>运行结果:
GoogleRunoobTaobao该实例演示了 ng-options 指令的使用。
ng-options 与 ng-repeat
我们也可以使用ng-repeat 指令来创建下拉列表:
实例
<!DOCTYPE html><html><head><meta charset="utf-8"><script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script></head><body><div ng-app="myApp" ng-controller="myCtrl"><select><option ng-repeat="x in names">{{x}}</option></select></div><script>var app = angular.module('myApp', []);app.controller('myCtrl', function($scope) { $scope.names = ["Google", "Runoob", "Taobao"];});</script><p>该实例演示了使用 ng-repeat 指令来创建下拉列表。</p></body></html>运行结果:
GoogleRunoobTaobao该实例演示了使用 ng-repeat 指令来创建下拉列表。
ng-repeat 指令是通过数组来循环 HTML 代码来创建下拉列表,但 ng-options 指令更适合创建下拉列表,它有以下优势:
使用 ng-options 的选项的一个对象, ng-repeat 是一个字符串。
应该用哪个更好?
假设我们使用以下对象:
$scope.sites = [ {site : "Google", url : "http:///libs/angular.js/1.4.6/angular.min.js"></script></head><body><div ng-app="myApp" ng-controller="myCtrl"><p>选择一辆车:</p><select ng-model="selectedCar" ng-options="y.brand for (x, y) in cars"></select><p>你选择的是: {{selectedCar.brand}}</p><p>型号为: {{selectedCar.model}}</p><p>颜色为: {{selectedCar.color}}</p><p>下拉列表中的选项也可以是对象的属性。</p></div><script>var app = angular.module('myApp', []);app.controller('myCtrl', function($scope) { $scope.cars = { car01 : {brand : "Ford", model : "Mustang", color : "red"}, car02 : {brand : "Fiat", model : "500", color : "white"}, car03 : {brand : "Volvo", model : "XC90", color : "black"} }});</script></body></html>运行结果:
选择一辆车:
FordFiatVolvo
你选择的是: Ford
型号为:Mustang
颜色为: red
下拉列表中的选项也可以是对象的属性。
以上就是对AngularJS Select资料的整理,后续继续补充,希望能帮助有需要的朋友。