HTA сценарии

installing-and-configuring-nut-000.pngHTA (HTML Application) – это простая технология, позволяющая создавать полезные приложения даже без знания серьезных языков программирования. Одно из мощнейших средств  — HTA или HTML Application (безбраузерные приложения), позволяет создавать Windows-приложения используя HTML, CSS и Javascript/VBscript. Сразу хочу заметить, что в этой статье используется исключительно Javascript. Думаю, помните *.bat файлы в DOS. И иногда пользуетесь: запустить что-то, скопировать автоматом. С точки зрения пользователя, созданная «программа» ничем, кроме расширения (*.hta), не отличается от любой другой программы: заголовок окна, иконка, отображение на панели задач, а самое главное никаких предупреждений при доступе к файлам компьютера. При всем этом вам не придется устанавливать никаких отдельных приложений или плагинов, достаточно Internet Explorer-а!

Создать HTA-приложение можно, просто написав HTML-страницу и сохранив ее с расширением .hta, которое обрабатывается программой mshta.exe, её задача – обеспечить связь программы с браузером. Так как такие приложения используют движок браузера, то они объединяют в себе все их возможности – их объектную модель, разметку страницы (HTML), каскадные листы стилей (CSS), скрипты (VBS и JS). Также на такие приложения не накладывается ограничения безопасности – они работают как любой исполняемый файл.

Самый простой код HTA-программы. Скопируйте его в любой текстовый редактор и сохраните с расширением .hta.  Запустите.

Перспективы HTA в моей работе.


HTA – HTML Applications. Тот, кто знает возможности VBScript или JScript, понимает, что основные конструкции и файловая система – у нас в руках. Тот, кто знает ООП (объектно-ориентированное программирование), понимает, что управление Word-ом, Excel-ем, многими другими приложениями – тоже у нас в руках. И тот, кто знает HTML (перевести?), понимает, что всю эту компанию мы можем классно оформить и заставить пахать. Вот что значит – HTA.

Параметры тега HTA:Application позволяют управлять видом созданным приложения. Если тег и/или параметры не заданы, то значения параметров назначаются по-умолчанию.

Параметр в HTML в JScript Значение(я)
(по умолчанию)
Обозначение
APPLICATIONNAME applicationName строка
(нет)
Уникальное имя приложения.
INNERBORDER innerBorder yes, no
(yes)
Наличие внутреннего бордюра.
BORDERSTYLE borderStyle normal, complex, raised, static, sunken
(normal)
Внутренний тип бордюра.
BORDER border thick, dialog, thin, none
(thick)
Наружный тип бордюра.
CAPTION caption yes, no
(yes)
Наличие заголовка.
Нет commandLine Только для чтения.
(полный путь к данному “*.hta”)
Содержимое командной строки.
CONTEXTMENU contextMenu yes, no
(yes)
Контекстное меню при клике правой кнопкой мыши.
SELECTION selection yes, no
(yes)
Возможность выделения текста внутри HTA.
ICON icon URL
(нет)
Путь к иконке (*.ico).
MAXIMIZEBUTTON maximizeButton yes, no
(yes)
Наличие кнопки «развернуть».
MINIMIZEBUTTON minimizeButton yes, no
(yes)
Наличие кнопки «свернуть».
SCROLL scroll yes, no, auto
(yes)
Наличие скроллинга.
SCROLLFLAT (IE 5.5+) scrollFlat yes, no
(no)
Cтиль скроллинга.
SHOWINTASKBAR showInTaskBar yes, no
(yes)
Отображение в панели задач.
SINGLEINSTANCE singleInstance yes, no
(no)
Запретить запуск второго экземпляра.
SYSMENU sysMenu yes, no
(нет)
Наличие системного меню.
VERSION version строка
(нет)
Версия HTA.
WINDOWSTATE windowState normal, minimize, maximize
(normal)
Начальное состояние окна.
NAVIGABLE (IE 5.5+) navigable yes, no
(no)
Переход по ссылке произойдет в окне HTA.

Атрибуты элемента HTA:APPLICATION и свойства связанного с ним объекта DOM

applicationName идентификатор исполнения HTA-документа /*name*/
border вид обрамления окна thin, dialog, none, thick
borderStyle стиль обрамления окна complex, normal, raised, static, sunken
caption наличие заголовка окна yes/no
commandLine командная строка, с которой было запущено приложение: путь к приложению и его аргументы (только свойство) путь к текущей папке
icon значок окна, в формате ICO (32×32) /*path*/
maximizeButton наличие кнопки «восстановить» yes/no
minimizeButton наличие кнопки «свернуть» yes/no
showInTaskbar отображение документа в панели задач Windows yes/no
windowState исходный размер окна normal, minimize, и maximize
innerBorder внутренняя граница окна yes/no
navigable определяет открытие ссылки в новом окне или родительском yes/no
scroll наличие полосы прокрутки yes/no
scrollFlat 3D-вид полосы прокрутки yes/no
singleInstance невозможность открытия других окон с тем же значением applicationName yes/no
sysMenu наличие системного меню и кнопок управления окном в заголовке окна yes/no
contextMenu контекстное меню, вызываемое правой кнопкой мыши yes/no
selection разрешение выделения текста в HTA-окне yes/no
version версия HTA /*version*/

