обзор javascript UI библиотек для SPA. Часть 1 / Хабр
Всем привет! На дворе 2016 год, и web давно превратился в нечто большее, чем простые сайты. Львиная доля компаний уже давно забыла про десктопные программы, и для повсеместных задач используют веб приложения, будь это CRM, система управления складом, система аналитики или простая панель администрирования от сайта (в дальнейшем – админка).
И их можно понять, ведь для работы не нужна специфическая конфигурация, специальное установленное ПО, его обновление. Достаточно открыть браузер и программа работает. Поэтому, на мой взгляд, за веб-приложениями – будущее!
Делать с нуля полноценную, ничуть не уступающую десктопной программу — это титанический труд.
Во-первых, нужно как-то реагировать на те или иные события в реальном времени, периодически подгружать данные.
Во-вторых, обычно нужны те контролы (виджеты), которые имеются в декстопных приложениях. Но их нет. В html нет дерева, нет вкладок, нет контекстного меню и много чего еще.
В-третьих, производительность десктопных приложений намного лучше, потому что им не надо подгружать библиотеки и ресурсы из интернета, да и написаны они на компилируемом языке. И, хотя браузеры вшивают в себя всяческие современные движки, которые позволяют достичь невероятной производительности, до компилируемых языков еще далеко. Но вполне возможно, что скоро ситуация поменяется.
В-четвертых, есть небольшая проблема в лице большого разнообразия всевозможных браузеров, каждый из которых имеет свои особенности, поддерживает тот или иной стандарт.
В итоге, на html все это, конечно, можно написать, затем оживить с помощью js, и стилизовать с помощью css. После этого следует оттестировать его работу в целом зоопарке браузеров. Затем графические элементы надо как-то связать с реальными данными, а в случае, если эти данные не постоянные… в общем, на все это дело уйдет уйма времени.
Хотя, конечно, решить данную задачу можно по-разному. Для оформления взять Bootstrap, Uikit, Semantic UI или другой CSS фреймворк. Для связки с данными и не только можно использовать Angular, Backbone, React, Knockout. Затем подключать еще десяток разных библиотек, пытаться их подружить и получить свое, правильное, тонко настроенное и современное приложение.
Может быть, я покажусь не модным и не современным, но для меня в таком случае идеальное решение — уже использовать библиотеку или фреймворк с большим количеством готовых виджетов. Большинство из них ушли достаточно далеко, многое умеют и не требуют изобретения своего велосипеда. Хотя и попадаются те, которые представляют из себя просто набор виджетов и являются неплохим дополнением к вышеописанным библиотекам.
Как это не удивительно, JS UI библиотек насчитывается несколько десятков, и лишь 5-6 на слуху у пользователей. Такой расклад вещей несправедлив и я решил написать обзор всего более-менее презентабельного из того, что удалось найти.
Небольшие пояснения
Моя цель — построение полноценной админки, работающей по принципу SPA. Библиотека может быть хороша, но будет подходить больше для сайта. Исключение составляет jquery UI (ну надо было с чего-то начать). В обзоре будет небольшое описание, демо-приложение и рейтинг. Я буду оценивать сложность, размер демо-кода, гибкость. Упомяну о потреблении памяти и времени рендеринга страницы. Также стоит упомянуть возможность работы с мобильными устройствами, так как на данный момент существует тенденция писать мобильные приложения на чистом html/js.
Под сложностью подразумевается, насколько трудно написать именно админку: это суммарная оценка времени на изучение кода, недоступность тех или иных контролов, мое время написания демо кода, поиск по документации, где был встречен какой-то глюк, который в любом случае надо исправлять, где застрял, и т.п. Поэтому не удивляйтесь большой сложности JqueryUI, так как у него нет половины элементов, необходимых для написания полноценной админки.
Я не претендую на чистоту кода, поэтому демо примеры идут “как есть”, написанные на очень беглую руку и, возможно, содержащие глюки. Уважаемые гуру, отнеситесь к этому с пониманием, так как поиск конкретного костыля для той или иной библиотеки – это дело большого времени и требует более детального изучения.
Jquery UI
Jquery UI – пожалуй, самая известная и простая UI библиотека. Очень удобна для сайта, но создание админки на ней — то еще извращение, так как Jquery UI содержит всего 14 виджетов. Однако за счет ее популярности недостающие UI элементы можно найти в интернете и получить админку на чистом Jquery UI а-ля “Франкенштейн” с кучей костылей. Как не странно, но на моей практике такое встречалось.
Лицензия: | Mit лучший результат | Демо |
---|---|---|
Кол-во виджетов: | 14 | |
Размер демо кода | 5. 00 кб | |
Сложность освоения | Очень легко | |
Скорость разработки | Очень долго | |
Мобильные виджеты | используйте Jquery Mobile | |
Возможности и гибкость | 1/10 | |
Код | html +JS | |
Потребляемая память | 4-9 мб | |
Время загрузки | 1.08 – 1.49 сек | |
Время написания демо | 2.5 часа |
Вывод: Удобна для сайта, но для продвинутой админки никуда не годится. Зато бесплатна.
Zino UI
Zino UI — еще одна библиотека, базирующаяся на Jquery. Если вы работали с Jquery UI, то разобраться в ней не проблема, названия методов почти идентичны, только с приставкой zino. В принципе, с ее помощью реально написать админку, так как она содержит все недостающие компоненты. Помимо этого, библиотека умеет работать с SVG, строить графики (около 30 видов графиков). Если вы не хотите возиться с html/js, то в коробке с библиотекой идет PHP класс, позволяющий создавать графический интерфейс на PHP. На момент написания статьи эта библиотека – пока самая шустрая из всех, которые упомянуты и будут упомянуты во второй части. Если будете использовать ее в коммерческом проекте, то обратите внимание на смешную цену.
Лицензия: | Commercial, 19$, для открытых проектов – GPL | Демо |
---|---|---|
Кол-во виджетов: | 25 | |
Размер демо кода | 7.83 кб | |
Сложность освоения | Очень легко. | |
Скорость разработки | Быстро | |
Мобильные виджеты | нет | |
Возможности и гибкость | 3/10 | |
Код | html +JS, PHP | |
Потребляемая память | 3-5 мблучший результат | |
Время загрузки | 0. 73 – 0.83лучший результат | |
Время написания демо | 1.2 часа |
Вывод: Шустрая, умеет работать с графиками. Отличная замена Jquery UI.
Jquery Easy UI
Jquery Easy UI — очень хороший, но почему-то мало кому известный проект. Он идеально подойдет для новичков. В теории админку можно написать без единой строчки js кода. Все свойства виджетов можно передать через атрибут data-options, а можно прописывать их в javascript-коде.
Лично я работал с ней достаточно долго, и могу точно сказать: она легка в освоении и удобна, для крупных проектов нужно писать много “велосипедного” кода, в то время как в старших братьях это все решается прописыванием 2-3 опций.
В запасе у библиотеки 52 виджета. Есть отдельный ряд виджетов для мобильных приложений. На официальном сайте есть конструктор стилей. Для Java-кодеров есть возможность писать на Java, используя DWR Loader. Для PHP разработчиков, не любящих возится с html и javascript, есть неофициальные компоненты для интеграции библиотеки в Yii.
Из недостатков: есть и ряд функций, которые не задокументированы вообще. Также можно отметить некую глючность библиотеки. Порой в попытках исправить тот или иной глюк приходилось лезть в исходный код библиотеки и ругаться, так как львиная доля кода зачем-то обфускацирована.
Лицензия: | Commercial, 499$, для открытых проектов – GPL | Демо |
---|---|---|
Кол-во виджетов: | 52 | |
Мобильные виджеты | ||
Размер демо кода | 4.58 кб | |
Сложность освоения | Очень легко. | |
Скорость разработки | В средних проектах – очень быстро, в сложных — средне | |
Возможности и гибкость | 4/10 | |
Код | html, html+JS, Java, PHP (Yii) лучший результат | |
Потребляемая память | 4. 4-9 мб | |
Время загрузки | 1.4 – 1.8 сек | |
Время написания демо | 25 минут лучший результат |
Вывод: Малая, да очень мощная библиотека. Идеально подойдет для новичков.
jQWidgets
jQWidgets — пожалуй, самый сложный инструмент для создания ui, базирующийся на JQuery. На сайте огромное количество примеров интеграции с такими библиотеками, как Angular, Angular 2, Knockout. Продемонстрирована возможность писать клиентский код на Typescript. Есть демки интеграции с серверными языками: PHP, Java, ASP.net. Сама библиотека содержит около 60 виджетов. Одних только видов Layout — 3 штуки. Умеет строить графики (около 30 видов). Все виджеты относительно гибкие, обладают большим количеством методов, свойств, событий. Конечно, все эти фичи сильно отразились на производительности самой библиотеки. Среди всех вышеописанных она самая прожорливая.
Помимо этого, банальное отсутствие нормального поиска по документации на сайте, помноженное на сложность и нагроможденность кода, приводит к тому, что разработка админки становится делом непосильным.Лицензия: | Commercial, 199$, для открытых проектов – GPL | Демо |
---|---|---|
Кол-во виджетов: | 60 | |
Мобильные виджеты | 60 | |
Размер демо кода | 10.3 кб | |
Сложность освоения | сложно | |
Скорость разработки | средне | |
Возможности и гибкость | 6/10 | |
Код | html+JS | |
Потребляемая память | 8 -20 мб | |
Время загрузки | 2 – 2.6 сек | |
Время написания демо | 4.5 часа |
Вывод: Самая мощная из текущего обзора, но в тоже время достаточно сложная и ресурсоемкая библиотека.
Также достойны внимания
W2ui– микроскопическая библиотека для построения интерфейса, основанная на jquery. Содержит всего 8 компонентов (layout, таблица, формы, тулбар, вкладки, формы, меню, дерево). Выглядит отлично, не тормозит. Рекомендуется для небольших проектов.
primeUI — более расширенная версия JQuery UI с деревом и таблицами. Имеет более 40 разных виджетов и более 30 тем оформления. Код можно писать в связке html + js, или на чистом html, используя предназначенные для этого нестандартные теги. Cама библиотека является примочкой для более крупного проекта PrimeFaces, который позволяет писать все это дело на Java.
На этом пока что всё. Это первая статья, мне интересна обратная связь и реакция. Если не закидаете помидорами, то во второй части я продолжу обзор библиотек, базирующихся на Jquery, но уже от компаний, занимающихся интерфейсом профессионально. Вас ждет обзор и демо примеры таких библиотек, как: Kendo UI, Wijmo, IgniteUI, Essensial Js, DevExtreme, ShieldUI.
PS: Примеры из первой можно скачать по ссылке. Там же скриншоты и дампы замеров производительности.
PPS. Список библиотек, которые будут/были описаны
Часть 1:
- JqueryUI
- Zino UI
- EasyUI
- jQWidgets
- W2ui
- primeUI
Часть 2:
- IgniteUI
- Wijmo
- Kendo UI
- Syncfusion Essensial Js
- ShieldUI
- devExtreme
Не отсортировано:
- AlloYUI
- Dojo
- ExtJs
- Qooxdoo
- Smartclient
- Webix
- dhtmlx
- Openui5
- RedUI
- Backbase
- CrossUI
- SproutCore
- Rialto
- Bindows
Не будет описано:
- YUI (устарела)
- Mochaui (устарела)
- Openrico (устарела)
- Lidorsystems (пока не решил, убого выглядит)
- Rightjs (пока не решил, мало виджетов)
- EnyoJS (WTF? для TV?)
Также не будет описано angularUI, elemental-ui, react-bootstrap и пр. Иначе статья затянется до бесконечности…
Возможно, я что-то не упомянул, прошу дополнить в комментариях.
Часть 2
Библиотека jQuery UI
Опубликовано от @altarasov — Оставить комментарий JavaScript-библиотека jQuery UI помогает улучшать пользовательский интерфейсСуществует большое количество библиотек, помогающих вести разработку пользовательского интерфейса
jQuery UI Dialogs — Диалоговые окна- jQuery UI http://jqueryui. com
- Sencha Ext JS https://www.sencha.com/products/extjs/
- Bootstrap http://getbootstrap.com/
- jQuery Mobile http://jquerymobile.com/
- Zino UI Framework http://zinoui.com/
- jQuery EasyUI http://www.jeasyui.com/index.php
- jQWidjets http://www.jqwidgets.com/
- Kendo UI http://www.telerik.com/kendo-ui
jQuery UI — библиотека, помогающая изменять интерфейс веб-страниц, реализовывать интерактив в веб-приложениях. Возможности библиотеки описываются четырьмя блоками: взаимодействия (Interactions), виджеты/элементы управления (Widgets), эффекты (Effects), утилиты (Utilities). Каждый из блоков содержит список возможных применений.
Взаимодействия (Interactions) jQuery UI
Представляют набор
- Draggable/Перемещаемость — перетаскивать HTML-элементы мышкой
- Droppable/»Приземляемость» — назначить HTML-элемент, на который будет приземляться перетаскиваемый элемент
- Resizable/Изменение размера — изменяет размер HTML-элемента при помощи мыши
- Selectable/Выделяемость — использует мышь для выделения элемента или группы элементов
- Sortable/Сортируемость — позволяет сортировать элементы на странице
Виджеты/элементы управления (Widgets) jQuery UI
jQuery UI Tabs- ВкладкиПредставляют набор
- Accordion/Аккордеон — набор схлопывающихся элементов
- Autocomplete/Автозавершение — автодополнение ввода по первым символам
- Button/Кнопка — кнопки на странице
- Datepicker/Календарь — выбор даты из календаря
- Dialog/Диалоговое окно — создание диалоговых окон
- Menu/Меню — выпадающее меню
- Progressbar/Индикатор загрузки — указание степени выполнения некоторого процесса
- Selectmenu/Аналог HTML-элемента select — расширяет функциональность базового HTML-элемента
- Slider/Ползунок — выбор числа при помощи ползунка
- Spinner/Стрелки в поле ввода — для изменения значений в текстовом поле ввода
- Tabs/Вкладки — организация вкладок на странице
- Tooltip/Подсказки — организация всплывающих подсказок
Эффекты (Effects) jQuery UI
Представляют набор
- Add Class/Добавление класса — добавляет CSS-класс элементу
- Color Animation/Анимация цвета — расширение анимации jQuery
- Easing/Скорость анимации — изменение темпа анимации
- Effect/Эффекты — анимационные эффекты
- Hide/Сокрытие — сокрытие элемента с использованием анимационных эффектов
- Remove Class/Удаление класса — Удаление CSS-класса
- Show/Показ — появление элемента с использованием анимационных эффектов
- Switch Class/Переключатель класса — поочередно включает один и второй классы
- Toggle/Переключатель — поочередно отображает и прячет элемент с использованием анимационных эффектов
- Toggle Class/Переключатель класса — поочередно добавляет и удаляет класс из элемента (в отличие от Switch Class работает с одним классом)
Утилиты (Utilities) jQuery UI
Представляют набор
- Position/Позиционирование — управление позиционированием элемента относительно документа, окна браузера, других элементов
- Widget Factory/Фабрика виджетов — позволяет использовать все виджеты jQuery UI на странице
Загрузка и установка jQuery UI
Загрузить библиотеку можно с сайта разработчиков http://jqueryui. com/, со страницы http://jqueryui.com/download/ (предварительно выбрав набор нужных компонентов jQuery UI), CDN-хранилища сторонних сайтов (https://tech.yandex.ru/jslibs/, https://developers.google.com/speed/libraries/). В любом случае нужно прописать элементы link и script, чтобы были подключены стили библиотеки и ее JavaScript-код.
Пример подключения<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js"></script>
<link rel="stylesheet" href="https://ajax.googleapis.com/ajax/libs/jqueryui/1.11.4/themes/smoothness/jquery-ui.css">
<script src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.11.4/jquery-ui.min.js"></script>
Оформление jQuery UI
Для оформления библиотеки можно использовать один из готовых наборов (тем) или сформировать свое оформление на странице оформителя тем (ThemeRoller). Созданная/скачанная тема будет представлять собой папку с CSS, которую будет нужно разместить рядом с основным кодом библиотеки. Не забудьте проверить адрес подключения новых стилей в link
Рубрика: Курсы JavaScript
Метки jQuery, UI
демонстраций и примеров jQuery с исходным кодом HTML5/JavaScript
Сетка
Сетка позволяет пользователям просматривать, редактировать, фильтровать, группировать, сортировать, выбирать и экспортировать табличные данные.
- гистограммы
Диаграмма
Диаграммы позволяют пользователям визуализировать и выводить графические представления данных.
- планировщик
Планировщик
Планировщик позволяет пользователям просматривать и редактировать свой календарь событий.
- выпадающий список
Раскрывающийся список
DropDownList позволяет пользователям выбрать одно значение из предопределенного списка.
- DateRangePicker
DateRangePicker
DateRangePicker позволяет пользователю выбирать диапазон дат из календаря или посредством прямого ввода.
- редактор
Редактор
Редактор позволяет создавать богатый текстовый контент через интерфейс WYSIWYG.
Предыдущий
Панель администратора
Панель истории акций
ЗАПУСК ОБРАЗЦАНачальная загрузка пользовательского интерфейса Кендо
ЗАПУСК ОБРАЗЦАОдностраничное приложение
ЗАПУСК ОБРАЗЦАОбразец диаграммы
ЗАПУСК ОБРАЗЦАПриборная панель «Борей»
ЗАПУСК ОБРАЗЦАСледующий
Новичок в пользовательском интерфейсе Kendo для jQuery?
Kendo UI для jQuery — это библиотека пользовательского интерфейса профессионального уровня с более чем 110 компонентами для создания современных и многофункциональных приложений. Чтобы попробовать его, подпишитесь на бесплатную 30-дневную пробную версию.
Скачать бесплатную пробную версию
Каркас
- Источник данных
- API рисования
- Глобализация
- Интеграция с библиотеками JS
- МВВМ
- Одностраничное приложение
- Шаблоны
- Сенсорные события
Связаться со службой поддержки
Пользовательский интерфейс jQuery— обзоры, плюсы и минусы
Домашняя страница
Приложения и данные
Библиотеки
Библиотеки пользовательского интерфейса Javascript
Специально подобранный набор взаимодействий пользовательского интерфейса, эффектов, виджетов и тем, созданных на основе библиотеки JavaScript jQuery
jqueryui
jqueryui. com
Stacks38.4K
Followers11.5K
+ 1
Голосов897
Что такое jQuery UI?
Независимо от того, создаете ли вы интерактивные веб-приложения или просто хотите добавить средство выбора даты в элемент управления формы, пользовательский интерфейс jQuery — идеальный выбор.
Пользовательский интерфейс jQuery — это инструмент из категории Javascript UI Libraries технического стека.
jQuery UI — это инструмент с открытым исходным кодом с 11.1K звезды GitHub и 5.3K форков GitHub. Вот ссылка на открытый репозиторий jQuery UI на GitHub
Кто использует jQuery UI?
Компании
24518 Компании, как сообщается, используют jQuery UI в своих технических стеках, включая LinkedIn, Accenture, и Somfilms.net .
LinkedIn
Accenture
Somfilms.
netBooking.com
Walmart
Barogo
Effedupmovies.com
ROBLOX
MasterCard
Developers
13591 developers on StackShare have stated that they используйте jQuery UI .
Эвандро Магальяйнс
Ктра
Луберт
Hitalo Silva
TimeTicket
yoshi-iketani
Adphorus
Malachai
AdManager
jQuery UI Integrations
Ant Design
DNN
Mobiscroll
Плюсы пользовательского интерфейса jQuery
Компоненты пользовательского интерфейса
Кроссбраузерность
Это jquery
Открытый исходный код
Widgets
Plugins
Popular
Datepicker
Great community
DOM Manipulation
Themes
Some good ui components
jQuery UI Alternatives & Comparisons
What are some alternatives to jQuery UI?
Bootstrap
Bootstrap — это самая популярная среда HTML, CSS и JS для разработки адаптивных мобильных проектов в Интернете.
jQuery
jQuery — это кросс-платформенная библиотека JavaScript, предназначенная для упрощения сценариев HTML на стороне клиента.
Многие люди используют React как V в MVC. Поскольку React не делает никаких предположений об остальном стеке ваших технологий, его легко опробовать на небольшой функции в существующем проекте.
jQuery Mobile
jQuery Mobile — это система пользовательского интерфейса на основе HTML5, предназначенная для создания адаптивных веб-сайтов и приложений, доступных на всех смартфонах, планшетах и настольных устройствах.
AngularJS
AngularJS позволяет вам писать клиентские веб-приложения, как если бы у вас был более умный браузер. Он позволяет вам использовать старый добрый HTML (или HAML, Jade и их друзей!) в качестве языка шаблонов и позволяет расширить синтаксис HTML для четкого и лаконичного представления компонентов вашего приложения. Он автоматически синхронизирует данные из вашего пользовательского интерфейса (представления) с вашими объектами JavaScript (моделью) посредством двусторонней привязки данных.