Angular 1组件与指令定义

时间:2016-10-03 07:42:05

标签: angularjs node.js angular-components

我对node.js很陌生,我计划将我们的angular 1指令迁移到组件,以便更容易过渡到Angular 2.

所以,我的问题是我有一些代码使用了几个这样的定义:

'use strict';

var angular = require('angular');

angular.module('dashboard')
.directive('yepNope', require('./yep-nope.directive'))
//.component('comp', require('./myFirstComponent.component'));
.component('comp', new (require('./myFirstComponent.component')));

yep-nope.directive和MyFirstComponent.component都以相同的方式定义:

'use strict';

function MyFirstComponent() {

    function componentController($element){
        var vm = this;

        init();

        function init(){
            vm.api = {
                bar : function(){
                    console.log('bar called');                            
                },
                foo :  function(){
                    console.log('foo called');                            
                }
            };                        
        }

        this.$onInit = function(){
            console.log("$onInit");
        };

        this.$postLink = function(){
            console.log("$postLink");                    
        };

        this.$onChanges = function(changesObj){
            console.log("$onChanges");
        };
    }

    return {
        bindings: { },
        controller: componentController,
        //controllerAs: '$ctrl',
        template:'<div><h1>My Component header</h1></div>'
    }
}

module.exports = MyFirstComponent;

'use strict';

function YepNopeDirective() {
  return {
    restrict: 'E',
    link: function (scope, element, attrs) {
      scope.$watch(attrs.check, function (val) {
        var words = val ? 'Yep' : 'Nope';
        element.text(words);
      });
    }
  }
}

module.exports = YepNopeDirective;

有没有解释为什么要定义我需要做一个新的组件(需要...而使用指令这是不需要的?

.directive('yepNope', require('./yep-nope.directive'))
//.component('comp', require('./myFirstComponent.component'));
.component('comp', new (require('./myFirstComponent.component')));

谢谢,

大卫。

2 个答案:

答案 0 :(得分:1)

您根本不需要:

.directive('yepNope', YepNopeDirective);

如果确实需要,可能需要检查项目架构。

您不会将指令转换为组件。

您使用.componentdirectives stay directives

将应用转换为组件架构

答案 1 :(得分:0)

我回答我自己的问题。

组件的定义方式与传统指令不同。虽然指令需要一个函数,但组件需要一个选项对象:

app.directive(name, fn)
app.component(name, options)