Примеры HTA [ править | править код ]


Создать HTA-приложение можно, просто написав HTML-страницу и сохранив ее с расширением .hta, которое обрабатывается программой mshta.exe, её задача – обеспечить связь программы с браузером. Так как такие приложения используют движок браузера, то они объединяют в себе все их возможности – их объектную модель, разметку страницы (HTML), каскадные листы стилей (CSS), скрипты (VBS и JS). Также на такие приложения не накладывается ограничения безопасности – они работают как любой исполняемый файл.

То есть при помощи HTML создается абсолютно любой пользовательский интерфейс, причем с минимальными усилиями и без каких-либо существенных ограничений, логика программы организуется кодом на Java Script или Visual Basic Script, а само приложение выходит за рамки браузера – программа на стадии выполнения ничем не будет отличаться от обычных оконных приложений для Windows – запущенное приложение будет присутствовать на панели задач, иметь собственные окно, меню и значок. Хотя здесь нужно оговориться: программа не будет видна среди запущенных приложений в диспетчере задач, единственное средство, которым можно контролировать запущенную программу – это процесс mshta.exe.

В то время, как расширение .hta указывает системе как работать с приложением, новый тег <hta:application> и аттрибуты указывают окну, как себя вести будучи приложением. Этот тег предоставляет ограниченный набор аттрибутов, управляющих всем от стиля границы окна и до программной иконки и меню. Для создания функционирующего HTA, этот тег должен быть описан внутри тега HEAD.

Элемент HTA:APPLICATION требует закрывающего тега.

Так как тэг элемента HTA:APPLICATION является пустым, он также может быть закрыт использую следующий прием.

При использовании вышеуказанного приема, прямому слэшу (/) должен предшествовать пробельный символ.

Помимо управлением окном приложения, этот тег также дает возможность обращаться к свойствам приложения из скриптов, расположенных в коде HTA-приложения. Стоит заметить, что все свойства этого тега доступны только для чтения.

Атрибут и свойство id

Определяет идентификатор объекта – уникального имени внутри файла HTA-приложения.

Атрибут и свойство applicationName

Содержит имя приложения. Свойство не имеет значения по умолчанию.

Будучи установленным в true, свойство singleInstance проверяет значение applicationName перед запуском экземпляра приложения. Чтобы проверка была успешной, значение applicationName должно быть уникальным. Можно использовать значение свойства applicationName для идентификации единственности запущенного приложения, независимо от адреса URL, используемого для доступа к нему.

Атрибут и свойство border

Содержит тип бордюра окна. Свойство border влияет на толщину бордюра и действительно только для окон HTA, у которых есть панель заголовка и сам заголовок. Устанавливая border в “None”, вы убираете панель заголовка, иконку программы, и кнопки максимизирования и минимизирования. Это свойство может быть использовано совместно со свойством borderStyle. Возможные значения:

Dialog</b?/td> Бордюр диалогового окна – пользователь не может изменить размер окна.
None Окно без бордюра.
Thick Толстый бордюр окна, плюс бордюр для изменения размера окна. (Значение по умолчанию).
Thin Тонкий бордюр окна с заголовком.

Примечание

Если не указать параметр BORDER или указать BORDER="thick", то размеры окна программы можно будет изменять при помощи мыши, в остальных же случаях, — размеры окна изменить нельзя.

Атрибут и свойство borderStyle

Содержит стиль бордюра клиентской области окна. Свойство borderStyle устанавливает стиль для бордюра содержимого окна, в то время как свойство border контролирует бордюр окна приложения. Возможные значения:

Complex Приподнятый и утопленный бордюр.
Normal Нормальный бордюр. (Значение по умолчанию).
Raised Приподнятый 3-D бордюр.
Static 3-D бордюр, обычно используемый для окон, не обрабатывающих ввод пользователя.
Sunken Утопленный 3-D бордюр.

Атрибут и свойство caption

Определяет, будет ли в окне HTML приложения отображаться панель заголовка. Заголовок приложения отображается только тогда, когда свойство caption установлено в “Yes”. Отключение свойства caption также отключит кнопки “Свернуть”, “Развернуть” и программную иконку. В этом случае нужно не забыть предоставить альтернативный способ выхода из приложения, например, кнопку “Закрыть” на форме приложения, вызывающую метод Window.Close. Возможные значения:

Yes Панель заголовка отображается. (Значение по умолчанию).
No Панель заголовка не отображается.

Свойство commandLine

Строка, которая содержит путь и параметры командной строки, которые использовались для запуска HTA-приложения. Если HTA-приложение было запущено с использованием HTTP протокола, свойство CommandLine содержит пустую строку.

Атрибут и свойство contextMenu

