Программное формирование форматированной строки в стиле html+inline CSS

18.11.17

Разработка - Инструментарий разработчика

Если вам приходилось работать с форматированными строками программно, то вы знаете, какая это боль. Данное решение облегчает программное формирование таких строк.

Файлы

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

Наименование Скачано Купить файл
(только для физ. лиц)
Программное формирование форматированной строки в стиле html+inline CSS:
.epf 9,02Kb
72 1 850 руб. Купить

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

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

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

Программное формирование форматированной строки в стиле html+inline CSS

В 1С:Предприятие 8.3 появились форматированные строки. Программная работа с такими строками не очень удобная. Например, нужно вывести надпись

Штатными средствами это делается так

ЧастиСтроки = Новый Массив;
ЧастиСтроки.Добавить("Задача ");
ЧастиСтроки.Добавить(Новый ФорматированнаяСтрока("сделай что-нибудь", Новый Шрифт("Consolas"),, Новый Цвет(234, 245, 255)));
ЧастиСтроки.Добавить(" назначена исполнителю ");
ЧастиСтроки.Добавить(Новый ФорматированнаяСтрока("ivanov@gmail.com", Новый Шрифт("Consolas"),, WebЦвета.ЛососьСветлый));
ЧастиСтроки.Добавить(".");
	
Элементы.Декорация1.Заголовок = Новый ФорматированнаяСтрока(ЧастиСтроки);

Правда ведь не очень удобно. А что если нам нужно поддерживать локализацию?

А вот как это можно сделать с помощью этого проекта

Элементы.Декорация1.Заголовок = ФорматированнаяСтрока(
  НСтр("ru = 'Задача <span style=""background-color: #eaf5ff; font-family: consolas"">сделай что-нибудь</span> назначена исполнителю <span style=""font-family: consolas; color: ЛососьСветлый"">ivanov@gmail.com</span>'"));

Возможности

Поддерживаются все возможности объекта ФорматированнаяСтрока. В том числе работает на клиенте. Предназначена для работы с версией платформы 8.3.10 и выше.

Цвет текста

<span style="color: #fff">Цветной текст</span>

Значение цвета можно задать 3 способами:

  • имя цвета из коллекции WedЦвета: red или желтый
  • полное шестнадцатеричное представление: #aabbff
  • сокращенное шестнадцатеричное представление: #abf

Цвет фона

<span style="background-color: #fff">Текст на цветном фоне</span>

Значение цвета задается аналогично цвету текста.

Шрифт текста

Жирный

<span style="font-weight:bold">Жирный текст</span>

или

<b>Жирный текст</b>

Наклонный

<span style="font-style: italic">Наклонный текст</span>

или

<i>Жирный текст</i>

Подчеркнутый

<span style="text-decoration: underline">Подчеркнутый</span>

Зачеркнутый

<span style="text-decoration: line-through">Зачеркнутый текст</span>

Размер

<span style="font-size: 18">Меняем размер шрифта</span>

Имя шрифта

<span style="font-family: consolas">Меняем шрифт</span>

Картинка

<img src="Календарь">

Можно вывести любую картинку из коллекции БиблиотекаКартинок, указав ее имя.

Гиперссылка

<a href="/redirect.php?url=aHR0cDovL3lhLnJ1" style="font-weight:bold; color: salmon">Цветная жирная ссылочка</a>.

 

См. также

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта 1С v8.3 Управляемые формы Запросы Система компоновки данных Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

15500 руб.

02.09.2020    196032    1085    409    

1006

SALE! 15%

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP, УНФ, КА и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку одновременно в несколько потоков. А так же автоматически, без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 7140 руб.

20.08.2024    32382    197    104    

187

Пакетная печать Печатные формы Инструментарий разработчика Программист 1С v8.3 Запросы 1С:Зарплата и кадры бюджетного учреждения 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Платные (руб)

Инструмент, позволяющий абсолютно по-новому взглянуть на процесс разработки печатных форм. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и "прозрачность" разработки, а также навести порядок в многообразии корпоративных печатных форм.

22200 руб.

06.10.2023    22754    62    19    

90

Инструменты администратора БД Инструментарий разработчика Роли и права Программист 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

Расширение позволяет без изменения кода конфигурации выполнять проверки при вводе данных, скрывать от пользователя недоступные ему данные, выполнять код в обработчиках. Не изменяет данные конфигурации, легко устанавливается практически на любую конфигурацию на управляемых формах.

15000 руб.

10.11.2023    15504    66    33    

84

Инструментарий разработчика Программист 1С v8.3 Платные (руб)

Инструмент для написания и отладки кода в режиме «1С:Предприятие». Представляет собой консоль кода с возможностью пошаговой отладки, просмотра значений переменных любых типов, использования процедур и функций, просмотра стека вызовов, вычисления произвольных выражений на встроенном языке в контексте точки останова, синтаксического контроля и остановки по ошибке. В консоли используется удобный редактор кода с подсветкой, контекстной подсказкой, возможностью вызова конструкторов запроса и форматной строки.

9360 руб.

17.05.2024    32930    112    48    

155

Инструментарий разработчика Программист 8.3.14 Россия Платные (руб)

Расширение для конфигурации “Конвертация данных 3”. Добавляет подсветку синтаксиса, детальную контекстную подсказку, глобальный поиск по коду.

20000 руб.

07.10.2021    20137    8    32    

44

Инструментарий разработчика Программист 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

Восстановление партий или взаиморасчетов, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

5000 руб.

07.02.2018    106291    248    100    

313
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. infosoft-v 985 21.11.17 09:00 Сейчас в теме
Как же классно! Спасибо большое.
2. zarucheisky 22.11.17 12:04 Сейчас в теме
Кстати сказать, при преобразовании цвета в html не всегда приводит к полному шестнадцатиричному значению, а вот форматированный документ всегда так делает :)
3. SeiOkami 3587 02.12.17 13:28 Сейчас в теме
Выглядит удобно. Отложу пока на будущее)
4. NN2P 422 10.04.18 17:14 Сейчас в теме
<img src="Календарь">
Можно вывести любую картинку из коллекции БиблиотекаКартинок, указав ее имя.


Могу ошибаться, но похоже на вредный совет.
Нам нужна ссылка на картинку в ВХ, а не имя самого изображения:
( СсылкаНаКартинку = ПоместитьВоВременноеХранилище(БиблиотекаКартинок.Календарь.ПолучитьДвоичныеДанные(),УникальныйИдентификатор));
5. bonv 1589 10.04.18 22:38 Сейчас в теме
(4) Нет, в данном случае именно так как описано.
6. Dzenn 913 10.10.19 17:51 Сейчас в теме
выглядит интересно, пошёл качать ;-)
7. Ibrogim 1346 05.02.20 16:05 Сейчас в теме
Классно. На каких условиях можно использовать в своих разработках как вспомогательный инструмент ?
8. bonv 1589 06.02.20 02:15 Сейчас в теме
(7) в целом можно использовать без ограничений. Если сошлетесь, например, на эту статью, то будет здорово
9. Ibrogim 1346 06.02.20 09:32 Сейчас в теме
10. user1302156 26.06.20 10:07 Сейчас в теме
Добрый день, подскажите как исправить код, чтобы картинка выводилась в нижнем колонтитуле? Пробовала задавать и имя картинки и путь к ней, текст выводит, а вместо картинки пустота

КартинкаФорматированная= Новый ФорматированнаяСтрока(НСтр("ru = '<img src='БиблиотекаКартинок.ПодписьРуководителя'>'"));
        ТабДок.НижнийКолонтитул.ТекстСлева=" «ПОСТАВЩИК» "+ Символы.ПС + Символы.ПС + КартинкаФорматированная + "/";
11. ValeriVP 1357 24.02.21 12:14 Сейчас в теме
по мотивам этой публикации - более полная реализация: https://infostart.ru/public/1389956/
12. kalyaka 1136 09.08.21 20:55 Сейчас в теме
Жаль, что вложенные теги не обрабатываются, например вот такие:
А теперь <span style="background-color: yellow; color: red">красный текст на желтом фоне</span>
smartcoder; TigerS74; +2 Ответить
13. kalyaka 1136 10.08.21 16:15 Сейчас в теме
Есть очень короткая реализация данной задачи, следующая функция вернет форматированную строку из строки HTML:
Функция ТекстHTMLВФорматированнуюСтроку(ТекстHTML)
	ФорматированныйДокумент = Новый ФорматированныйДокумент;
	ФорматированныйДокумент.УстановитьHTML(ТекстHTML, Новый Структура);
	Возврат ФорматированныйДокумент.ПолучитьФорматированнуюСтроку();
КонецФункции
Она конечно встроенные стили не обработает, однако мой пример выше - запроста.
Работает также во всех клиентах.
comptr; smartcoder; Alias; SagittariusA; triviumfan; Поручик; ixijixi; +7 Ответить
Оставьте свое сообщение