angularjs 使用中的积累
来源:互联网 发布:木马编程 编辑:程序博客网 时间:2024/06/05 15:16
感觉AngularJS最大的优点
将传统的JQuery的先选择元素,再操作的方式改变成了直接对于元素本身的操作。
这依赖于强大的Html Parser的能力和directive灵活。
2. 后端MVC前端化
是的,http://ASP.net MVC, strucs的很多机制,完全可以用AngularJS替代
依赖于良好的后端restful接口的配合,完全的变成了早些年pb这样的数据集成化开发
module是angular中重要的模块组织方式,它提供了将一组内聚的业务组件(controller、service、filter、directive…)封装在一起的能力。同时module也是我们angular代码的入口,首先需要声明module,然后才能定义angular中的其他组件元素,如controller、service、filter、directive、config代码块、run代码块等。
对于angular.module方法,我们常用的方式有有种,分别为angular.module(‘com.ngbook.demo’, [可选依赖])和angular.module(‘com.ngbook.demo’)。请注意它是完全不同的方式,一个是声明创建module,而另外一个则是获取已经声明了的module。
第一章
angularjs简介:
放弃了ie8,引入了单向数据绑定
删掉了一些过时的api
2.angularjs 4大核心特性:MVC、模块化、指令系统、双向数据绑定
其他特性:依赖注入、过滤器、服务
mvc: Model数据模型层、View视图层、Controller业务逻辑和控制逻辑
mvc的好处:职责清楚,代码模块化
第四章.angularjs开发移动app
一.
1.Native APP 原生app
2.WEB APP 用js html开发用其他的打个包
3.Hybrid APP 混合式式开发 一部分用原生一部分用html的这种 如qq、酷狗音乐
纯原生 成本太大开发时间慢、更新慢;webapp操作体验性不是那么很好; Hybrid混合式开发呢则是两者中和,都还行
常用打包工具:
Phonegap、Appcan(国内)、appcelerator
常见web app框架:
jquery 技术栈统一成本低 缺点:低端安卓机存在性能问题
Sencha Touch 各项技术架构很完善 学习成本高
angularjs
第五章 前端自动化测试工具
第二章Angularjs
2.1 angulargis是怎么样实现mvc的
如何使用Control:
都是由$scope来进行的,在页面html标签中加上了ng-app来识别, <button ng-click="save()" >
2.2路由、模块、依赖注入
一些都是从模块开始的,模块化实现
一。
1.angularjs点击事件跳转【2017-3-31】
//定义一个控制器
app.controller('addPersonnelCtrl', ['$http', '$location', function ($http, $location) {
var self = this;
self.jumpToUrl = function (path) {
$location.path(path);
};
}]);
<input ng-click="ctl.jumpToUrl('/app/admin/managePersonnel')" type="button" value="查看信息" class="sp-btn-blue sp-radius" />
self.viewManagePersonnel = function () {
self.jumpToUrl('/app/admin/managePersonnel');
};
2.angularjs的 ui-sref中传递参数【2017-3-31】
例如:路由配置如下:
$stateProvider.state('admin.userList', {
url: '/listUser?id&role', //参数必须先在这边声明
templateUrl: requirejs.toUrl('../../user/user_list.html'),
})
页面中:
<a ui-sref="admin.userList({id: 1, role: 2})" class="btn">按钮</a>
在js的指令中,接收 用到了$stateParams
app.controller('retiredCtrl', ['$http', '$stateParams', function ($http, $stateParams) {
var getID = $stateParams.id; //获取到编号id
var getType = $stateParams.type; //获取到编号id
}]);
3.【2017-04-02】angularjs的ng-model与laydae一起使用 的解决办法
/**
* 使用示例
* <input def-laydate type="text" id="id1" ng-model="startTime"/>
*/
app.directive('defLaydate', function () {
return {
require: '?ngModel',
restrict: 'A',
scope: {
ngModel: '='
},
link: function (scope, element, attr, ngModel) {
var _date = null, _config = {};
// 初始化参数
_config = {
elem: '#' + attr.id,
format: attr.format != undefined && attr.format != '' ? attr.format : 'YYYY-MM-DD',
max: attr.hasOwnProperty('maxDate') ? attr.maxDate : '',
min: attr.hasOwnProperty('minDate') ? attr.minDate : '',
choose: function (data) {
scope.$apply(setViewValue);
},
clear: function () {
//ngModel.$setViewValue(null);
}
};
// 初始化
_date = laydate(_config);
// 模型值同步到视图上
//ngModel.$render = function () {
// element.val(ngModel.$viewValue || '');
//};
// 监听元素上的事件
element.on('blur keyup change', function () {
scope.$apply(setViewValue);
});
setViewValue();
// 更新模型上的视图值
function setViewValue() {
var val = element.val();
//ngModel.$setViewValue(val);
}
}
}
});
4. ng-show 判断
<a ng-show="'{{user.STATUS}}'=='未生效'" ui-sref="app.app_install({id:'{{item.ID}}',appid:{{item.APPID}}})" class="ligblue">安 装</a>
5.指令 directive
<a ui-sref="" toggle-main-menu>首页</a>
angular.module('app').directive("toggleMainMenu", function() {
return {
restrict: "A",
link: function(scope, elem, attrs) {
$(elem).click(function() {
if($(this).next().hasClass('sub-menu') === false) {
return;
}
console.log("click");
});
}
}
});
6,。
$http({
method: 'get',
url: 'json/message.txt',
data: { info: self.info }
}).success(function (response) {
//成功之后,提示 继续添加,还是查看信息
if (response.success) {
special.dialog(response.message);
} else {
special.dialog("添加失败!");
}
});
7.ng-click传参数
<a ng-click="ctl.deleteWorksheet('{{item.ID}}')" class="sp-color-red">删除</a>
var self = this;
self.deleteWorksheet = function (str) {
var getID = str;
alert(getID);
}
8.声明控制器
app.controller('myappCtrl', ['$http', function ($http) {
}]);
9.angularjs中的img
<img class="sp-upload-photo" alt="" ng-src="{{ctl.info.photo2}}" />
10.angularjs教程:
10.1. ng-app指令: 标记了AngularJS脚本的作用域,在<html>中添加ng-app属性即说明整个<html>都是AngularJS脚本作用域
10.2. 双大括号绑定的表达式: AngularJS模板的核心功能——绑定,这个绑定由双大括号{{}},这个绑定告诉AngularJS需要运算其中的表达式并将结果插入DOM中
10.3. ng-model 指令用于绑定应用程序数据到 HTML 控制器(input, select, textarea)的值。
ng-init 指令初始化应用程序数据。
10.4. AngularJS 使用$scope 对象来调用控制器。在 AngularJS 中, $scope 是一个应用对象(属于应用变量和函数)。控制器的 $scope (相当于作用域、控制范围)用来保存AngularJS Model(模型)的对象。
10.5. AngularJS 过滤器 过滤器可以使用一个管道字符(|)添加到表达式和指令中
AngularJS 过滤器可用于转换数据:
10.5.1. currency 格式化数字为货币格式。
<div ng-app="myApp" ng-controller="costCtrl">
数量: <input type="number" ng-model="quantity">
价格: <input type="number" ng-model="price">
<p>总价 = {{ (quantity * price) | currency }}</p>
</div>
<script>
var app = angular.module('myApp', []);
app.controller('costCtrl', function($scope) {
$scope.quantity = 1;
$scope.price = 9.99;
});
</script>
10.5.2. uppercase 格式化字符串为大写
<div ng-app="myApp" ng-controller="personCtrl">
<p>姓名为 {{ lastName | uppercase }}</p>
</div>
10.5.3. lowercase 格式化字符串为小写。
<div ng-app="myApp" ng-controller="personCtrl">
<p>姓名为 {{ lastName | lowercase }}</p>
</div>
10.5.4. orderBy 过滤器根据表达式排列数组:
<div ng-app="myApp" ng-controller="namesCtrl">
<ul>
<li ng-repeat="x in names | orderBy:'country'">
{{ x.name + ', ' + x.country }}
</li>
</ul>
</div>
angular.module('myApp', []).controller('namesCtrl', function($scope) {
$scope.names = [
{name:'Jani',country:'Norway'},
{name:'Hege',country:'Sweden'},
{name:'Kai',country:'Denmark'}
];
});
10.5.5. 输入过滤器
<div ng-app="myApp" ng-controller="namesCtrl">
<p><input type="text" ng-model="test"></p>
<ul>
<li ng-repeat="x in names | filter:test | orderBy:'country'">
{{ (x.name | uppercase) + ', ' + x.country }}
</li>
</ul>
</div>
angular.module('myApp', []).controller('namesCtrl', function($scope) {
$scope.names = [
{name:'Jani',country:'Norway'},
{name:'Hege',country:'Sweden'},
{name:'Kai',country:'Denmark'}
];
});
10.5.6. 自定义过滤器
以下实例自定义一个过滤器 reverse,将字符串反转:
var app = angular.module('myApp', []);
app.controller('myCtrl', function($scope) {
$scope.msg = "Runoob";
});
app.filter('reverse', function() { //可以注入依赖
return function(text) {
return text.split("").reverse().join("");
}
});
10.5.7. 常用实例
1、uppercase,lowercase 大小写转换
{{ "lower cap string" | uppercase }} // 结果:LOWER CAP STRING
{{ "TANK is GOOD" | lowercase }} // 结果:tank is good
2、date 格式化
{{1490161945000 | date:"yyyy-MM-dd HH:mm:ss"}} // 2017-03-22 13:52:25
3、number 格式化(保留小数)
{{149016.1945000 | number:2}}
4、currency货币格式化
{{ 250 | currency }} // 结果:$250.00
{{ 250 | currency:"RMB ¥ " }} // 结果:RMB ¥ 250.00
5、filter查找
输入过滤器可以通过一个管道字符(|)和一个过滤器添加到指令中,该过滤器后跟一个冒号和一个模型名称。
filter 过滤器从数组中选择一个子集
// 查找name为iphone的行
{{ [{"age": 20,"id": 10,"name": "iphone"},
{"age": 12,"id": 11,"name": "sunm xing"},
{"age": 44,"id": 12,"name": "test abc"}
] | filter:{'name':'iphone'} }}
6、limitTo 截取
{{"1234567890" | limitTo :6}} // 从前面开始截取6位
{{"1234567890" | limitTo:-4}} // 从后面开始截取4位
7、orderBy 排序
// 根id降序排
{{ [{"age": 20,"id": 10,"name": "iphone"},
{"age": 12,"id": 11,"name": "sunm xing"},
{"age": 44,"id": 12,"name": "test abc"}
] | orderBy:'id':true }}
// 根据id升序排
{{ [{"age": 20,"id": 10,"name": "iphone"},
{"age": 12,"id": 11,"name": "sunm xing"},
{"age": 44,"id": 12,"name": "test abc"}
] | orderBy:'id' }}
11.自定义过滤器
<div ng-app="myApp" ng-controller="myCtrl">
姓名: {{ msg | reverse }}
</div>
<script>
var app = angular.module('myApp', []);
app.controller('myCtrl', function($scope) {
$scope.msg = "Runoob";
});
app.filter('reverse', function() { //可以注入依赖,进行反转
return function(text) {
return text.split("").reverse().join("");
}
});
</script>
11.2. 过滤时间:
<td ng-bind="ctl.info.BIRTHDAY | date:'yyyy-MM-dd'"></td>
0 0
- angularjs 使用中的积累
- AngularJS积累
- angularjs积累
- angularjs中的使用注意
- angularJS使用中的坑
- 使用AngularJS开发中的几个问题
- Angularjs使用中的一些注意事项
- js使用中的一些自己的积累
- 初入职oracle使用中的一点积累
- Linux使用过程中的经验积累
- 瀑布流在Angularjs中的使用
- angularJs中的form指令的使用
- angularJs中的ng-repeat的使用
- Angularjs:Angularjs使用心得
- 【SpringFox / Swagger文档生成工具】使用过程中的几个问题积累
- AngularJS使用
- angularJS使用
- AngularJS最佳实践: 请小心使用 ng-repeat 中的 $index
- 使用php的swoole扩展实现数据实时更新(上)
- EndNote的基础学习
- linux exercise 13
- Mysql 经典8小时问题
- 1006. 换个格式输出整数 (15)
- angularjs 使用中的积累
- restful架构
- ffmpeg编译过程(三)-->编译
- JavaScript-02-优先级/提取行间事件
- Win7、Ubuntu双系统正确卸载Ubuntu系统
- linux 重写Tomcat启停脚本
- Android中使用Java开源库Javassist动态创建字节码的学习研究
- TTL和CMOS集成电路输入端接电阻的两种情况
- 判断邮件地址是否合法