Определяет, появляется ли контекстное меню при нажатии на правую кнопку мыши. Возможные значения:

Yes Контекстное меню появляется. (Значение по умолчанию).
No Контекстное меню не появляется.

Атрибут и свойство icon

Определяет путь к файлу иконки, используемой в HTML приложении. HTA использует системную иконку, если значение не определено. Атрибут Icon распознаёт стандартные файлы с расширением .ico, содержащие изображение размером 32×32 пикселя, а также успешно распознаёт первую иконку из файлов “*.exe”, “*.icl” (библиотека иконок), “*.dll”, и “*.ocx”.

Атрибут и свойство innerBorder

Определяет, отображается ли внутренняя 3-D граница. Возможные значения:

Yes Внутренняя 3-D граница отображается. (Значение по умолчанию).
No Внутренняя 3-D граница не отображается.

Атрибут и свойство maximizeButton

Определяет, отображается ли кнопка “Развернуть” на панели заголовка окна HTML приложения. Чтобы отображались кнопки “Свернуть” и “Развернуть”, окно должно иметь панель заголовка (атрибут caption). Возможные значения:

Yes Кнопка “Развернуть” отображается. (Значение по умолчанию).
No Кнопка “Развернуть” не отображается.

Атрибут и свойство minimizeButton

Определяет, отображается ли кнопка “Свернуть” на панели заголовка окна HTML приложения. Чтобы отображались кнопки “Свернуть” и “Развернуть”, окно должно иметь панель заголовка (атрибут caption). Возможные значения:

Yes Кнопка “Свернуть” отображается. (Значение по умолчанию).
No Кнопка “Свернуть” не отображается.

Атрибут и свойство navigable

Определяет, в каком окне будут открываться загружаемые документы. Возможные значения:

No Будут открываться в новых окнах. (Значение по умолчанию).
Yes Будут открываться в основном окне.

Атрибут и свойство scroll

Определяет, будут ли отображаться полосы прокрутки. Возможные значения:

Yes Полосы прокрутки отображаются. (Значение по умолчанию).
No Полосы прокрутки не отображаются.
Auto Полосы прокрутки появляются только тогда, когда содержимое документа не умещается в клиентской области окна.

Атрибут и свойство scrollFlat

Определяет, в каком виде будут отображаться полосы прокрутки. Возможные значения:

Yes Полосы прокрутки двухмерные.
No Полосы прокрутки трёхмерные. (Значение по умолчанию).

Атрибут и свойство selection

Определяет, может ли содержимое документа быть выбрано мышкой или с помощью клавиатуры. Значение “No” запрещает появление контекстного меню и присвоение атрибуту contextMenu значения “Yes” не произведёт никакого эффекта. Возможные значения:

Yes Содержимое может быть выбрано. (Значение по умолчанию).
No Содержимое не может быть выбрано.

Атрибут и свойство showInTaskBar

Определяет, будет ли HTML приложение появляться на панели задач Windows. Возможные значения:

Yes Приложение отображается на панели задач. (Значение по умолчанию).
No Приложение не отображается на панели задач.

Атрибут и свойство singleInstance

Определяет, может ли быть запущенно больше одного экземпляра HTML приложения одновременно. Возможные значения:

Yes Может быть запущен только один экземпляр приложения.
No Может быть запущенно несколько экземпляров приложения одновременно. (Значение по умолчанию).

Атрибут и свойство sysMenu

Определяет, отображается ли системное меню в HTML приложении. Системное меню HTA обозначается программной иконкой в левом углу панели заголовка. Системное меню HTA показывает все команды, входящие в стандартное системное меню Windows, включая “Восстановить”, “Переместить”, “Размер”, “Свернуть”, “Развернуть”, и “Закрыть”. Возможные значения:

Yes Системное меню отображается в панели заголовка. (Значение по умолчанию).
No Системное меню не отображается в панели заголовка.

Атрибут и свойство version

Определяет номер версии HTML приложения.

Атрибут и свойство windowState

Определяет начальные размеры окна HTML приложения. Возможные значения:

Normal Размер окна – стандартный размер для Microsoft Internet Explorer. (Значение по умолчанию).
Minimize Появляется только заголовок окна на панели задач.
Maximize Окно появляется развёрнутым во весь экран.

Пример


В этом маленьком примере объединены объектная модель, разметка страницы (HTML), каскадный лист стилей (CSS), Javascript и элементы WSH.

В папке “MyHTA_files” размещаются следующие файлы:

  • text.txt- любой текстовый файл;
  • test.js- файл, содержащий только одну строку: WScript.Echo (“Hello script!”);
  • MyHTA.ico – любая иконка;
  • MyHTA.css – файл стилей;
  • MyHTA.js- файл, содержащий все скрипты.

Листинг файла “MyHTA.hta”

Листинг файла “MyHTA_files\MyHTA.js”

Листинг файла “MyHTA_files\MyHTA.css”

 

Один комментарий для “HTA сценарии

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *