Qooxdoo - Qooxdoo
Веб-браузер с приложением qooxdoo | |
Стабильный выпуск | 5.0.2 / 9 января 2017 г. |
---|---|
Репозиторий | |
Тип | Фреймворк приложения JavaScript |
Лицензия | LGPL, EPL |
Интернет сайт | qooxdoo |
Тема этой статьи может не соответствовать Википедии общее руководство по известности.Май 2020 г.) (Узнайте, как и когда удалить этот шаблон сообщения) ( |
qooxdoo /ˈkuksdu/ является Открытый исходный код Аякс каркас веб-приложений. Это LGPL - и / или EPL -лицензионное клиентское и независимое от сервера решение, включая поддержку профессиональных JavaScript развитие, графический интерфейс пользователя (GUI) Инструментарий и общение клиент-сервер на высоком уровне.
Рамки
qooxdoo полностью основан на классах, пытается использовать возможности объектно-ориентированный JavaScript и основан на пространства имен. Поддерживаются большинство современных браузеров, в том числе Геккон (Fire Fox, Mozilla, SeaMonkey ), Престо (Опера ), Трезубец (Internet Explorer, Реальный игрок, Winamp ), WebKit (Хром, Сафари ).[1] Он включает ссылку на API, которая автоматически создается из Javadoc -как комментарии. Среди сопутствующих инструментов есть обширный JavaScript парсер это неотъемлемая часть процесса автоматической сборки и используется для оптимизации, компресс, ссылка и развертывать обычай Приложения и создайте документацию. Интернационализация и локализация приложений поддерживаются. qooxdoo можно скачать[2] как всеобъемлющий SDK.
Набор инструментов GUI
Несмотря на то, что это чистый JavaScript-фреймворк, qooxdoo вполне соответствует инструментам GUI, таким как Qt, Стандартный набор инструментов виджетов (SWT) и другие в отношении реализации пользовательские интерфейсы. Предлагает набор виджеты напоминающие элементы собственных настольных приложений. Предусмотрена встроенная поддержка навигации с помощью клавиатуры, управления фокусом и вкладками, а также перетаскивания. Размеры могут быть заданы как статические, с автоматическим изменением размера, растяжения, процентного соотношения, взвешенного изгиба или минимального / максимального значения или даже как их комбинации. Все виджеты основаны на гибких менеджерах компоновки, которые важны для многих расширенных возможностей компоновки. Описание интерфейса выполняется программно на JavaScript для повышения производительности.
Для определения пользовательского интерфейса не требуется HTML, а стилизация интерфейса не требует Каскадные таблицы стилей (CSS). Простые темы оформления используются для стилизации цветов, значков и других визуальных свойств; они также поддерживают переключение во время выполнения ..
Объектно-ориентированного программирования
qooxdoo использует закрытую форму для определения новых классов. Конструктор глобального класса принимает два аргумента: имя нового класса и карту, которая предоставляет значения для набора предопределенных ключей, таких как 'construct' (перехватчик метода конструктора), 'statics' (для атрибутов и методов статического класса), «члены» (например, атрибуты и методы) и «деструктировать» (для деструктора). Эта (возможно, большая) карта представляет определение класса. Классы могут быть производными от других классов с помощью ключевого слова «extension».
Следующий скелет приложения дает представление о том, как это работает. Код создаст небольшое приложение с кнопкой, которая имеет всплывающую подсказку и при нажатии открывает окно предупреждения. Вы также можете запустить и отредактировать этот код на онлайн-площадке:[3]
qx.Учебный класс.определять("custom.Application",{ продлевать : qx.заявление.Автономный, члены : { главный : функция() { это.основание(аргументы); // Создать кнопку вар button1 = новый qx.ui.форма.Кнопка(«Первая кнопка», "icon / 22 / apps / internet-web-browser.png"); // Документ - это корень приложения вар док = это.getRoot(); // Добавляем кнопку в документ с фиксированными координатами док.Добавить(button1, {оставили: 100, верх: 50}); // Присоединяем всплывающую подсказку button1.setToolTip(новый qx.ui.всплывающая подсказка.Подсказка("Хорошая подсказка", "icon / 32 / status / dialog-information.png")); // Добавляем слушателя событий button1.addListener("выполнять", функция(е) { тревога("Привет, мир!"); }); } }});
Интерфейсы и миксины определены и используются аналогичным образом.
Аякс
Будучи клиентским и независимым от сервера решением, проект qooxdoo включает в себя необязательные RPC реализации сервера (в настоящее время в Ява, PHP, Perl и Python ) для демонстрации взаимодействия клиент-сервер. Абстрактный транспортный уровень поддерживает очереди, таймауты и реализации через XMLHttpRequest, Iframe и скрипты. Как и остальная часть qooxdoo, этот уровень основан на программировании на основе событий для упрощения асинхронный коммуникация.
Смотрите также
Рекомендации
- ^ "Требования qooxdoo". Получено 2 февраля 2011.
- ^ "Страница загрузки qooxdoo". Получено 2 февраля 2011.
- ^ "Детская площадка". Получено 2 февраля 2011.
Источники
- Демо
- Справочник по API
- Страница проекта Sourceforge
- Краткое видео на Ajaxian.com
- Критический обзор TechRepublic в Archive.today (Архивировано 2 января 2013 г.)
- Обзор на HTMLGoodies