在AngularJS中使用ES6
本篇记录一些AngularJS结合使用ES6的各种写法。
ES6中module的导出导入
class MainController {
constructor(searchService){
this.searchService = searchService;
}
search(){
this.searchService
.fetch(this.searchTerm)
.then(response => {
this.items = resposne.data.items;
})
}
}
export {MainController}
如何把module中的Controller注册进module呢?
import {MainController } from './MainController';
import {searchService } from './SeachService';
angualr
.module('app',[])
.controller('mainController', MainController)
.service('searchService', searchService);
ES6中的继承
class PageController{
constructor(name){
this.name = name;
}
sayHello(){
return 'Hello ' + this.name;
}
}
export {PageController}
在另外一个文件中:
import {PageController} from './PageController';
class ProductPageController extends PageController {
constructor(){
super('jack');
}
}
export {ProductPageController}
最后注册到module中去:
angular
.module('app',[])
.controller('ProductPageController', ProductPageController);
ES6中Service和Controller的写法
class UserService{
constructor($http){
this.$http = $http;
}
getFullName(){
return this.$http.get('api/user/details');
}
}
class MyController{
//注意:定义时的class名是UserService,正真的名称是在service('realname',UserServie)中定义的
constructor(userService){
userService.getFullName().then(result => this.userName = result.fullName);
}
}
angular.module('app')
.service('userService', UserService)
.controller('MyController', MyController);
ES6中Providers的写法
class MyProvider{
constructor(){
this.apiPath = 'default/api';
}
setApiPath(value){
this.apiPath = value;
}
$get($http){
return {
getThings: () => $http.get(this.apiPath);
}
}
}
ES6的Provider中依赖的注入是写在$get()中的,不能在constructor中注入。Provider中必须有$get()方法。
ES6中Factory的写法
class Thing{
constructor(){
console.log('create the thing');
showMsg();
}
showMsg(){
console.log('some msg');
}
}
class ThingFactory{
constructor($timeout){
this.$timeout = $timeout;
}
createThing(){
return this.$timeout(() => new Thing(),1000);
}
}
如何往module中注册呢?
● 第一种写法
angular.module('app')
.factory('thingFactory', () => new ThingFactory());
以上写法是错误的,因为$timeout还没有注入进去。可以这样写。
angular.module('app')
.factory('thingFactory', ['$timeout', ($timeout) => new ThingFactory($timeout)]);
● 第二种写法
但,以上的写法也不是最理想的。最好是写在类中。
class ThingFactory{
constructor($timeout){
this.$timeout = $timeout;
}
createThing(){
return this.$timeout(() => new Thing(),1000);
}
}
ThingFactory.$inject = ['$timeout'];
然后,
angular.module('app')
.factory('thingFactory', () => new ThingFactory());
● 第三种写法
class ThingFactory{
constructor($timeout){
this.$timeout = $timeout;
}
createThing(){
return this.$timeout(() => new Thing(),1000);
}
}
ThingFactory.$inject = ['$timeout'];
var constructorFn = ThingFactory;
//args = ['$timeout']
var args = constructorFn.$inject;
//根据参数创建ThingFactory实例,任意多的参数
var factoryFunction = (...args) => {
return new constructorFn(...args);
}
//['$timeout', ($timeout) => new ThingFactory($timeout)]
var factoryArray = args.push(factoryFunction);
angular.module('app')
.factory('thingFactory', factoryArray);
ES6中Directive的写法
class MyDirective{
constructor($interval){
this.template = '<div>I\'m a directive</div>';
this.restrict = 'E';
this.scope = {};
this.$interval = $interval;
}
compile(tElement){
tElement.css('position','absolute');
}
link(scope, element){
this.$interval(() => this.move(element),1000);
}
move(element){
element.css('left', (Math.random() * 500) + 'px');
element.css('top', (Math.random() * 500) + 'px');
}
}
以上,如果同时使用compile和link方法,link方法应该是compile的返回值。
compile(tElement){
tElement.css('position','absolute');
return this.link;
}
以上,当angular调用this.link方法,将不会在MyDirective的当前上下文中,调用this.$interval(() => this.move(element),1000);会报undefined类型错误。
如果改成这样:
compile(tElement){
tElement.css('position','absolute');
return (scope, element) => {
this.$interval(() => this.move(element),1000);
};
}
这里,当使用=>后,调用this.$interval(() => this.move(element),1000);方法能保证还MyDirective所在的当前上下文中。
还可以这么写:
compile(tElement){
tElement.css('position','absolute');
return this.link.bind(this);
}
link(scope, element){
this.$interval(() => this.move(element),1000);
}
但, 以上所有的做法都必须调用compile方法,而在实际场景中,调用compile方法不是必须的。最好这样写:
var constructorFn = MyDirective; //是否有compile方法
if (!constructorFn.prototype.compile) {
// 如果没有,通过原型创建compile方法
constructorFn.prototype.compile = () => {};
} var originalCompileFn = _cloneFunction(constructorFn.prototype.compile); //重写compile方法
_override(constructorFn.prototype, 'compile', function () {
return function () { //先调用原先的compile方法
originalCompileFn.apply(this, arguments); //如果Directive包含link方法再执行link方法,绑定正确的上下文
if (constructorFn.prototype.link) {
return constructorFn.prototype.link.bind(this);
}
};
});
往module注册controller、factory、provider等的帮助方法
Michael Bromley还专门写了一个帮助方法,在这里。
大致这样使用:
class MyAngularComponent {
/*@ngInject*/
constructor(dependency1, dependency2) {
this.dependency1 = dependency1;
// stuff happens here
}
someMethods() {
this.dependency1.doThatThing();
// more stuff here
}
}
register('app')
.controller('MyController', MyAngularComponent)
.service('myService', MyAngularComponent)
.provider('myOtherService', MyAngularComponent)
.factory('myFactory', MyAngularComponent)
.directive('myDirective', MyAngularComponent);
参考资料:
http://blog.thoughtram.io/angularjs/es6/2015/01/23/exploring-angular-1.3-using-es6.html
http://www.michaelbromley.co.uk/blog/350/exploring-es6-classes-in-angularjs-1-x
https://github.com/timroes/angular-es6-sample
在AngularJS中使用ES6的更多相关文章
- angularJS中的Promise对象($q)的深入理解
原文链接:a better way to learn AngularJS - promises AngularJS通过内置的$q服务提供Promise编程模式.通过将异步函数注册到promise对象, ...
- Angularjs中的promise
promise 是一种用异步方式处理值的方法,promise是对象,代表了一个函数最终可能的返回值或抛出的异常.在与远程对象打交道非常有用,可以把它们看成一个远程对象的代理. 要在Angular中创建 ...
- angularJS中XHR与promise
angularJS应用是完全运行在客户端的应用,我们可以通过angularJS构建一个不需依赖于后端,同时能够实现动态内容和响应的web应用,angularJS提供了将应用与远程服务器的信息集成在一起 ...
- AngularJS中get请求URL出现跨域问题
今天早上帮助同学看了一个AngularJS的问题,主要是请求中出现了跨域访问,请求被阻止. 下面是她给我的代码: <html lang="en" ng-app="m ...
- AngularJS 中的Promise --- $q服务详解
先说说什么是Promise,什么是$q吧.Promise是一种异步处理模式,有很多的实现方式,比如著名的Kris Kwal's Q还有JQuery的Deffered. 什么是Promise 以前了解过 ...
- AngularJS中的表单验证
AngularJS中的表单验证 AngularJS自带了很多验证,什么必填,最大长度,最小长度...,这里记录几个有用的正则式验证 1.使用angularjs的表单验证 正则式验证 只需要配置一个正则 ...
- 关于angularjs中的jQuery
关于angularjs中的jQuery 下面是一个小例子,用来说明我经常看到的一种模式.我们需要一个开关型的按钮.(注意:这个例子的代码有点装逼,并且有点冗长,只是为了用来代表更加复杂一些的例子,这些 ...
- angularjs中的directive scope配置
angularjs中的directive scope配置 定义directive其中重要的一环就是定义scope,scope有三种形式: 默认的scope,DOM元素上原有的scope scope: ...
- angularjs中provider,factory,service的区别和用法
angularjs中provider,factory,service的区别和用法 都能提供service,但是又有差别 service 第一次被注入时实例化,只实例化一次,整个应用的生命周期中是个单例 ...
随机推荐
- Parameters.Add和Parameters.AddWithValue
因为vs2013没有更新update 5所以Parameters.Add可以用Parameters.AddWithValue赋值无效 更新后可以. Parameters.AddWithValue的底层 ...
- orm 缺点
背景 提起orm,在我开发这几年可是阴魂不散,因为我的开发没人带,全是自己琢磨,好处是很多东西都懂,都理解的透彻,缺点是见得少,接触少.而我一直没用orm,但是又到处听说orm,但我总想不明白有啥用处 ...
- jenkins 使用Git持续构建
为jenkins添加git插件. 在Available tab页中找到Git Plugin 点击下方的Install without Restart安装插件. 插件安装完毕后,我们需要在jenkins ...
- DOM事件阶段以及事件捕获与事件冒泡先后执行顺序
平时浏览这么多技术文章,如过不去实践.深入弄透它,这个技术点很快就会在脑海里模糊.要加深印象,就得好好过一遍.重要的事情说三遍,重要的知识写一遍. 开发过程中我们都希望使用别人成熟的框架,因为站在巨人 ...
- C++ code:动态内存
C++给我们提供了动态内存分配的new和delete操作.一般而论,new和delete操作多用在内存需求捉摸不定的场合.然而,需要处理的数据,如果变动范围很小,我们可以用STL中通用型的容器来做,大 ...
- ajax最基础入门
1.介绍 AJAX = 异步 JavaScript 和 XML. AJAX 是一种用于创建快速动态网页的技术. 通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新.这意味着可以在不重 ...
- C++Primer #7 类
类的定义 简单的来说类就是数据和它的操作的一种封装,内部提供接口函数 类的成员函数的声明必须在类的内部,而它的定义则既可以放在类的内部也可以放在类的外部.(一般在类内进行声明,类外实现函数定义) 定义 ...
- 【LOJ】#2090. 「ZJOI2016」旅行者
题解 每次按较长边把矩形分成两半,找一个中间轴,轴上的每个点跑一边最短路更新所有的答案 然后把矩形分成两半,递归下去 代码 #include <bits/stdc++.h> #define ...
- WebView图片点击查看
需求:WebView中的图片点击后放大全屏查看 this.setWebViewClient(new WebViewClient() { @Override public boolean shouldO ...
- 010.Zabbix的zatree插件安装
一 zatree简介 zatree 是来自国内58公司开发的监控软件zabbix的一个插件,主要功能是提供host group的树形展示和在item里指定关键字查询及数据排序. 二 安装前准备 2.1 ...