Как найти реквизит на форме 1с программно

Перейти в раздел примеры кода 1С 8.3:

При наличии в конфигурации БСП, желательно использовать метод ЕстьРеквизитИлиСвойствоОбъекта (ссылка выше). Но что делать если конфигурация нетиповая? Вариантов (в зависимости от поставленной задачи) несколько: скопировать метод из БСП, проверить на свойство объекта, проверить через поиск, использовать попытку (не рекомендуется, только как временная заплатка).

Проверка реквизита через свойство объекта в 1С 8.3:

Функция ПроверкаНаСвойствоОбъекта(Объект, ИмяСвойстваОбъекта) Экспорт

   ЕстьСвойство = Ложь;
   СтруктураОбъекта = Новый Структура(ИмяСвойстваОбъекта, Неопределено);
   ЗаполнитьЗначенияСвойств(СтруктураОбъекта, Объект);

   Если СтруктураОбъекта[ИмяСвойстваОбъекта] = Неопределено Тогда
       СтруктураОбъекта[ИмяСвойстваОбъекта] = Ложь;
       ЗаполнитьЗначенияСвойств(СтруктураОбъекта, Объект);
       Если СтруктураОбъекта[ИмяСвойстваОбъекта] <> Ложь Тогда
           ЕстьСвойство = Истина;
       КонецЕсли;
   Иначе
       ЕстьСвойство = Истина;
   КонецЕсли;

   Возврат ЕстьСвойство;// Булево

КонецФункции

Проверка реквизита через Найти в 1С 8.3:

Функция ПроверитьНаРеквизит(ИмяРеквизита, МетаданныеДок) // универсальная функция

   // Например ИмяРеквизита=”ДрагМеталлы”;
   Если МетаданныеДок.Реквизиты.Найти(ИмяРеквизита) = Неопределено Тогда
       Возврат Ложь;
   Иначе
       Возврат Истина;
   КонецЕсли;

КонецФункции

Функция НайтиДрагМеталлы(Номенклатура, Материал, ОсновноеСредство) // пример использования в универсальной обработке

   // если реквизит шапки
   ИмяРеквизита=“ДрагМеталлы”;
   Если Метаданные.Справочники.Товары.Реквизиты.Найти(ИмяРеквизита) <> Неопределено Тогда
       Возврат Номенклатура.ДрагМеталлы;
   ИначеЕсли Метаданные.Справочники.Материалы.Реквизиты.Найти(ИмяРеквизита) <> Неопределено Тогда
       Возврат Материал.ДрагМеталлы;
   ИначеЕсли Метаданные.Справочники.ОсновныеСредства.Реквизиты.Найти(ИмяРеквизита) <> Неопределено Тогда
       Возврат ОсновноеСредство.ДрагМеталлы;
   Иначе
       Возврат Ложь;
   КонецЕсли;

   // если реквизит таб.части
   //Если НЕ ТекущаяСтрока.Свойство(ИмяРеквизита) ИЛИ НЕ ТекущаяСтрока.ДрагМеталлы Тогда
   //    ЗаполнитьЗначенияСвойств(ТаблицаДок.Добавить(), ТекущаяСтрока); // приёмник, источник
   //КонецЕсли;

КонецФункции

Проверка реквизита через Попытка (&НаКлиенте) в 1С 8.3:

&НаКлиенте
Функция ПроверитьНаНаличиеРеквизитаЧерезПопытку(ИмяРеквизита)

   Попытка
       РеквизитФормыПоИмени = ЭтаФорма[ИмяРеквизита];
       ЕстьРеквизитНаФорме = Истина;
   Исключение
       ЕстьРеквизитНаФорме = Ложь;
   КонецПопытки;

   Возврат ЕстьРеквизитНаФорме;

КонецФункции

В определенных задачах можно использовать метод в 1С 8.3:

ПолучитьРеквизиты(GetAttributes)

Синтаксис:

ПолучитьРеквизиты(<Путь>)

Параметры:

<Путь> (необязательный)

Тип: Строка.

Указывает путь к родительскому реквизиту. Если параметр опущен или указана пустая строка, возвращаются реквизиты верхнего уровня.

Возвращаемое значение:

Тип: Массив.

Массив объектов РеквизитФормы.

Описание:

Получает описание реквизитов формы.

Copyright©, «Программист 1С в г.Минске», 06.11.2021

Перепечатка текста и фотографий разрешена при наличии прямой ссылки на источник

(3) + Уже сам порылся :

ВсеЭлементыФормы.Найти (FormAllItems.Find)

ВсеЭлементыФормы (FormAllItems)

Найти (Find)

Синтаксис:

Найти(<Имя>)

Параметры:

<Имя> (обязательный)

Тип: Строка.

Имя элемента формы.

Возвращаемое значение:

Тип: Элемент управления; Неопределено.

Элемент управления в форме. Если элемент не найден, то возвращается значение Неопределено.

Описание:

Осуществляет поиск элемента управления с заданным именем.

