2017-02-16 8 views
0

У меня есть директива AngularJS, которая создает Sparkline, которую я затем использую внутри нескольких модулей. Приложение работает так, как ожидалось, в Firefox (51 ..), однако при просмотре в браузере Google Chrome (56 ..) приложение не может доставить нужный графический файл.Нечетное поведение AngularJS 1.5 в Chrome вложенной директивы в компоненте

Обратите внимание, что я протестировал фактическое приложение с сервера, и это не проблема с запросами на перекрестный запрос. Кроме того, при проверке на консоли не сообщается никаких ошибок.

Image showing output in two browsers

Это plunker воспроизводит мой первоначальный вопрос: https://plnkr.co/edit/K9wO5Ibx1Uk8ygkOUGU6?p=preview

Заранее спасибо за любую помощь.

index.html

<html> 
    <head> 
    <link rel="stylesheet" href="style.css" /> 
    <script src="jquery.min.js"></script> 
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.5.6/angular.min.js"></script> 
    <script src="jquery.sparkline.js"></script> 
    <script src="app.module.js"></script> 
    <script src="ab-help.module.js"></script> 
    <script src="ab-help.component.js"></script> 
    <script src="ab-spkline.directive.js"></script> 
    </head> 
<body ng-app="abMyapp"> 
    <h2>Testing sparkline directive via component in angular </h2> 
    <p>This is outside the ab-help tags</p> 
    <spk-line data="30, 1, 14, 10, 8, 15, 6, 13, 2"></spk-line> 
    <ab-help></ab-help> 
    </body> 
</html> 

различных .js части прессуют ниже:

// Define the 'app' module 
angular.module('abMyapp', ['abHelp']); //note in my original app more modules are injected here, example on plunker only shows one! 

// Define the `abHelp` module 
angular.module('abHelp', []); 

// Register `abHelp` component, along with its associated controller and template 
angular. 
module('abHelp'). 
component('abHelp', { 
    templateUrl: 'ab-help.template.html', 
    controller: function(){ 
     this.myData = "1, 1, 4, 14, 4, 15, 6, 23, 4"; 
    } 
}); 

//template 
<p>This is from inside component</p> 
<spk-line data="3, 1, 4, 10, 8, 5, 6, 3, 4"></spk-line> <br> 
<spk-line data="{{ $ctrl.myData }}"></spk-line> 

Все важные Спарклайн директива с благодарностью за http://jsfiddle.net/NAA5G/ и конечно http://omnipotent.net/jquery.sparkline/#s-about, & JQuery, Угловая!

angular.module('abMyapp').directive("spkLine", function() { 
    return { 
    restrict: "E", 
    scope: { 
     data: "@" 
    }, 

    compile: function(tElement, tAttrs, transclude) { 
     tElement.replaceWith("<span>" + tAttrs.data + "</span>"); 
     return function(scope, element, attrs) { 
     attrs.$observe("data", function(newValue) { 
      element.html(newValue); 
      element.sparkline('html', { 
      type: 'line' 
      }); 
     }); 
     }; 
    } 
    }; 
}); 

ответ

1

Фактически отсортировано, используя выпуск 2.1.2 искровой линии jquery. У этого есть проблема всплывающих подсказок, которую я поднял с помощью issue #188

Спасибо, что посмотрели.

 Смежные вопросы

  • Нет связанных вопросов^_^