Я новичок в angularjs (особенно angular js2).
Я запутался с импортом/конфигурацией SystemJS.
У меня есть приложение (angularjs2), которое работает нормально. Я разрабатываю его с помощью Visual Studio.
Я настроил package.json, который загружает в node_modules все необходимое. В моем случае я хотел бы использовать chart.js
фрагмент из файла package.json
"dependencies": {
"angular2": "2.0.0-beta.15",
"es6-shim": "^0.35.0",
"reflect-metadata": "0.1.2",
"rxjs": "5.0.0-beta.2",
"systemjs": "^0.19.26",
"zone.js": "0.6.11",
"bootstrap": "3.3.6",
"jquery": "2.2.3",
"font-awesome": "4.5.0",
"toastr": "2.1.2",
"chart.js": "2.0.2"
},
В моем Index.html у меня есть следующее:
<!-- 2. Configure SystemJS -->
<script>
System.config({
packages: {
app: {
format: 'register',
defaultExtension: 'js'
}
}
});
System.import('app/main')
.then(null, console.error.bind(console));
$(document).ready(function () {
window.toastr = toastr;
setTimeout(function () {
toastr.options = {
closeButton: true,
progressBar: true,
showMethod: 'slideDown',
timeOut: 2500
};
toastr.success('Welcome to the APP');
}, 1300);
});
</script>
Как импортируется Chart JS:
<!-- ChartJS-->
<!--version1: OLD ChartJS importing WORKS ok-->
<!--<script src="scripts/plugins/chartJs/Chart.min.js"></script>-->
<!--version2: This kind of importing does not work-->
<script src="node_modules/chart.js/dist/Chart.min.js"></script>
Примечание:
У меня есть toastr, который также импортируется из node_modules следующим образом:
<!-- Toastr -->
<script src="node_modules/toastr/build/toastr.min.js"></script>
Но работает нормально.
Папка node_modules не включена в мое решение
Я собираюсь использовать его в компоненте (позже в отдельной директиве - в соответствии с лучшим подходом)
На этой линии
var myNewChart = new Chart(ctx).Line(lineData, options);
он жалуется на:
ReferenceError: Chart is not defined
at DashboardComponent.execute.DashboardComponent.createLinearChart