Доступность:

Тонкий клиент, веб-клиент, сервер, толстый клиент.

Пример:

Процедура АктивизироватьРеквизитВФорме(ФормаДокумента) Экспорт

   // Структура – порядок активизации реквизитов.

   // Активизируется первый не заполненный.

   СтруктураРеквизитов = Новый Структура;

   СтруктураРеквизитов.Вставить(“Дата”);

   СтруктураРеквизитов.Вставить(“Номер”);

   СтруктураРеквизитов.Вставить(“Организация”);

   СтруктураРеквизитов.Вставить(“Касса”);

   СтруктураРеквизитов.Вставить(“БанковскийСчет”);

   СтруктураРеквизитов.Вставить(“Склад”);

   СтруктураРеквизитов.Вставить(“Контрагент”);

   СтруктураРеквизитов.Вставить(“Получатель”);

   СтруктураРеквизитов.Вставить(“Плательщик”);

   СтруктураРеквизитов.Вставить(“ФизЛицо”);

   Для каждого Элемент Из СтруктураРеквизитов Цикл

       // Определим, есть ли ЭУ с таким именем.

       ЭУ = ВсеЭлементыФормы.Найти(Элемент.Ключ);

       Если ЭУ  <> Неопределено Тогда

           // есть такой элемент

           Если Не ЗначениеЗаполнено(ЭУ.Значение) Тогда

               // Нашли не заполненный ЭУ.

               // Делаем его текущим и прекращаем цикл.

               ФормаДокумента.ТекущийЭлемент = ЭУ;

               Прервать;

           КонецЕсли;

       КонецЕсли;

   КонецЦикла;

КонецПроцедуры

При попытке разобраться с другим вопросом, изобрел велосипед:

&НаСервере
Функция  НайтиВозможныйРеквизитформыНаСервере(ИскомыйЭлементНаСервере)
Если Не ИскомыйЭлементНаСервере="" Тогда
Для Каждого Рек из ЭтаФорма.Элементы  Цикл
Если рек.Имя=ИскомыйЭлементНаСервере
Или Рек.Заголовок=ИскомыйЭлементНаСервере
Тогда
Возврат рек.ПутьКДанным;
КонецЕсли;
КонецЦикла;
КонецЕсли;
Возврат Истина;
КонецФункции  //НайтиЭлементыНаСервере

&НаКлиенте
Процедура НайтиРеквизит(Команда)
ИмяОбъекта = НайтиВозможныйРеквизитформыНаСервере(ЭлементДляПоиска);
Если ИмяОбъекта=Истина Тогда
Предупреждение("Не найдено");
Иначе
ЭтотОбъект[ИмяОбъекта]=НовоеЗначение;
КонецЕсли;
КонецПроцедуры

&НаКлиенте
Процедура ПриОткрытии(Отказ)
ЭлементДляПоиска="Реквизит1"; НовоеЗначение="Текст нового значения";
КонецПроцедуры

Позволяет найти нужный реквизит, используя обработчик события, например:

Регулирование(Элемент, Направление, СтандартнаяОбработка)А точнее:

Элемент.Имя

Содержание:

1.      Когда возникает необходимость проверить наличие реквизита 1С?

2.      Как можно получить метаданные объекта 1С?  

1.    Когда возникает необходимость проверить наличие реквизита 1С

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

В ряде типовых конфигураций 1С предлагается стандартная функция проверки наличия реквизита в объекте (расположена в модуле “ОбщегоНазначения”)

Функция ЕстьРеквизитОбъекта(ИмяРеквизита, МетаданныеОбъекта) Экспорт

            Возврат НЕ (МетаданныеОбъекта.Реквизиты.Найти(ИмяРеквизита) = Неопределено);

КонецФункции   

2. Как можно получить метаданные объекта 1С

Однако написать свою функцию также не представляет труда. В первую очередь необходимо получить метаданные объекта 1С одним из способов:

через функцию Метаданные() объекта

пример синтаксиса: СправочникСсылка.Метаданные()

                                    ДокументСсылка.Метаданные()

через свойство глобального контекста Метаданные

пример синтаксиса: Метаданные.Справочники.[ИмяСправочника]

                                    Метаданные.Документы.[ИмяДокумента]

Далее через свойство “Реквизиты” использовать функцию Найти(). В случае, если реквизит не найден, возвращается значение Неопределено.

Пример 1

Метаданные = Контрагент.Метаданные();

Если Метаданные.Реквизиты.Найти(«Ответственный») = Неопределено Тогда

            Возврат Ложь;

Иначе

            Возврат Истина;

КонецЕсли;

Пример 2

Функция ПолучитьОрганизацию(Контрагент, Пользователь)

            Если Метаданные.Справочники.Контрагенты.Реквизиты.Найти(«Организация») <> Неопределено Тогда

                        Возврат Контрагент.Организация;

            Иначе

                        Возврат Пользователь.Организация;

            КонецЕсли;

КонецФункции

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

