1С + javascript + HTML

17.01.25

Разработка - Работа с интерфейсом

Обработка позволяет отобразить в виде диаграммы иерархический справочник с картинками средствами 1С и javascript в поле html. Данная статья в ознакомительных целях.

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
1С + javascript + HTML:
.cf 123,21Kb
5 1 850 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

В статье мы передадим данные в JavaScript и получим результат обратно в поле HTML.

1. Создадим пустую конфигурацию и добавим два справочника: "Организации", "Подразделения". Справочник "Подразделения" иерархический с видом иерархии "Иерархия элементов" и реквизитами "Порядок", "Организация"

2. Создадим обработку для работы с данными. Добавим реквизит объекта "Диаграмма" с типом строка. В свойствах формы укажем вид "Поле HTML документа.

3. Добавим команду "Сформировать"(Нарисовать) и в модуле формы добавим несколько процедур.

&НаКлиенте
Процедура Нарисовать(Команда)
	Если Объект.Организация = ПредопределенноеЗначение("Справочник.Организации.ПустаяСсылка") Тогда
		Возврат;
	КонецЕсли;     
	
	
	//Вариант3
	Объект.Диаграмма = 
	"<html>  
	|<head>
	|<style>" + ПолучитьСкрипт(1) + "</style>
	|<style>" + ПолучитьСкрипт(2) + "</style>
	|<script>" + ПолучитьСкрипт(3) + "</script>
	|<script>" + ПолучитьСкрипт(4) + "</script>
	|
	|<script>
	|jQuery(document).ready(function() {
	|	$(""#org"").jOrgChart({
	|	chartElement : '#chart',
	|	dragAndDrop  : true
	|	});
	|	});
	|	</script>
	|</script> 
	|</head>
	|
	|<body> 
	|<ul id=""org"" style=""display:none"">" + Обход(Объект.Организация) + "
	| 
	|</ul>
	|<div id=""chart"" class=""orgChart""></div>
	|
	|</body>
	|</html>";
	
	
КонецПроцедуры

4. С помощью функции ПолучитьСкрипт(Вид) мы получаем JavaScript, который сохранили в макете обработки. 

Функция ПолучитьСкрипт(Вид)
	Обработка = РеквизитФормыВЗначение("Объект");
	Скрипт = "";
	Если Вид = 1 Тогда
		Скрипт = Обработка.ПолучитьМакет("jqueryjOrgChartcss").ПолучитьТекст();	
	ИначеЕсли Вид = 2 Тогда
		Скрипт = Обработка.ПолучитьМакет("customcss").ПолучитьТекст();
	ИначеЕсли Вид = 3 Тогда
		Скрипт = Обработка.ПолучитьМакет("jquerymin").ПолучитьТекст();
	ИначеЕсли Вид = 4 Тогда
		Скрипт = Обработка.ПолучитьМакет("jqueryjOrgChart").ПолучитьТекст();
	КонецЕсли;
	Возврат Скрипт;
КонецФункции

5. Далее обходим все элементы справочника "Подразделения" функциями "Обход" и "ПолучитьВсеПозицииДерево"

Функция Обход(Организация)
	ПозицииТекст = "";
		
	Дерево = ПолучитьВсеПозицииДерево(Организация); 
	ОбойтиРекурсивно(Дерево);
	Возврат ПозицииТекст;
КонецФункции
Функция ПолучитьВсеПозицииДерево(Организация)
	
	Дерево = Новый ДеревоЗначений;	
	Запрос = Новый Запрос;
	Запрос.Текст = 
	"ВЫБРАТЬ
	|	Подразделения.Ссылка КАК Ссылка
	|ИЗ
	|	Справочник.Подразделения КАК Подразделения
	|ГДЕ
	|	Подразделения.Организация = &Организация
	|	И Подразделения.ПометкаУдаления = ЛОЖЬ
	|
	|УПОРЯДОЧИТЬ ПО
	|	Подразделения.Порядок ИЕРАРХИЯ";
	Запрос.УстановитьПараметр("Организация",Организация);
	Дерево = Запрос.Выполнить().Выгрузить(ОбходРезультатаЗапроса.ПоГруппировкамСИерархией);
		
	Возврат Дерево;
	
КонецФункции 

6. Формируем html

Процедура ОбойтиРекурсивно(Дерево) 
	ОткрТег = "<li>";
	ЗакрТег = "</li>";
	ОткрТегПод = "<ul>";
	ЗакрТегПод = "</ul>";
	
	Сч = 0;
	Для Каждого Строка Из Дерево.Строки Цикл    
		Если Строка.ОтображатьКартинку = Ложь Тогда
			ПозицииТекст = ПозицииТекст + ОткрТег + Строка.Ссылка;
		Иначе			
			ДвоичныеДанные = Строка.Изображение.Получить();
			Ссылка = ПоместитьВоВременноеХранилище(Двоичныеданные);  					
			ПозицииТекст = ПозицииТекст + ОткрТег + "<img src=""" + Ссылка + """>";
		КонецЕсли;
		Если Строка.Строки.Количество()>0 Тогда 							
			ПозицииТекст = ПозицииТекст + ОткрТегПод;
			ОбойтиРекурсивно(Строка); 
			ПозицииТекст = ПозицииТекст + ЗакрТегПод; 
		Иначе
			ПозицииТекст = ПозицииТекст + ЗакрТег;  			
		КонецЕсли; 
		Сч = Сч + 1;
	КонецЦикла; 
КонецПроцедуры 

7. В скрипте JavaScript можно изменить цвет, оформление элементов. Добавлено возможность отображения картинок

Тестирование проводилось на платформе 1С 8.3.17.

Вступайте в нашу телеграмм-группу Инфостарт

обработка html javascript

См. также

Работа с интерфейсом Анализ учета Мониторинг 1С:Предприятие 8 1С 8.3 1C:Бухгалтерия 1С:Бухгалтерия 3.0 1С:Библиотека стандартных подсистем 1С:ERP Управление предприятием 2 1С:Управление холдингом 1С:Зарплата и Управление Персоналом 3.x 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Управление торговлей 11 Платные (руб)

Создайте свой функциональный интерфейс в любой конфигурации 1С с помощью расширения Infostart Dashboard. Настраивайте панели виджетов с метриками, индикаторами и показателями на начальном экране. Узнайте возможность внедрения подсистемы у себя в конфигурации с помощью бесплатной обработки "Анализ внедрения подсистемы 1С Infostart Dashboard"!

28800 руб.

27.03.2025    56399    31    25    

45

Разработка Инструментарий разработчика Работа с интерфейсом Адаптация типовых решений Нейросети 1C:Бухгалтерия 1C:ERP 1С:ЗУП 1С:КА 1С:УНФ 1С:УТ 1С:Розница 1С:ДО 1С:ERP Управление предприятием 2 Платные (руб)

Разработка "Дизайнер форм 1С" реализована в виде расширения 1С и является универсальным инструментом для разработки прототипа форм с целью демонстраций, технических заданий и т.д. Без участия разработчика с возможностью экспорта в файл внешней обработки и генерации формы используя искусственный интеллект.

36000 руб.

28.08.2025    2701    1    2    

4

Работа с интерфейсом Системный администратор Программист 1С:Предприятие 8 1C:Бухгалтерия Платные (руб)

Расширение «Динамическое управление доступом к элементам форм объектов 1С8» предназначен для обеспечения возможности оперативного управления видимостью и доступностью элементов форм документов и справочников продуктов фирмы «1С» «1С:Предприятие 8». Решение универсальное, встраивается в любую конфигурацию с минимальными доработками, что позволяет без проблем обновлять типовые решения.

6000 руб.

14.01.2016    58239    20    25    

46

Работа с интерфейсом Программист 1С:Предприятие 8 1C:Бухгалтерия 1С:ERP Управление предприятием 2 Платные (руб)

Обработка предназначена для создания и управления дашбордами (виджетами) в 1С.

5160 руб.

29.06.2020    22865    32    6    

51

Работа с интерфейсом Программист 1С:Предприятие 8 1C:Бухгалтерия Россия Платные (руб)

Редактор графов в 1С - внешний отчет, который формирует графы на основе таблицы значений, используя рисунки табличного документа. Есть возможность добавления, редактирования объектов графа и выгрузки результата в таблицу значений.

5040 руб.

06.10.2020    12852    8    8    

14

Работа с интерфейсом Программист Стажер 1С:Предприятие 8 Бесплатно (free)

Это инструкция по дизайну форм в среде 1С. Гайд охватывает рекомендации и стандарты для оптимизации пользовательского интерфейса. В гайде содержатся указания по использованию элементов интерфейса, включая как основные, так и продвинутые аспекты. Предоставляются также примеры и антипримеры для наглядного понимания принципов дизайна

20.08.2024    43395    mrXoxot    44    

138

Работа с интерфейсом Программист 1С:Предприятие 8 Бесплатно (free)

Пример простого и симпатичного прогресс-бара в динамическом списке, без картинок, используя редактирование запроса.

27.05.2024    24834    smielka    38    

111
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. ImHunter 341 13.06.23 12:24 Сейчас в теме
Под капотом jOrgChart?... Как-то бы немного подробнее про это. Почему именно эта библиотеке, что еще можно сделать на ней, еще про что-нить.
2. ImHunter 341 15.06.23 10:42 Сейчас в теме
Мда, еще интрига в строках вида
Скрипт = Обработка.ПолучитьМакет("jqueryjOrgChartcss").ПолучитьТекст()

Типа, качайте за sm, и тогда там что-то увидите.
Для отправки сообщения требуется регистрация/авторизация