Angular基础开始
这个我是想用Angular写一个简单的WebApp,这个是一个简简单单路由:
公共模板--index.html:
<!DOCTYPE html>
<html ng-app='myApp'>
<head>
<meta charset="utf-8">
<meta name="viewport" content="initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
<title>首页</title>
<link rel="stylesheet" href="css/app.css" media="all" />
<script src="js/angular.js"></script>
<script src="js/angular-route.js" type="text/javascript" charset="utf-8"></script>
<script src="js/app.js"></script>
<script src="js/controller/controller.js" type="text/javascript" charset="utf-8"></script>
</head>
<body>
<header>松鼠闹IT</header>
<div ng-view class="container"></div>
<footer>
<a href='#/'>首页</a>
<a href='#/list'>列表</a>
<a href="#/detail">详情</a>
<a href="#/demo">演示</a>
</footer>
</body>
</html>
CSS
html,body,h1,h2,h3,h4,h5,h6,ul,dd{padding: 0;margin: 0;}
html{font-size: 62.6%;}
html,body{height: 100%;}
a{text-decoration: none;}
header,footer{box-sizing:border-box;z-index: 9999;}
header{font-size: 2.0rem;text-align: center;border-bottom: 1px solid #ccc;padding: 15px 0;position: absolute;top: 0;left: 0;width: 100%;}
footer{position: absolute;width: 100%;bottom: 0;left: 0;display: -webkit-box;font-size: 1.4rem;border-top: 1px solid #ccc;}
footer a{display: block;-webkit-box-flex: 1;text-align: center;padding: 20px 0;border-right: 1px solid #ccc;}
footer a:last-of-type{border-right: none;} .container{position: absolute;top:54px;left: 0;bottom: 57px;width: 100%;overflow-y: auto;}
路由:
var myApp = angular.module('myApp',['ngRoute']);
myApp.config(function($routeProvider){
$routeProvider.
when('/',{controller:indexController,templateUrl:'views/index.html'}).
when("/list",{controller:listController,templateUrl:'views/list.html'}).
when("/detail/:id",{controller:detailController,templateUrl:'views/detail.html'}).
when("/demo",{controller:demoController,templateUrl:"views/demoList.html"})
});
控制器:
var cityCode = [{"province":"北京","city":[{"cityName":"北京","code":"101010100"},{"cityName":"朝阳","code":"101010300"},{"cityName":"顺义","code":"101010400"},{"cityName":"怀柔","code":"101010500"},{"cityName":"通州","code":"101010600"},{"cityName":"昌平","code":"101010700"},{"cityName":"延庆","code":"101010800"},{"cityName":"丰台","code":"101010900"},{"cityName":"石景山","code":"101011000"},{"cityName":"大兴","code":"101011100"},{"cityName":"房山","code":"101011200"},{"cityName":"密云","code":"101011300"},{"cityName":"门头沟","code":"101011400"},{"cityName":"平谷","code":"101011500"},{"cityName":"八达岭","code":"101011600"},{"cityName":"佛爷顶","code":"101011700"},{"cityName":"汤河口","code":"101011800"},{"cityName":"密云上甸子","code":"101011900"},{"cityName":"斋堂","code":"101012000"},{"cityName":"霞云岭","code":"101012100"},{"cityName":"北京城区","code":"101012200"},{"cityName":"海淀","code":"101010200"}]}]; function indexController($scope){
var user = {
name:"松鼠闹IT",
age : 24
}
$scope.user = user;
} function listController($scope){
$scope.cityCode = cityCode;
} function detailController($scope,$routeParams,$http){
$scope.show=true;
$http({
url:'http://api.36wu.com/Weather/GetWeather?district='+$routeParams.id+'&authkey=eb1983f443d94a78a7925222873a7722',
method:'get',
dataType:'json'
}).success(function(data){
var status = parseInt(data.status,10);
if(status === 200){
$scope.detail = data.data;
$scope.show=false;
}
}).error(function(data){
console.log("从无");
});
} var demos = [
{title:'translation-transform'},
{title:'1'},
]; function demoController($scope){
$scope.demos = demos;
}
上面的代码如果复制出来的话,啥都不显示,需要你创建一个views文件夹,里面存放“index.html”、“list.html”、“detail.html”、“demo.html”四个页面,四个页面对应的就是底部的四个链接,这四个页面也是四个不同的内容。
说说基本步骤:
1、加载angular.js
2、在模板的html标签里面加上"ng-app",也可以这样写"ng-app='myApp'"后面的属性值随便写,但是如果写了,就必须在下面这样定义一遍
<script>
var myApp = angular.module("myApp",[]);
</script>
如果不定义的话,就会报错,如果没有属性值,就不需要定义了
3、创建控制器
控制器的单词就是:controller,所以看到这个单词就表示我们看到了控制器。控制器有两种创建方式:
第一种:
<script>
var data = {titie:"松鼠闹IT"};
function myAppController($scope){
$scope.data = data;
}
</script>
<script>
var data = {titie:"松鼠闹IT"};
myApp.controller("myAppController",function($scope){
$scope.data = data;
});
</script>
控制器控制的是哪里呢?
<div ng-controller="myAppController">
<h1>{{data.title}}<h1>
</div>
在一对闭合的标签中加上“ng-controller=’myAppController‘”,在这对闭合标签中的内容以及子元素就受这个控制器管理了。在上面,我们看到了一个很有趣的东西{{data.title}},恩,看上去很屌的样子,其实一眼我们也可以看出来是啥意思,就是获取data.title的值,那这个值从哪里来呢?这里我们就要简单说说Angular中的另外一个特性:依赖注入,其实我也不懂这个概念
在“myAppController”控制器中,我们看到function中有一个参数$scope,这个参数是干啥的呢?就是来进行数据绑定的。上面"$scope.data = data;"就是将上面的data对象赋值给$scope上的data属性,当然这个data属性是我们自定义的。然后在angular会在模板中找到定义了"myAppController"的闭合标签,在这对闭合标签中产生一个上下文,在这个上下文中,获取到的就是data属性,我们就可以获取到data.title的值了。这一段写的有点扯
Angular基础开始的更多相关文章
- 第214天:Angular 基础概念
一.Angular 简介 1. 什么是 AngularJS - 一款非常优秀的前端高级 JS 框架 - 最早由 Misko Hevery 等人创建 - 2009 年被 Google 公式收购,用于其多 ...
- Angular基础---->AngularJS的使用(一)
AngularJS主要用于构建单页面的Web应用.它通过增加开发人员和常见Web应用开发任务之间的抽象级别,使构建交互式的现代Web应用变得更加简单.今天,我们就开始Angular环境的搭建和第一个实 ...
- angular 基础练习
<!DOCTYPE HTML> <html> <head> <title> 测试页 </title> <meta charset=&q ...
- Angular基础(三) TypeScript
一.模仿Reddit a) 运行ng new –ng4angular-reddit创建应用,从随书代码中复制样式文件,新建组件app-root,代码为: 界面可以看到了: b) 对于界面输入的数据,获 ...
- Angular基础(二) 组件的使用
一.简单操作 a) 使用Angular CLI可以快速创建项目框架,先运行 $ npm install –g @angular/cli@1.0.0安装CLI,为CLI的位置设置环境变量,然后就可以 ...
- angular基础入门
第一章 AngularJs入门 AngularJS是一款由Google公司开发维护的前端框架,其克服了HTML在构建应用上的诸多不足,从而降低了开发成本提升了开发效率. 1 特点 AngularJS与 ...
- Angular 基础入门
简介 什么是AngularJS 一个功能非常完备的前端框架,通过增强HTML的方式提供一种便捷开发Web应用程序的方式 其核心特点就是几乎无任何DOM操作,让开发人员的精力和时间全部集中于业务 MVC ...
- Angular基础教程:表达式日期格式化[转]
本地化日期格式化: ({{ today | date:'medium' }})Nov 24, 2015 2:19:24 PM ({{ today | date:'short' }})11/24/15 ...
- Angular基础知识
AngularJS 是一个 JavaScript 框架.它可通过 <script> 标签添加到 HTML 页面. AngularJS 通过 ng-directives 扩展了 HTML. ...
- Angular基础(二)
双向数据 利用angular把input框里面的值和h3的值绑定在一起.在input里输入内容,内容会在h3标签里显示出来. 具体效果请看下面代码: <!DOCTYPE html> ...
随机推荐
- Grunt-学习。
Grunt 依赖 Node.js 所以在安装之前确保你安装了 Node.js.然后开始安装 Grunt 实际上,安装的并不是 Grunt,而是 Grunt-cli,也就是命令行的 Grunt,这样你就 ...
- Linux 挂载
千万不要挂载到 根目录下 也不要用 umount -fl 会死的 fdisk -l 看 能挂载的是哪个盘 格式化 mkfs.ext4 /dev/vde 创建一个文件 mkdir /testmnt 卸 ...
- ORAchk-数据库健康检查好帮手
ORAchk 之前被称为RACcheck,后来它的检查范围进行了扩展,改名为了ORAchk,它是在数据库系统进行健康检查的一个专用工具,这个工具主要用来检查软件的配置是否符合要求以及一些最佳实践是否被 ...
- CSS学习摘要-定位
CSS学习摘要-定位 注:全文摘自MDN-CSS定位 定位允许您从正常的文档流布局中取出元素,并使它们具有不同的行为,例如放在另一个元素的上面,或者始终保持在浏览器视窗内的同一位置. 本文解释的是定位 ...
- APP分析之海豚睡眠
APP分析之海豚睡眠 产品:海豚睡眠 引文 由于笔者暑假经常晚睡,导致在习惯性失眠.长时间睡眠不足,导致头脑反应迟钝,还整日无精打采,不知所措.一个偶然的机会,在一个燥热的夜晚,眼看又是一个不眠之夜, ...
- JDK/bin目录下的不同exe文件的用途
新安装完JDk 大家是否发现安装目录的bin文件夹有很多exe文件 下面就为大家讲解不同exe文件的用途 javac:Java编译器,将Java源代码换成字节代 java:Java解释器,直接从类文件 ...
- Django之Model (ORM)
传统操作数据库 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去调用数据访问层 ...
- iOS: 聊聊 Designated Initializer(指定初始化函数):NS_DESIGNATED_INITIALIZER
总结:指定函数的调用规则: 初始化函数的调用顺序与初始化顺序相反. 上面关于指定初始化的规则讲了那么多,其实可以归纳为两点: 便利初始化函数只能调用自己类中的其他初始化方法 指定初始化函数才有资格调用 ...
- Day16 IO流
流的概念和作用 流是一组有顺序的,有起点和终点的字节集合,是对数据传输的总称或抽象.即数据在两设备间的传输称为流,流的本质是数据传输,根据数据传输特性将流抽象为各种类,方便更直观的进行数据操作. Ja ...
- Sequelize-nodejs-10-Hooks
Hooks钩子 Hooks (also known as lifecycle events), are functions which are called before and after call ...