Управляемая форма для замены Таблица.ВыбратьСтроку()

09.03.16

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

В управляемых формах убрали возможность использовать "ВыбратьСтроку()". К статье приложена управляемая форма в обработке, которая поможет решить данную проблему. Просто добавьте форму в общие и вызывайте из любого объекта конфигурации

Файлы

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

Наименование Скачано Купить файл
УФТаблицаДляВыбора.epf
.epf 7,15Kb
53 1 850 руб. Купить

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

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

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

Так уж получилось, что в 1С посчитали лишним метод "ВыбратьСтроку()" для управляемых форм. Мне надоело делать под каждую таблицу отдельную управляемую форму, поэтому была сделана универсальная управляемая форма, которая подойдет практически под любой случай. Я помещаю эту форму в общие формы и вызываю в нужное время с нужными параметрами.

	ТекстЗапроса = "ВЫБРАТЬ
	               |	ДополнительноеСоглашение.Ссылка,
	               |	ДополнительноеСоглашение.Проведен,
	               |	ДополнительноеСоглашение.Номер,
	               |	ДополнительноеСоглашение.Дата,
	               |	ДополнительноеСоглашение.Тип
	               |ИЗ
	               |	Документ.ДополнительноеСоглашение КАК ДополнительноеСоглашение
	               |ГДЕ
	               |	ДополнительноеСоглашение.Договор = &Договор";
				   
	ПараметрыЗапроса = Новый СписокЗначений;
	ПараметрыЗапроса.Добавить(Объект.Ссылка, "Договор");
	
	ЗаголовокФормы = "Дополнительные соглашения по договору";
	
	ОформлениеТаблицы = Новый СписокЗначений;
	ОформлениеТаблицы.Добавить(Новый Структура("Видимость, Ширина, Заголовок", Ложь, Неопределено, Неопределено), "Ссылка");
	ОформлениеТаблицы.Добавить(Новый Структура("Видимость, Ширина, Заголовок", Неопределено, 5, Неопределено), "Проведен");
	ОформлениеТаблицы.Добавить(Новый Структура("Видимость, Ширина, Заголовок", Неопределено, Неопределено, "Тип допсоглашения"), "Тип");
	
	Если ТекущийРежимЗапуска() = РежимЗапускаКлиентскогоПриложения.УправляемоеПриложение Тогда
		РежимОкна = 0;
	Иначе
		РежимОкна = 2;
	КонецЕсли;
	
	ФорматРезультата = "Ссылка";
	
	ИмяСобытия = "СписокДопСоглашений" + Строка(Объект.Ссылка.УникальныйИдентификатор());
	
	ЗакрыватьФормуПриВыборе = Истина;
	
	ПараметрыФормы = Новый Структура("ТекстЗапроса, ПараметрыЗапроса, ЗаголовокФормы, ОформлениеТаблицы, РежимОкна, ФорматРезультата, ИмяСобытия, ЗакрыватьФормуПриВыборе",
	ТекстЗапроса, ПараметрыЗапроса, ЗаголовокФормы, ОформлениеТаблицы, РежимОкна, ФорматРезультата, ИмяСобытия, ЗакрыватьФормуПриВыборе);
	
	ОткрытьФорму("ОбщаяФорма.ФормаТаблицаДляВыбора_тк", ПараметрыФормы, ЭтаФорма);

Форма может вызываться в обычном и модальном режиме.

Как видно на примере, форма принимает следующие параметры:

ТекстЗапроса - тип Строка, принимается текст запроса по стандарту 1С;

ПараметрыЗапроса - тип СписокЗначений, каждый элемент списка соответствует одному параметру, при этом представление элемента - имя параметра, а значение элемента - это значение параметра. Если параметров у запроса нет, нужно либо убрать параметр из структуры параметров формы, либо передавать в качестве параметра пустую структуру;

ЗаголовокФормы - тип Строка, прописывает данный текст в заголовок формы таблицы;

ОформлениеТаблицы - тип СписокЗначений, где представление элемента - это имя колонки результата запроса, а значение элемента - структура с элементами Видимость, Ширина, Заголовок, которые применяются к колонкам таблицы при отображении. Если какое-то свойство нужно оставить по умолчанию, то в значение нужно передать Неопределено;

РежимОкна - тип Число, доступные значения от 0 до 3.

  • 0 - форма открывается исключительно для отображения данных, обработка выбора строки отключена.
  • 1 - работает для модального режима окна, в этом случае результат будет возвращен, как результат обработки мдального окна.
  • 2 - используется при передаче выбранного результата в обработку оповещения формы-владельца.
  • 3 - используется для передачи результата в обработку выбора.

ФорматРезультата - тип Строка или СписокЗначений. Строка используется если необходимо выбрать значение из одной колонки выбранной строки, в этом случае нужно просто указать имя колонки результата запроса. СписокЗначений используется в случае, если при выборе нужно передать несколько значений. В этом случае каждое значение элемента списка должно содержать строковое значение наименования колонки результата запроса. А этом случае при выборе строки будет сформирована структура, в которую будут помещены значения соответствующих ячеек выбранной строки.

ИмяСобытия - тип Строка, может использоваться при РежимОкна = 2 для отслеживания оповещения по имени события.

ЗакрыватьФормуПриВыходе - тип Булево, при Ложь форма не закрывается в случае выбора строки. Работает только для РежимОкна = 2 или РежимОкна = 3.

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

ВыбратьСтроку

См. также

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

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

15500 руб.

02.09.2020    225791    1228    415    

1071

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

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

14400 руб.

20.08.2024    48041    269    138    

243

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

Первые попытки разработки на 1С с использованием больших языковых моделей (LLM) могут разочаровать. LLMки сильно галлюцинируют, потому что не знают устройства конфигураций 1С, не знают нюансов синтаксиса. Но если дать им подсказки с помощью MCP, то результат получается кардинально лучше. Далее в публикации: MCP для поиска по метаданым 1С, справке синтакс-помошника и проверки синтаксиса.

9900 руб.

25.08.2025    22167    57    9    

60

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

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

22200 руб.

06.10.2023    29216    77    30    

104

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

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

16000 руб.

10.11.2023    20643    84    42    

95

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

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

9500 руб.

17.05.2024    41232    151    57    

190

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

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

6000 руб.

07.02.2018    109499    250    100    

314
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. пользователь 11.03.16 12:24
Сообщение было скрыто модератором.
...
2. пользователь 11.03.16 16:12
Сообщение было скрыто модератором.
...
3. пользователь 11.03.16 17:11
Сообщение было скрыто модератором.
...
4. пользователь 11.03.16 17:19
Сообщение было скрыто модератором.
...
5. Yashazz 4885 12.03.16 21:07 Сейчас в теме
Я что-то не понял, а где все комментарии? Это у меня браузер дурит?
6. Yashazz 4885 14.03.16 16:20 Сейчас в теме
Так вот, повторюсь. Автор публикации выбрал один из самых неудобных, ресурсо- и трудо-ёмких способов. Это замечательно можно и нужно сделать безо всяких запросов.

P.S. Если уж доводить до абсурда, то на формочке выбора должен располагаться динамический список с произвольным запросом; накручено всяческое СКД и условное оформление)))
7. pentanom 31 23.03.16 10:52 Сейчас в теме
(6) Yashazz, "Пример (или ссылка) в студию !"
Sher_Han; chrnv; +2 Ответить
8. grom04 11 21.03.17 13:43 Сейчас в теме
Отличная идея, спасибо!
Для отправки сообщения требуется регистрация/авторизация