Метаданные.Справочники.<ИмяСправочника>.ТабличныеЧасти.Реквизиты.Найти(<ИмяОбъектаПоиска>).

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

Пример синтаксиса:

Если НЕ ТекущаяСтрока.Свойство(«Исключить») ИЛИ НЕ ТекущаяСтрока.Исключить Тогда

            ЗаполнитьЗначенияСвойств(ТаблицаЗагрузки.Добавить(); ТекущаяСтрока);

КонецЕсли;

Специалист компании ООО «Кодерлайн»

Кондренко Анна Сергеевна

Котовчанин

942 / 482 / 200

Регистрация: 16.02.2010

Сообщений: 3,338

Записей в блоге: 37

1

Найти реквизит на форме

29.06.2016, 13:32. Показов 15560. Ответов 10


Студворк — интернет-сервис помощи студентам

Всем доброго времени уток!

Вопрос странный и глупый, но … Как найти реквизит на форме? Пытаюсь провести документ, выдаёт ошибку, мол не заполнен реквизит… А его нет на форме! Нигде. Просмотрела модуль формы – там выполняются операции с этим реквизитом, но я его не вижу…

Как найти?
з.ы. если нужно – сброшу конфу, но она большая.



0



Эксперт 1С

3051 / 1998 / 524

Регистрация: 25.06.2009

Сообщений: 6,964

29.06.2016, 13:37

2

Тамика, какая форма? Обычная или управляемая?



1



Котовчанин

942 / 482 / 200

Регистрация: 16.02.2010

Сообщений: 3,338

Записей в блоге: 37

29.06.2016, 13:39

 [ТС]

3

GreenkA, управляемая.



0



Эксперт 1С

3051 / 1998 / 524

Регистрация: 25.06.2009

Сообщений: 6,964

29.06.2016, 13:44

4

Тамика, см скрин

Найти реквизит на форме

Посмотрите в модуле возможно где-то отключается видимость этого реквизита. Либо возможен вариант автоматического заполнения его при заполнении/выборе другого, в таком случае он на форме может и отсутствовать.
Какая у вас конфигурация? Типовая?



1



Котовчанин

942 / 482 / 200

Регистрация: 16.02.2010

Сообщений: 3,338

Записей в блоге: 37

29.06.2016, 13:49

 [ТС]

5

GreenkA, у меня почему-то другой вид формы… Я не могу открыть её в таком виде.

Найти реквизит на форме



0



Эксперт 1С

3051 / 1998 / 524

Регистрация: 25.06.2009

Сообщений: 6,964

29.06.2016, 13:57

6

Тамика, у вас обычная форма. Тогда сверху в меню Форма-элементы управления



1



Котовчанин

942 / 482 / 200

Регистрация: 16.02.2010

Сообщений: 3,338

Записей в блоге: 37

29.06.2016, 14:00

 [ТС]

7

GreenkA, поискала… Не нашла этот реквизит.



0



Злой самаритянин

182 / 182 / 94

Регистрация: 24.04.2014

Сообщений: 686

29.06.2016, 14:02

8

Лучший ответ Сообщение было отмечено GreenkA как решение

Решение

Тамика, это обычная форма. Чтобы посмотреть, какие реквизиты выведены на форме открой Форма – Размещение данных…

Миниатюры

Найти реквизит на форме
 



1



Котовчанин

942 / 482 / 200

Регистрация: 16.02.2010

Сообщений: 3,338

Записей в блоге: 37

29.06.2016, 14:04

 [ТС]

9

SHIFT_969, да, нашла! Спасибо! И правда рекзвизит без галочки… Но я не понимаю – почему он используется в коде, если он невидим по умолчанию?..



0



58 / 63 / 11

Регистрация: 13.11.2014

Сообщений: 939

30.06.2016, 06:31

10

Цитата
Сообщение от Тамика
Посмотреть сообщение

если он невидим по умолчанию?..

Вроде если он даже не видим, то его все равно можно использовать



0



Эксперт 1С

3051 / 1998 / 524

Регистрация: 25.06.2009

Сообщений: 6,964

30.06.2016, 09:50

11

Тамика, укажите название конфигурации, документа и реквизита.



0



IT_Exp

Эксперт

87844 / 49110 / 22898

Регистрация: 17.06.2006

Сообщений: 92,604

30.06.2016, 09:50

Помогаю со студенческими работами здесь

реквизит 7.7
есть реквизит &quot;р1&quot; тип Справочники…. у этого справочника есть реквизиты &quot;р2&quot; и &quot;р3&quot; …
как мне…

реквизит
Здравствуйте, помоги пожалуйста разобраться, как сделать реквизит в документе не доступным для…

Реквизит-объект
Прошу объясните мне. Одно не могу понять. Вот в Delphi7 есть объект..скажем Edit.. если мне надо…

1с 7.7 реквизит с шаблоном
Необходимо сделать так чтобы значение реквизита на форме справочника вводилось определенным видом -…

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:

11

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