在Angular中使用单个,更通用的指令或基于多个类型的指令是否更好?

时间:2015-12-26 06:59:31

标签: javascript angularjs

拥有以下是不错的做法:

  1. 具有多个data- *参数和串行数据的单个通用指令从控制器
  2. 绑定
  3. 具有配置和串行数据的单个通用指令来自控制器
  4. 多个指令在指令中有一些预定义的配置,一些配置是通过data- *参数和串行数据从控制器绑定
  5. 例如,我有一个模板,我需要创建~16个图表(Highcharts / amCharts)。所有这些都没有相同的配置和串行数据。

    1选项示例:

    angular.module('myApp')
      .directive('ngHighcharts', () => ({
        restrict: 'AE',
        replace: 'true',
        scope: {
          data: '='
        },
        template: '<div></div>',
        link: function(scope, $elem, $attrs) {
    
          var chart, config;
          config = {
            chart: {
              renderTo: $elem[0],
              type: $attrs.type ? $attrs.type : 'bar'
            },
            exporting: {
              enabled: $attrs.exporting ? $attrs.exporting : false
            },
            title: {
              text: $attrs.title ? $attrs.title : ''
            },
            xAxis: {
              categories: $attrs.categories ? $attrs.categories : data[0]
            },
            tooltip: {
              valueSuffix: $attrs.valueSuffix ? $attrs.valueSuffix : ''
            },
            plotOptions: {
              bar: {
                dataLabels: {
                  enabled: $attrs.dataLabels ? $attrs.dataLabels : false
                }
              }
            },
            series: scope.data
          };
    
          chart = new Highcharts.Chart(config);
    
          scope.$on('$destroy', function () {
            scope.$evalAsync(function () {
              chart.destroy ();
            });
          });
    
        }
       }));
    

    2选项示例:

    angular.module('myApp')
      .directive('ngHighcharts', () => ({
        restrict: 'AE',
        replace: 'true',
        scope: {
          config: '=',
          data: '='
        },
        template: '<div></div>',
        link: function(scope, $elem, $attrs) {
    
          config.chart.renderTo = $elem[0];
          var chart = new Highcharts.Chart(config);
    
          scope.$on('$destroy', function () {
            scope.$evalAsync(function () {
              chart.destroy ();
            });
          });
    
        }
       }));
    

    3选项示例:

    angular.module('myApp')
      .directive('ngHighcharts', () => ({
        restrict: 'AE',
        replace: 'true',
        scope: {
          data: '='
        },
        template: '<div></div>',
        link: function(scope, $elem, $attrs) {
    
          var chart, config;
          config = {
            chart: {
              renderTo: $elem[0],
              type: 'bar'
            },
            exporting: {
              enabled: true
            },
            title: {
              text: $attrs.title ? $attrs.title : ''
            },
            xAxis: {
              categories: $attrs.categories ? $attrs.categories : data[0]
            },
            tooltip: {
              valueSuffix: $attrs.valueSuffix ? $attrs.valueSuffix : ''
            },
            plotOptions: {
              bar: {
                dataLabels: {
                  enabled: true
                }
              }
            },
            series: scope.data
          };
    
          chart = new Highcharts.Chart(config);
    
          scope.$on('$destroy', function () {
            scope.$evalAsync(function () {
              chart.destroy ();
            });
          });
    
        }
       }));
    

    在这种情况下,最佳做法是什么?

0 个答案:

没有答案