Angularjs基础(五)
AngularJS Select(选项框) AngularJS 可是使用数组或对象创建一个下拉列表选项。 使用ng-options创建选项框 在AngularJS 中我们可以使用ng-option指令来创建一个下拉列表,列表通过对象和数组循环输出 实例:
<div ng-app="myApp" ng-controller="myCtrl">
<select ng-model="selectedName" ng-options="x for in names"></select>
</div>
<script>
var app = angular.module('myApp',[]);
app.controller('myCtrl',function($scope){
$scope.name = ["Google","Runoob","Taobao"];
})
</script>
ng-options 与 ng-repeat 我们也可以使用ng-repeat指令来创建下拉列表 <select> <option ng-repeat="x in name">{{x}}</option> </select> ng-repeat指令是通过数组来循环HTML 代码来创建下拉列表,但ng-options指令更适合创建下拉列表,它有一下优势 使用ng-options的选项的一个对象,ng-repeat是一个字符串。
应该用那个更好? 假设我们使用以下对象: $scope.sites = [{site : "Google",url:"http://www.google.com"}, $scope.sites = [{site : "Runoob",url:"http://www.runoob.com"}, $scope.sites = [{site : "Taobao",url:"http://www.runoob.com"}] ng-repeat有局限性,选择的值是一个字符串: 实例:
<select ng-model="selectedSite">
<option ng-repeat="x in sites" value="{{x,url}}">{{x.site}}</option>
</select>
<h1>你选择的是:{{selectedSite}}</h1>
实例: 使用ng-options: <select ng-model="selectedSite" ng-options="x.site for x in sites"></select> <h1>你选择的是:{{selectedSite.site}}</h1> <p>网址为:{{selectedSite.url}}</p> 当选择值是一个对象时,我们就可以获取更多信息,应用也更灵活。
数据源为对象 前面实例我们使用了数组作为数据源,以下我们将数据对象作为数据源。
$scope.sites = {
site01 :"Google",
site02:"Runoob",
site03 :"Taobao"
};
实例 使用对象作为数据源,x 为键(key),y为值(value); <select ng-model="selectedSite" ng-options="x for (x,y) in sites"> </select> <h1>你选择的值是:{{selectedSite}}</h1> 你选择的值在key-value对中的value value 在key-value 对中也可以是个对象; 实例 选择的值在key-value 对的value 中,这是 它是一个对象。
$scope.cars = {
car01 : {brand : "Ford",model :"Mustang", color :"red"},
car02 : {brand : "Fiat",model :"500", color :"white"},
car03 : {brand : "Fiat",model :"XC90", color :"black"},
}
在下拉菜单也可以不使用 key-value 对中的 key , 直接使用对象的属性: <select ng-model="selectedCar" ng-options="y.brand for (x,y) in sites "></select>
AngularJS 表格 ng-repeat 指令可以完美的显示表格。
在表格中显示数据 使用angular显示表格是非常简单的 实例
<div ng-myApp="myApp" ng-controller="customersCtrl">
<table>
<tr ng-repeat = "x in names">
<td>{{x.Name}}</td>
<td>{{x.Country}}</td>
</tr>
</table>
</div>
<script>
var app= angular.module('myApp',[]);
app.controller('customersCtrl',function($scope,$http){
$http.get("http://www.runoob.com/try/angularjs/data/Customers_JSON.php").
success(function (response) {$scope.names = response.records;});
})
</script>
使用CSS样式 为了让页面更加美观,我们可以在页面中使用CSS css 样式
<style>
table, th ,td{
border:1px solid grey;
border-collapse:collapse;
padding:5px;
}
table tr:nth-child(odd){
background-color:#f1f1f1;
}
table tr:nath-child(even){
background-color:#ffffff;
}
</style>
使用 orderBy 过滤器 排序显示,可以使用orderBy过滤器: 实例:
<table>
<tr ng-repeat="x in names | orderBy : 'Country'">
<td>{{x.Name}}</td>
<td>{{x.Country}}</td>
</tr>
</table>
使用uppercase 过滤器 使用uppercase过滤器转换为大写 实例
<table>
<tr ng-repeat="x in names">
<td>{{x.Name}}</td>
<td>{{x.Country | uppercase}}</td>
</tr>
</table>
显示序号($index) 表格显示序号可以在<td>中添加$index: 实例
<table>
<tr ng-repeat="x in names">
<td>{{$index + 1}}</td>
<td>{{x.Name}}</td>
<td>{{x.Country}}</td>
</tr>
</table>
使用$even 和$odd 实例
<table>
<tr ng-repeat="x in names">
<td ng-if="$odd" style="background-color:#f1f1f1">{{x.Name}}</td>
<td ng-if="$even">{{x.Name}}</td>
<td ng-if="$odd" style="background-color:#f1f1f1">{{x.Country}}</td>
<td ng-if="$even">{{x.Country}}</td>
</tr>
</table>
AngularJS SQL 使用PHP从MySQL 中获取数据 实例:
<div ng-app ="myApp" ng-controller="customersCtrl">
<table>
<tr ng-repeat="x in names">
<td>{{x.Name}}</td>
<td>{{x.Country}}</td>
</tr>
</table>
</div>
<script>
var app = angular.module('myApp',[]);
app.controller('customersCtrl',function($scope,$http){
$http.get("http://www.runoob.com/try/angularjs/data/Customers_MySQL.php")
.success(function (response) {$scope.names = response.records;});
})
</script>
跨域HTTP请求 如果你需要从不同的服务器(不同的域名)上获取数据就需要使用跨域HTTP请求。 跨域请求在网页上非常常见。很多网页从不同服务器上载入CSS,图片,Js 脚本等。 在现代浏览器中,为了数据的安全,所又请求被严格限制在同一域名下,如果需要调用不同站点数据,需要通过跨域来解决。 以下的PHP代码运行使用的网站进行跨域访问。 header("Access-Control-Allow-Origin: *");
- DP较为完整的知识
- HDUOJ----The Number Off of FFF
- HDUOJ-------Naive and Silly Muggles
- HDUOJ----A Computer Graphics Problem
- HDUOJ---(4708)Herding
- HDUOJ---(4708)Rotation Lock Puzzle
- HDUOJ---Hamming Distance(4712)
- HDUOJ-----Difference Between Primes
- HDUOJ----(4706)Children's Day
- poj-------Common Subsequence(poj 1458)
- poj----Maximum sum(poj 2479)
- HDUOJ---hello Kiki
- HDUOJ-----X问题
- POJ-----C Looooops
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- CentOS7+apache+php7+mysql5.7配置教程详解
- 如何利用SystemTap统计函数执行耗时详解
- 关于安装linux redhat后无法使用yum命令安装gcc-c++问题的解决过程
- 基于代码的自动化和无代码自动化
- Java Stream中map和flatMap方法
- 关于Apache shiro实现一个账户同一时刻只有一个人登录(shiro 单点登录)
- 视频上云安防视频云服务平台EasyCVR通过海康sdk协议接入多路设备拉流时出现部分设备拉流不稳定是什么原因?
- Centos6.x服务器配置jdk+tomcat+mysql环境(jsp+mysql)
- Linux的压缩和解压缩的方法总结
- RTSP/GB28181/HIKSDK/Ehome协议视频融合平台EasyCVR编译C++报参见“XXX”的声明错误
- 详解 Linux 常用目录的作用
- CentOS6环境下搭建路由器的方法
- centos7下NFS使用与配置的步骤
- 基于DOM4J的XML文件解析类
- Win7安装和配置Apache2.4服务器的详细方法