前端学习(三十七)angular(笔记)
MVC 后台
M Module 数据层
V View 视图层
C Controller 控制层
前端开始用MVC
M 数据层 交互
V 视图层 DOM操作
C 控制层 逻辑
===================================================
不用原生写MVC
1.不是所有人都懂MVC,用人需求变高。
2.风格不统一
===================================================
库和框架的区别?
库 辅助程序员开发 JQuery
框架 限制程序员开发 Angular
===================================================
AngularJS
MVVM的框架
Angular火。有人在推,Google
用的人少了,自己作。更新。
主版本.次版本.修订号
1.2.x
玩法直接变了
1.3.x
javascript
2.x
TypeScript
本质还是MVC,只不过衍生出很多叫法
MVC
MVVM
MVP
MV*
=====================================================
面向过程
面向对象
面向数据
致力于解决所有交互所带来的痛苦。
只需要关心数据就行。
=======================================================
官网:https://angularjs.org/
下载:https://code.angularjs.org/
文档:https://code.angularjs.org/1.5.8/docs/api
=======================================================
Function Angular提供的方法
angular.bind 矫正this
angular.bootstrap 开启angular应用
angular.copy 复制对象
angular.element 小jquery
angular.equals 比较是否相等
angular.forEach 迭代
angular.fromJson
angular.isArray 检测是否是数组
angular.module angular模块
===================================================
玩的就是数据——数据就是一切
ng-app 哪是angular管的
一个页面只能加一个
ng-model 数据源
ng-bind 数据绑定
ng-bind平时用的少。
用:{{}}
angular的核心:
依赖注入、双向绑定
===================================================
Directive 指令
ng-app
ng-model
ng-bind
ng-init 初始化
ng-click 点击
ng-repeat 迭代
{{$index}} 索引
{{$first}} 是否是第一行
{{$last}} 是否是最后一样
{{$even}} 是否是奇数行
{{$odd}} 是否是偶数行
数组有重复会有问题:
原因:默认把值当成索引了。
解决:
ng-repeat="item in arr track by $index"
ng-show 显示
ng-hide 隐藏
ng-if 如果是真的就显示,否则就已隐藏
ng-controller 控制器
环境:
原生环境
NG环境
================================================
Controller 控制器
let app = angular.module('名字',[依赖]);
app.controller('控制名字',($scope)=>{
$scope 当前控制器的域
});
==================================================
Filter 过滤器
{{item.price|currency}}
currency 货币
{{item.price|currency:'¥'}}
date 日期
filter 过滤器
limitTo 限制数量
number 1004354548
================================================
Angular的问题
数据变了,但是DOM没有渲染
解决:
脏检查
==============================================
Service 服务
$interval 定时器
$timeout 定时器
==============================================
交互
$http服务
GET
$http.get('url',{
params:{
参数
}
}).then((res)=>{
res.data 数据
},(err)=>{
});
POST
$http({
method:'POST',
url:'',
data:{
参数
},
headers:{
'Content-Type':'application/x-www-form-urlencoded'
},
transformRequest:function(data){
var arr = [];
for(var key in data){
arr.push(key+'='+data[key]);
}
return arr.join('&');
}
}).then((res)=>{
res.data 数据
},(err)=>{
});
---------------------------------------------------
Angular
优势是做SPA
spa 单页应用
==================================================
controller 通信
父子级通信
子级给父级发送数据
发送
$scope.$emit('名字',值);
父级给子级发送数据
发送
$scope.$broadcast('名字',值);
接收
$scope.$on('名字',function(ev,data){
data
});
===============================================
jsonp
https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su
================================================
filter 过滤器
自定义过滤器
app.filter('过滤器名字',function(){
return function(input){
操作input的值。
return 值;
};
});
capitalizes 首字母大写
getCnDay 获取中文星期
trim 去除首尾空格
==================================================
自定义指令
directive
app.directive('名字',function(){
return {
link:function(scope,ele,attr){
}
};
});
===================================================
深入Controller
传统写法不能压缩,因为angular核心是依赖注入
app.controller('main',['$scope','$http',function(scope,http){
}]);
controller的另一种写法
var app = angular.module('app',[],function($controllerProvider){
$controllerProvider.register('控制器名字',function($scope){
});
});
filter的另一种写法
var app = angular.module('app',[],function($controllerProvider,$filterProvider){
$filterProvider.register('名字',function(){
return function(input,param){
};
});
$controllerProvider.register('控制器名字',function($scope){
});
});
directive另一种写法
var app = angular.module('app',[],function($controllerProvider,$filterProvider,$compileProvider){
$compileProvider.directive('名字',function(){
return {
link(scope,ele,attr){
}
};
});
$filterProvider.register('名字',function(){
return function(input,param){
};
});
$controllerProvider.register('控制器名字',function($scope){
});
});
==============================================
前端学习(三十七)angular(笔记)的更多相关文章
- 前端学习:JS(面向对象)代码笔记
前端学习:JS(面向对象)代码笔记 前端学习:JS面向对象知识学习(图解) 创建类和对象 创建对象方式1调用Object函数 <body> </body> <script ...
- 前端学习(十七):JavaScript常用对象
进击のpython ***** 前端学习--JavaScript常用对象 JavaScript中的所有事物都是对象:字符串.数字.数组.日期,等等 在JavaScript中,对象是拥有属性和方法的数据 ...
- Java开发学习(三十七)----SpringBoot多环境配置及配置文件分类
一.多环境配置 在工作中,对于开发环境.测试环境.生产环境的配置肯定都不相同,比如我们开发阶段会在自己的电脑上安装 mysql ,连接自己电脑上的 mysql 即可,但是项目开发完毕后要上线就需要该配 ...
- 前端学习(三十八)vue(笔记)
Angular+Vue+React Vue性能最好,Vue最轻=======================================================Angular ...
- 前端学习(三十六)promise(笔记)
一个页面: 头部.用户信息.新闻列表 jquery ajax: 1.$.ajax({ url:'', dataType:'json', }).then(res=>{ //r ...
- 前端学习(三十九)移动端app(笔记)
移动端App 开发App的三种方式 Native App 原生 底层语言 java Android oc ...
- 前端学习(三十五)模块化es6(笔记)
RequireJs:一.安装.下载 官网: requirejs.org Npm: npm i requirejs二.使用 以前的开发方式的问题: 1).js 是阻塞加 ...
- 前端学习(三十四)对象&模块化(笔记)
人,工人 //类的定义 function Person(name,age){ //构造函数 //工厂模式 //1.原料 //var obj = new ...
- 前端学习(三)css选择器(笔记)
字体样式: color:red: font-size:12px: font-weight:bold/normal; font-style:italic/normal; f ...
随机推荐
- LeetCode--052--N皇后II(java)
n 皇后问题研究的是如何将 n 个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击. 上图为 8 皇后问题的一种解法. 给定一个整数 n,返回 n 皇后不同的解决方案的数量. 示例: 输入 ...
- Redis之数据类型
一.概念: Redis:一个开源.支持网络.基于内存.键值对存储数据库. 特点:它可以支持多种数据类型. 二.数据类型 1)Redis String 具体说明: 一般的普通的k到v一个映射是Strin ...
- 【2019 Multi-University Training Contest 7】
01:https://www.cnblogs.com/myx12345/p/11653845.html 02: 03: 04: 05: 06:https://www.cnblogs.com/myx12 ...
- CSU 1548 Design road(三分查找)
题目链接:https://cn.vjudge.net/problem/142542/origin Description You need to design road from (0, 0) to ...
- ''.startswith() and ''.endswith() instead of string slicing to check for prefixes or suffixes.
w http://legacy.python.org/dev/peps/pep-0008/ Yes: if foo.startswith('bar'):No: if foo[:3] == 'bar' ...
- Chrome开发小技巧--浏览器控制台现写并运行js代码--snippets
想简单等运行一段js代码,以前可能会新建一个html 里面包含script标签,或者引入一个js,然后chrome浏览器打开.这样很麻烦. 想再console控制台写,也不方便,换行处理麻烦. 基于在 ...
- 测开之路六十一:接口测试平台之interface蓝图
create的js //添加header的函数function add_header() { // 这里是动态拼接html语句,带着样式,拼凑成页面的 "key [] value []&qu ...
- Vagrant 手册之 Provisioning - Shell 配置程序
原文地址 Provisioner 命令:"shell" 示例: node.vm.provision "shell" do |s| s.inline = < ...
- 手撸红黑树-Red-Black Tree 入门
一.学习红黑树前的准备: 熟悉基础数据结构 了解二叉树概念 二.红黑树的规则和规则分析: 根节点是黑色的 所有叶子节点(Null)是黑色的,一般会认定节点下空节点全部为黑色 如果节点为红色,那么子节点 ...
- POJ - 3176 Cow Bowling 动态规划
动态规划:多阶段决策问题,每步求解的问题是后面阶段问题求解的子问题,每步决策将依赖于以前步骤的决策结果.(可以用于组合优化问题) 优化原则:一个最优决策序列的任何子序列本身一定是相当于子序列初始和结束 ...