Недавно я столкнулась со следующей проблемой: мне нужно было найти полностью настраиваемые веб-компоненты, с которыми несложно взаимодействовать и которые могут использоваться как встроенные BI-инструменты для анализа, отчётов и визуализации в моём приложении.
Из всех таких компонентов я выбрала Angular. Ни один его потенциальный конкурент не может сравниться с ним. Думаю, я не одна столкнулась с такой проблемой, поэтому хочу поделиться своим опытом использования Angular.
Как преданный пользователь Angular, я бы хотела в первую очередь рассказать о его преимуществах. Затем перейду к работе с аналитикой в приложениях Angular и созданию отчётов при помощи сводной сетки JavaScript и библиотеки для построения графиков.
К тому же мы сделаем несложный отчёт, который поможет в дальнейшем анализе.
Для тех, кто не хочет читать: перейдите к секции с полезными ссылками, которые позволят попрактиковаться.
Начну с того, почему я считаю фреймворк Angular лучше аналогов и как он помогает упростить и ускорить процесс разработки.
Создание динамических клиентских приложений (как одностраничных, так и многостраничных) с Angular имеет ряд преимуществ:
Именно эти свойства повышают продуктивность в создании мобильных, десктопных и веб-приложений.
Есть и недостатки: Angular достаточно сложный для изучения, особенно по сравнению с React.
Теперь поговорим о создании веб-отчётов. Я использовала два компонента: Flexmonster и Google Charts. Сейчас я расскажу о них.
Flexmonster —компонент сводной таблицы, написанный на JavaScript. Он хорош в создании веб-отчётов и проведении анализа. Также этот инструмент имеет обёртку Angular, что было немаловажно для моей задачи.
После добавления Flexmonster вы можете использовать все встроенные свойства и функции для создания своего отчёта. В конце работы таблица может быть экспортирована в Excel, PDF, Image и HTML.
Давайте посмотрим на список полезных для создания отчётов свойств.
Процесс довольно простой. Для начала нужно создать приложение Angular в командной строке:
ng new PROJECT-NAMEcd PROJECT-NAMEЗатем добавить пакет Flexmonster и модуль Flexmonster Angular:
npm i ng-flexmonster --saveВ файл angular.json
добавить следующие строчки:
"styles": [
"styles.css",
"/node_modules/flexmonster/flexmonster.min.css"
],
"scripts": [ "/node_modules/flexmonster/flexmonster.full.js" ]
Включить FlexmonsterPivotModule
в app.module.ts
. Этот файл находится внутри папки PROJECT-NAME/src/app
:
import { FlexmonsterPivotModule } from 'ng-flexmonster';
@NgModule({
...
imports: [FlexmonsterPivotModule],
...
})
Добавить директиву fm-pivot
туда, где должна быть таблица. licenseKey
— лицензионный ключ или ключ пробной версии:
<fm-pivot
[licenseKey]="'XXXX-XXXX-XXXX-XXXX-XXXX'"
[report]="'https://cdn.flexmonster.com/reports/report.json'">
</fm-pivot>
Запустить приложение из командной строки:
ng serveПодробную инструкцию можно найти здесь.
Если нужно не только группировать данные, но и визуализировать их, пригодится информационная панель. Аналитики любят её использовать, потому что она помогает отслеживать изменения бизнес-метрик и принимать решения на основе данных. Но, как разработчики, вы, вероятно, знаете, что её настройка требует большого количества времени и усилий.
Поэтому перейдём к следующему инструменту, который позволит сохранить ваше время и визуализировать данные.
Google Charts — лучший бесплатный веб-сервис для создания графиков и схем. Для взаимодействия с ним не нужно взаимодействовать с DOM-элементами, можно просто использовать API от Google Charts. Для анимации данных нужно включить в приложение Google Loader и добавить объект класса DataTable в JavaScript. Таблице передаются данные и определяется функция для построения графика.
Для получения данных можно использовать Datasource или сводную таблицу Flexmonster. Первый поддерживает протокол Chart Tools Datasource и позволяет отправлять SQL-запросы сервису для получения таблицы (объекта класса DataTable), заполненной данными. Второй же инструмент можно использовать как провайдер данных для клиентской стороны. Этот компонент использует коннекторы JavaScript, которые избавляют нас от необходимости писать код для обработки данных для создания простых графиков. Но, конечно, при необходимости вы можете применить пользовательскую логику.
Google Charts совместимы с Angular — обёртку можно найти на npm.
Вот моя информационная панель, в которой я соединила Flexmonster и Google Charts.
Можно увидеть, что вместе таблица и график заиграли новыми красками. Это совмещение позволяет связывать результаты анализа между собой.
Я указала преимущества Angular как платформы для создания динамических веб-приложений, но не стоит забывать, что при разработке каждого приложения нужно выбирать именно тот фреймворк, который лучше всего подходит для целей конкретно этого приложения.
Полезные ссылкиПеревод статьи Emilee Smith: Get started with Object Oriented Programming in Python: Classes and Instances
Комментарии