快捷搜索:
来自 新京葡娱乐场网址 2019-11-10 15:44 的文章
当前位置: 67677新澳门手机版 > 新京葡娱乐场网址 > 正文

新京葡娱乐场网址:亟待希图的手续,带您走入

从 Angular 1 升级到 Angular 2 要求预备的手续

2016/07/09 · JavaScript · AngularJS, 升级

本文由 伯乐在线 - 段昕理 翻译,光光头去打生抽 校稿。未经许可,禁绝转发!
葡萄牙共和国语出处:Oren Farhi。应接参预翻译组。

自己近日在试玩 Angular 2。刚伊始觉得很想获得,和大家爱怜的第 1 版完全分歧。第 1 版是用 ES5 标准的纯 javascript 编写,而第 2 版采取了 typescript 和 es 二〇一六。可是,你早就足以利用部分手续,让您的 Angular 1 代码(或用 Angular 1 创造的新品类卡塔 尔(阿拉伯语:قطر‎特别贴近 Angular 2。

AngulaJS实战计算, 带你进去AngularJS世界(待续卡塔尔国

选用AngularJS  进行Hybrid App 开采已经有一年多日子了,这里做二个计算.

 

 

 

意气风发、AngularJS 初步化加载流程

 

 

 

1、浏览器载入HTML,然后把它拆解深入分析成DOM。

2、浏览器载入angular.js脚本。

3、AngularJS等到DOMContentLoaded事件触发。

4、AngularJS找出ng-app指令,那一个命令提示了应用的分界。

5、使用ng-app中内定的模块来布局注入器($injector)。

6、注入器($injector)是用来创设“编写翻译服务($compile service)”和“根功效域($rootScope)”的。

7、编写翻译服务($compile service)是用来编写翻译DOM并把它链接到根功效域($rootScope)的。

8、ng-init指令将“World”赋给效用域里的name那些变量。

9、通过{{name}}的轮番,整个表明式产生了“Hello World”。

 

 

 

二、AngularJS Provider/Service/Factory

 

 

 

1、什么是 provider ?

 

provider 可感觉使用提供通用的劳动,格局得以是常量,也得以是目的。

 

比方说大家在 controller 里注入进来的 $http, $scope 都足以感觉是 provider。

 

 

app.controller('MainCtrl', function ($scope, $http) {

 

  $http.get(....).then(.....);

 

}

 

 

2、provider  

 

近些日子让我们团结来定制八个 provider

 

 

// 方法 1

$provide.provider('test', {

 

   n:1;

 

   $get: function () {

 

      return n;

 

    };

 

});

 

// 方法 2

$provide.provider('test', function () {

 

   this.n = 2;

 

   this.$get = function () {

 

   return n;

 

};

 

});

 

// 使用

app.controller('MainCtrl', function ($scope, test) {

    $scope.test = test;

});

  

 

让大家看看 provider 的内部得以完结代码

 

function provider(name, provider_) {

 

  if (isFunction(provider_)) {

 

      provider_ = providerInjector.instantiate(provider_);

 

  }

 

   if (!provider_.$get) {

 

       throw Error('Provider ' name ' must define $get factory method.');

 

   }

 

   return providerCache[name providerSuffix] = provider_;

 

}

 

 

能够看出 provider 的为主原则正是经过完成 $get 方法来拓宽单例注入,使用时拿到的正是 $get 实施后的结果。

 

3、factory

 

 

那即使老是都要写叁个 $get 是或不是很麻烦? OK,所以大家有了 factory。 factory 能够说是 provider 的变种, 方法中的第三个参数便是 $get 中的内容。

 

 

// 定义 factory

 

$provide.factory('dd', function () {

 

   return new Date();

 

});

 

// 使用

 

app.controller('MainCtrl', function ($scope, dd) {

 

    $scope.mydate = dd;

 

});

  

 

 

factory 的贯彻源代码:

 

 

function factory(name, factoryFn) {

 

 return provider(name, {

 

   $get: factoryFn

 

});

 

}

  

 

4、service

 

 

在 factory 的例证中大家依旧必要 new 二个指标回来,而 service 就更简明了,这一步都帮你省了, 他的第贰个参数正是您要回到的对象类, 也正是 new 的哦给您办事都毫无您做了。够清爽吧?

 

// 定义 service

 

$provide.service('dd', Date);

 

 

上边是 service 的兑现源代码:

 

 

function service(name, constructor) {

 

  return factory(name, ['$injector', function($injector) {

 

       return $injector.instantiate(constructor);

 

   }]);

}

 

 

然后 factory 和 service 带给代码简洁明了的还要也损失了豆蔻梢头部分特色。 provider 定义的服务是能够透过模块 config 来布署的。

 

 

 

三、AngularJS 动态添新币素和删除成分

 

 

$scope.userName='Welcome to Angular World!';

$scope.test = function test(){

console.log('Angular 动态添新币素');

}

 

//通过$compile动态编译html

var html="<div ng-click='test()'>}</div>";

var template = angular.element(html);

var mobileDialogElement = $compile(template)($scope);

angular.element(document.body).append(mobileDialogElement);

 

// remove移除创设的因素

var closeMobileDialog = function () {

if (mobileDialogElement) {

  mobileDialogElement.remove();

}

 

 

四、AngularJS 事件广播与选用 

 

 

 

出殡音讯: $scope.$emit(name, data) 可能 $scope.$broadcast(name, data);

 

收下音讯: $scope.on(name,function(event,data){ });

 

区分: $emit 广播给父controller   $broadcast 广播给子controller

 

 

 

broadcast 是从发送者向他的子scope广播八个事件。

 

此地就是ParentController发送, ParentController 和 ChildController 会接收到, 而MainController是不会吸收接纳的

 

 

 

$emit 广播给父controller,父controller 是足以采纳音信

 

$on 有七个参数function(event,msg)  第三个参数是事件目的,第二个参数是选取到音信音信

 

 

 

angular.module('onBroadcastEvent', ['ng'])

     .controller('MainController', function($scope) {

       $scope.$on('To-MainController', function(event,msg) {

         console.log('MainController received:' msg);

       });

     })

     .controller('ParentController', function($scope) {

       $scope.click = function (msg) {

         $scope.$emit('To-MainController',msg ',from ParentController to MainController');

         $scope.$broadcast('To-ChildController', msg ',from ParentController to ChildController');

         $scope.$broadcast('To-BrotherController', msg ',from ParentController to BrotherController');

       }

     })

     .controller('ChildController', function($scope){

       $scope.$on('To-ChildController', function(event,msg) {

         console.log('ChildController received:' msg);

       });

     })

     .controller('BrotherController', function($scope){

       $scope.$on('To-BrotherController', function(event, msg) {

         console.log('BrotherController received:' msg);

       });

     });

 

 

五、AngularJS Promise Deferred实例

 

var app = angular.module('app', ['autocomplete']);

app.factory('Suggestion',

function($http, $q, $timeout){

  var suggestion = new Object();

  suggestion.getData = function(keyword) {

    var deferred = $q.defer();

    $http.get('',

    }).success(function(data){

      deferred.resolve(data);

    });

    return deferred.promise;

  }

  return suggestion;

});

app.controller('MySuggestionCtrl',

function($scope, $sce,Suggestion){

  $scope.autoComplete = function(keyword){

    if(keyword){

        Suggestion.getData(keyword).then(function(data){

        var dataList = data.split('|');

        $scope.dataList = dataList;

      });

    }

  }

});

 多个Promise实例:

 

var data2="222";

var promises = [];

var deffered1  = $q.defer();

var deffered2  = $q.defer();

$timeout(function(){

  deffered1.resolve(data1);

},2000);

$timeout(function(){

  deffered2.resolve(data2);

},2000);

promises.push(deffered1.promise);

promises.push(deffered2.promise);

 $q.all(promises).then(function(data){

    console.log(data);

});

输出: ["111", "222"] 那几个多个数组对象顺序与push的逐个大器晚成致

 

  

 

六、AngularJS 全局scope与Isolate scope通信

 

 

一、scope作用域

1、AngularJS中,子成效域常常都会经过JavaScript原型世襲机制接轨其父成效域的天性和艺术。但有二个例外:在directive中采用scope: { ... },这种格局开创的功用域是叁个独门的"Isolate"功效域,它也会有父功能域,但父效用域不在其原型链上,不会对父作用域进行原型继承。这种措施定义成效域日常用于组织可复用的directive组件.

 

2、倘使我们在子成效域中拜候多个父效率域中定义的性质,JavaScript首先在子功用域中追寻该属性,没找到再从原型链上的父功效域中查找,倘使尚未找到会再往上一流原型链的父成效域寻觅。在AngularJS中,成效域原型链的上方是$rootScope,JavaScript寻找到$rootScope截至.

 

3、scope: { ... } - directive创设三个独自的“Isolate”成效域,未有原型世襲。那是开创可复用directive组件的最棒选项。因为它不会一直访谈/改过父效用域的属性,不会生出意料之外的副功效。

 

 

二、Isolate scope 援引修饰符

1、 = or =attr “Isolate”功能域的性质与父成效域的习性实行双向绑定,任何一方的改革均影响到对方,那是最常用的办法;

 

2、 @ or @attr “Isolate”功效域的习性与父功用域的性格举办单向绑定,即“Isolate”功用域只好读取父效用域的值,并且该值长久的String类型;

 

3、 & or &attr “Isolate”作用域把父功能域的属性包装成多少个函数,进而以函数的点子读写父功能域的品质,包装情势是$parse

 

 

三、directive 与 controller 数据传递和通讯

1、父controller监听全局scope(父scope)变量, 并广播事件给子scope(directive scope,每种directvie都有本人单独的scope功效域)

 

2、directive 定义本地scope,通过=、@、&(方法)字符显示援引全局scope

 

3、directive scope(子scope)通过parent[$scope.$parent.xxx]引用全局scope的质量

 

4、directive监听全局scope变量变化,能够由此$scope.$parent.$watch方法

 

 

 

四、实例讲明

 

 

 

 

七、AngularJS $apply vs $digest

 

$apply会使ng走入$digest cycle, 并从$rootScope最先遍历(深度优先)检查数据改变。

$digest仅会检讨该scope和它的子scope,当您显明当前操作仅影响它们时,用$digest可以稍微升高品质。

部分不要求的操作,放到$timeout里面延迟试行。

假诺不涉及数量变动,还足以增进第五个参数false,幸免调用$apply。

directive中实施的$evalAsync, 会在angular操作DOM之后,浏览器渲染此前推行。

controller中施行的$evalAsync, 会在angular操作DOM早前执行,日常不那样用。

而利用$timeout,会在浏览器渲染之后施行。

对时间有要求的,第叁个参数可以设置为0。

 

$http.get('

  $scope.name = data.name;

  $timeout(function(){

    //do sth later, such as log

  }, 0, false);

});

 

 

    详细:

 

 

 

八、AngularJS Directive 学习 实例

 

 

 

1、restrict 它界定directive为钦赐的扬言方式。假若简单的话,directive将唯有允许通过质量评释

 

E - 成分名称: <my-directive></my-directive>

 

A - 属性名: <div my-directive="exp"></div>

 

C - class名: <div class="my-directive:exp;"></div>

 

M - 注释 : <!-- directive: my-directive exp -->

 

2、dialog实例

 

 

<!DOCTYPE html>

  

<html ng-app="Dialog">

  

<head>

  

  <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>

  

  <title>directive-dialog</title>

  

  <meta content="IE=edge,chrome=1" http-equiv="X-UA-Compatible">

  

  <script src="../../sea-modules/angular/angularjs/1.1.5/angular.js"></script>

  

</head>

  

<body>

  

<div ng-controller="MyCtrl">

  

  <button ng-click="show=true">show</button>

  

  <dialog title="Hello }"

  

          visible="}"

  

          on-cancel="show=false;"

  

          on-ok="show=false;methodInParentScope();">

  

    <!--上面的on-cancel、on-ok,是在directive的isoloate scope中通过&引用的。

  

    假诺表明式中蕴涵函数,那么必要将函数绑定在parent scope(当前是MyCtrl的scope卡塔尔国中-->

  

    Body goes here: username:} , title:}.

  

    <ul>

  

      <!--这里还是能够如此玩~names是parent scope的-->

  

      <li ng-repeat="name in names">}</li>

  

    </ul>

  

  </dialog>

  

</div>

  

<script type="text/javascript">

  

  var myModule = angular.module("Dialog", []);

  

  myModule.controller("MyCtrl", function ($scope) {

  

    $scope.names = ["name1", "name2", "name3"];

  

    $scope.show = false;

  

    $scope.username = "carl";

  

    $scope.title = "parent title";

  

    $scope.methodInParentScope = function() {

  

      alert("scope里面通过&定义的东东,是在父scope中定义!!。。。");

  

    };

  

  });

  

  myModule.directive('dialog', function factory() {

  

    return {

  

      priority:100,

  

      template:['<div ng-show="visible">',

  

        '    <h3>}</h3>',

  

        '    <div class="body" ng-transclude></div>',

  

        '    <div class="footer">',

  

        '        <button ng-click="onOk()">OK</button>',

  

        '        <button ng-click="onCancel()">Close</button>',

  

        '    </div>',

  

        '</div>'].join(""),

  

      replace:false,

  

      transclude: true,

  

      restrict:'E',

  

      scope:{

  

        title:"@",//援用dialog标签title属性的值

  

        onOk:"&",//以wrapper function方式援用dialog标签的on-ok属性的剧情

  

        onCancel:"&",//以wrapper function情势援引dialog标签的on-cancel属性的原委

  

        visible:"@"//引用dialog标签visible属性的值

  

      }

  

    };

  

  });

  

</script>

  

</body>

  

</html>

, 带你进去AngularJS世界(待续)使用AngularJS 举办Hybrid App 开采已经有一年多时刻了,这里做三个总计. 后生可畏、AngularJS 开头化加载...

笔者怎么要为 Angular 1 搬迁到 Angular 2 做筹划

率先,当机缘成熟了,你计划用 Angular 2 作为框架时,肯定想让代码迁移更易于些。如今,Angular 小组已经提供了某些搬迁政策,你能够勾兑使用 Angular 1 和 Angular 2 组件,但指标是要将代码库统风度翩翩,最终只使用一个框架。

附带,在 Angular 2 中更加多的是写纯 javascript,然后才是应用专有的框架代码。

重复,社区和浏览器厂商将日趋拥抱 Ecmascript 的时髦标准,所以,坚定不移利用正规编码,尽恐怕让代码库可复用,而无论接收的框架是怎么。

迁移到 Angular 2 的步骤

选取这几个政策能够令你的代码越发临近 Angular 2,使调换变得轻巧。

1. 开始用 Ecmascript 2015

Angular 2 采纳 Typescript 编写,Typescript 是 Ecmascript 2016的超集,带有越来越多的特征。不过,即便你厌恶 Typescript, 也能够只用 Ecmascript 二〇一四 编写 angular 2。 近日,代码最后都会编写翻译成 Ecmascript 5。所以实际你也足以用 Ecmascript 5 来编排 Angular 2。

然而,在作者眼里,使用 Ecmascript 贰零壹陆的新特点,能够减小代码量(某个时候…卡塔尔、巩固代码可读性、用上令人欢喜的风味,如解构。

借使想使用 Ecmascript 2014的特色,你供给叁个转变器来编写翻译代码。前段时间最盛行的调换器是 babel。babel 在数不完盛行的塑造脚本中都能够安顿,如 gulp、webpack、browserify 及任何。

JavaScript

// 对象属性加强 var exports = { search: search, setType: setType, setDuration: setDuration }; // 能够写成那样 var exports = { search, setType, setDuration }; ///////////// // 使用“胖箭头” => 能够简化代码并巩固可读性 var videoIds = response.data.items.map(function(video){ return video.id[idPropertyName[activeType]]; }).join(','); // 使用了胖箭头符号 var videoIds = response.data.items.map((video) => { return video.id[idPropertyName[activeType]]; }).join(',');

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
// 对象属性增强
var exports = {
    search: search,
    setType: setType,
    setDuration: setDuration
};
// 可以写成这样
var exports = {
    search,
    setType,
    setDuration
};
 
/////////////
// 使用“胖箭头” =>  可以简化代码并增强可读性
var videoIds = response.data.items.map(function(video){
    return video.id[idPropertyName[activeType]];
}).join(',');
 
// 使用了胖箭头符号
var videoIds = response.data.items.map((video) => {
    return video.id[idPropertyName[activeType]];
}).join(',');

2. 使用 “angular.service” 替换 “angular.factory”

接受 Ecmascript 二零一四 意味着大家能够用新的 “class” 关键字来创设新指标竟是推而广之此外对象。我早就写过,比起一而再一而再小编更加热衷于整合,所以笔者看不出用 “extend” 实现接二连三有啥样用途,然则经过 class 的风味确实可认为创造对象增添好用的语法糖(简化代码卡塔 尔(阿拉伯语:قطر‎。

在 angular 1 中的 “service” 和 “factory” 的界别是实例化方法:

“service” 使用 “new” 关键字调用(仅三次卡塔尔国

“factory” 使用普通函数调用 — 无需 “new” 关键字。

在 Angular 2 中,Services 使用了 Ecmascript 2016类编写。这会产生您须求将 Angular 1 代码中的 factories 转形成services,何况使用 “class” 代替 function。

举例说在本身的开源项目-Echoes Player 中,笔者动用了“class” 和 Angular“service” 编写 youtube api 服务(作者在此以前用的是 factory卡塔尔:

JavaScript

(function() { 'use strict'; /* @ngInject */ class YoutubePlayerApi { /* @ngInject */ constructor ($window, $q) { /*jshint validthis: true */ this.deferred = $q.defer(); //当 API 筹划好时,Youtube 回调 $window.onYouTubeIframeAPIReady = () => { this.deferred.resolve() }; } // 注入 YouTube 的 iFrame API load () { let validProtocols = ['http:', 'https:']; let url = '//www.youtube.com/iframe_api'; // 大家甘愿利用有关的 url 公约,但为制止合同不可用,依旧回退到 ‘http:’ if (validProtocols.indexOf(window.location.protocol) < 0) { url = 'http:' url; } let tag = document.createElement('script'); tag.src = url; let firstScriptTag = document.getElementsByTagName('script')[0]; firstScriptTag.parentNode.insertBefore(tag, firstScriptTag); return this.deferred.promise; } } angular .module('youtube.player') .service('YoutubePlayerApi', YoutubePlayerApi); })();

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
(function() {
    'use strict';
 
    /* @ngInject */
    class YoutubePlayerApi {
 
        /* @ngInject */
        constructor ($window, $q) {
            /*jshint validthis: true */
            this.deferred = $q.defer();
            //当 API 准备好时,Youtube 回调
            $window.onYouTubeIframeAPIReady = () => {
                this.deferred.resolve()
            };
        }
 
        // 注入 YouTube 的 iFrame API
        load () {
            let validProtocols = ['http:', 'https:'];
            let url = '//www.youtube.com/iframe_api';
 
            // 我们愿意使用相关的 url 协议,但为避免协议不可用,还是回退到 ‘http:’
            if (validProtocols.indexOf(window.location.protocol) < 0) {
                url = 'http:' url;
            }
            let tag = document.createElement('script');
            tag.src = url;
            let firstScriptTag = document.getElementsByTagName('script')[0];
            firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
            return this.deferred.promise;
        }
    }
 
    angular
       .module('youtube.player')
       .service('YoutubePlayerApi', YoutubePlayerApi);
})();

3. 编写 Controllers 时使用 “Class” 替换 “function”

这一步和上一步多罕有一点相符。Angular 1 中的 Controllers 总是不停被重新创立(或 “新建”卡塔尔国- 因为它们不是单例。

Angular 2 差不离不用 controllers。

反之,Angular 2 是依赖组件的。各样组件都有七个简短的类(包括小量 es7 评释卡塔 尔(英语:State of Qatar)来支配。纵然您的 Angular 1 代码是用 web 组件情势来编排的,那么很只怕每一个指令(directive卡塔尔都对应二个 controller 函数来支配。

有个十分重的点必需意识到 - 指令的定义在 Angular 2 中尤其简约:

  1. 接纳了成分选用器的授命都以组件。
  2. 剩下的都以命令。

Angular 2 依旧会在里面初始化 services 和 controllers,不要本身去初步化,因为那样会招致代码很难测量试验。然而 Angular 2 如故轻易测量试验并对 TDD (测验驱动开荒卡塔尔国 和 BDD(行为使得开垦卡塔 尔(英语:State of Qatar)友好。作者还写过大器晚成篇作品,内容是讲怎么应当封装 “new” 关键字,进而写出更便于测量试验的代码。

诸如把 controller 写成类,会使代码迁移到 angular 2 组件变得特别轻松:

JavaScript

class DurationCtrl { /* @ngInject */ constructor (YoutubeSearch) { this.YoutubeSearch = YoutubeSearch; this.durations = [ 'Any', 'Short (less then 4 minutes)', 'Medium (4-20 minutes)', 'Long (longer than 20 minutes)' ]; this.durationsMap = [ '', 'short', 'medium', 'long' ]; } onDurationChange (duration, index) { this.YoutubeSearch.setType(this.YoutubeSearch.types.VIDEO); this.YoutubeSearch.setDuration(this.durationsMap[index]); this.YoutubeSearch.search(); } } angular .module('echoes') .controller('DurationCtrl', DurationCtrl);

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
class DurationCtrl {
    /* @ngInject */
    constructor (YoutubeSearch) {
        this.YoutubeSearch = YoutubeSearch;
        this.durations = [
            'Any',
            'Short (less then 4 minutes)',
            'Medium (4-20 minutes)',
            'Long (longer than 20 minutes)'
        ];
        this.durationsMap = [
            '',
            'short',
            'medium',
            'long'
        ];
    }
 
    onDurationChange (duration, index) {
        this.YoutubeSearch.setType(this.YoutubeSearch.types.VIDEO);
        this.YoutubeSearch.setDuration(this.durationsMap[index]);
        this.YoutubeSearch.search();
    }
}
 
angular
    .module('echoes')
    .controller('DurationCtrl',  DurationCtrl);

本文由67677新澳门手机版发布于新京葡娱乐场网址,转载请注明出处:新京葡娱乐场网址:亟待希图的手续,带您走入

关键词: