Новичок новичку: как открыть документ и установить курсор на нужной строке табличной части (обычные формы)

20.04.23

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

Как открыть документ и установить курсор на нужной строке табличной части (обычные формы).

Здравствуйте.

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

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

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

 

 

Поиск в интернете не дал полного и точного ответа. То есть вопросы люди задавали: "А как открыть документ и встать на нужную строку", но в большинстве случаев получали ответ вида:

Форма.Элементы.Товары.ТекущаяСтрока = НайденныеСтроки[0].ПолучитьИдентификатор();

Не знаю почему, но этот код  у людей не работал. Например, у меня "ПолучитьИдентификатор()" 1С не понимала... Возможно, данный код работает только на УФ, не проверял. Покажу, как мне удалось решить этот вопрос на обычных формах.

Задание: по нажатию кнопки обработки открыть документ и перейти на строку с сотрудником Баринов Борис Николаевич. Код кнопки получился таким:

Процедура КнопкаВыполнитьНажатие(Кнопка)
	//получим сотрудника любым способом,
	//у Вас это может быть запрос, или реквизит формы
	//я, для примера, получу его поиском из справочника
	Сотрудник = Справочники.СотрудникиОрганизаций.НайтиПоНаименованию("Баринов Борис Николаевич", Ложь);
	//найдем нужный документ
	//Сотрудник может быть в нескольких документах. Нам нужен документ, который был создан последним
	Запрос = Новый Запрос;
	Запрос.Текст = 
	"ВЫБРАТЬ ПЕРВЫЕ 1
	|	СведенияОЗастрахованныхЛицахФССРаботникиОрганизации.Ссылка
	|ИЗ
	|	Документ.СведенияОЗастрахованныхЛицахФСС.РаботникиОрганизации КАК СведенияОЗастрахованныхЛицахФССРаботникиОрганизации
	|ГДЕ
	|	СведенияОЗастрахованныхЛицахФССРаботникиОрганизации.Ссылка.Проведен = ИСТИНА
	|	И СведенияОЗастрахованныхЛицахФССРаботникиОрганизации.Сотрудник = &Сотрудник
	|
	|УПОРЯДОЧИТЬ ПО
	|	СведенияОЗастрахованныхЛицахФССРаботникиОрганизации.Ссылка.Дата УБЫВ";
	
	Запрос.УстановитьПараметр("Сотрудник", Сотрудник);
	РезультатЗапроса = Запрос.Выполнить().Выгрузить();
	
	//возможно, документ так и не был найден. Проверим это:	
	Если РезультатЗапроса.Количество() = 1 Тогда 
		Документ = РезультатЗапроса[0].Ссылка;
		//получим программно форму документа
		Форма = Документ.ПолучитьФорму("ФормаДокумента");
		//найдем все строки в документе по сотруднику
		Отбор = Новый Структура();
		Отбор.Вставить("Сотрудник", Сотрудник);
		СтрокаТаблицы = Форма.ЭтотОбъект.РаботникиОрганизации.НайтиСтроки(Отбор);
		//установим текущую позицию в первую из найденных строк,
		//на всякий случай проверив перед этим, что есть хотя бы одна
		Если СтрокаТаблицы.Количество() > 0 Тогда
			Форма.ЭлементыФормы.РаботникиОрганизации.ТекущаяСтрока = СтрокаТаблицы[0];
		КонецЕсли;
		//откроем форму программно
		Форма.Открыть();
	КонецЕсли;	
КонецПроцедуры

На вид текст получился сложным и объемным. Но большая его часть просто определяет сотрудника и ищет документ с данным сотрудником. Если Документ уже Вами получен и сотрудник известен, то все сведется к:

		//получим программно форму документа
		Форма = Документ.ПолучитьФорму("ФормаДокумента");
		//найдем все строки в документе по сотруднику
		Отбор = Новый Структура();
		Отбор.Вставить("Сотрудник", Сотрудник);
		СтрокаТаблицы = Форма.ЭтотОбъект.РаботникиОрганизации.НайтиСтроки(Отбор);
		//установим текущую позицию в первую из найденных строк,
		//на всякий случай проверив перед этим, что есть хотя бы одна
		Если СтрокаТаблицы.Количество() > 0 Тогда
			Форма.ЭлементыФормы.РаботникиОрганизации.ТекущаяСтрока = СтрокаТаблицы[0];
		КонецЕсли;
		//откроем форму программно
		Форма.Открыть();

Здесь мы сначала получаем форму документа и перед открытием этой формы у элемента табличной части устанавливаем текущую позицию. При этом, "ПолучитьИдентификатор()" не требуется.

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

См. также

Работа с интерфейсом Анализ учета Мониторинг 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"!

29280 руб.

27.03.2025    66875    41    29    

53

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

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

36600 руб.

28.08.2025    5148    2    2    

5

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

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

6088 руб.

17.10.2025    1356    3    0    

2

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

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

6100 руб.

14.01.2016    59149    20    25    

46

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

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

5246 руб.

29.06.2020    23488    33    6    

52

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

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

20.08.2024    45942    mrXoxot    44    

138

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

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

27.05.2024    25588    smielka    38    

112

Инструментарий разработчика Работа с интерфейсом Программист 1С:Предприятие 8 1C:Бухгалтерия Абонемент ($m)

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

3 стартмани

10.04.2023    16941    180    acces969    31    

132
Для отправки сообщения требуется регистрация/авторизация