Как получить реквизит документа в его форме

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

Данные объекта, которые отображаются в форме (в нашем случае данные документа), находятся всегда в основном реквизите формы. В подавляющем большинстве случаев этот реквизит имеет имя Объект. По крайней мере именно такое имя дает ему платформа, когда с помощью конструктора создает форму объекта. В нашем случае это именно так:


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

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

ПоставщикДокумента = Объект.Поставщик; 

 Как получить доступ к реквизитам формы?

Если реквизит объекта «вытащен» на форму, то реквизит формы можно получить через объект ЭлементыФормы, который содержит коллекцию элементов формы, сканируя ее в цикле:

ДокСсылка = СсылкаНаДокумент(ТипДокумента, НомерДок);
ДокОбъект = ДокСсылка.ПолучитьОбъект();
 
ФормаОбъекта = ДокОбъект.ПолучитьФорму();
Для Каждого Элемент Из ФормаОбъекта.ЭлементыФормы Цикл
        Сообщить(Элемент);
КонецЦикла;     
 

Этот цикл позволяет просмотреть имена а так же типы всех реквизитов формы, в том числе такие реквизиты как надписи, командные панели и тд.

Реквизиты формы могут быть различных типов. Поставив фильтр в виде типа реквизита мы можем просмотреть реквизиты определенного типа.

Если реквизит формы имеет тип «ТабличноеПоле», то можно такой элемент просканировать во вложенном цикле и узнать имена колонок таблицы:

 
Для Каждого Элемент Из ФормаОбъекта.ЭлементыФормы Цикл
        Сообщить(Элемент.Имя);
        Если Тип(Элемент) = Тип("ТабличноеПоле") Тогда
                Сообщить(" Это табличное поле! "  + Элемент.Имя );
                Для Каждого Колонка Из Элемент.Колонки Цикл
                        ИмяКолонки = Колонка.Имя;
                        Сообщить(ИмяКолонки);
                КонецЦикла;
        КонецЕсли;      
КонецЦикла;     
 

Как получить значение отдельного реквизита формы?

Чаще требуется получать не массив реквизитов формы,  а значение отдельных конкретных реквизитов формы. Например реквизиты «Шапки» или «Подвала» формы документа.

Пример:

 
ФормаОбъекта = ДокОбъект.ПолучитьФорму("ФормаДокумента");
Поставщик = ФормаОбъекта.ЭлементыФормы.Поставщик;
Поставщик = ФормаОбъекта.ЭлементыФормы.Получатель;
Сообщить(ФормаОбъекта.ЭлементыФормы.ТаблПоле.Колонки.Количество());
 

Реквизиты шапки могут иметь различные типы: Дата, СправочникСсылка, ЧекБокс, элемент раскрывающегося списка и др.

Как получить значение элементов табличной части формы?

Доступ к табличной части формы через объект

Доступ к табличной части формы (например: Товары) можно получить через объект:

 
  ДокОбъект = Док.ПолучитьОбъект(); //здесь Док - ссылка на объект
  //просканируем построчно таб часть документа
  Для Каждого Стр из ДокОбъект.Товары Цикл
      Номенклатура = Стр.Номенклатура;
      Стр.Коэффициент = 1;
  КонецЦикла;
 

Здесь ДокОбъект.Товары — это табличная часть «Товары» объекта. Далее в цикле табличная часть построчно сканируется!
В каждой итерации цикла можно получить доступ к любому полю строки указав через точку имя этого поля:

      Номенклатура = Стр.Номенклатура;

Доступ к табличной части формы через ЭлементыФормы

Табличная часть объекта и табличная часть формы объекта — это не одно и то же!

Для того, чтобы код работал правильно, надо чтобы колонка формы табчасти объекта в свойстве данные ссылалась на реквизит табличной части объекта. Этим определяется тип колонки таб части формы.

То есть должна быть установлена связь между реквизитом табчасти объекта и реквизитом табчасти формы. Форм у объекта метаданных может быть много мы знаем. Табличную часть формы объекта можно получить через объект ЭлементыФормы:

Объект ЭлементыФормы используется для доступа к элементам управления, расположенным на форме, в частности к таб части документа.

 
        ДокСсылка = СсылкаНаДокумент(ТипДокумента, НомерДок);
        ДокОбъект = ДокСсылка.ПолучитьОбъект();
                                
        ФормаОбъекта = ДокОбъект.ПолучитьФорму();
        Для Каждого Элемент Из ФормаОбъекта.ЭлементыФормы Цикл
                Если Тип(Элемент) = Тип("ТабличноеПоле") Тогда //элемент формы - табличное поле
                                                        
                        Если Элемент.Имя = "Товары" Тогда
                                Сообщить("Это табличное поле!! "  + Элемент.Имя );
                                
                                //ТабПоле = ФормаОбъекта.ЭлементыФормы.Товары.Значение;
                                ТабПоле = Элемент.Значение;
                                Колво = ТабПоле.Количество();
                                Сообщить("Количество строк: " + Колво); 
                                
                                Для Каждого ТекущаяСтрока Из ТабПоле Цикл
                                        
                                        Имя = ТекущаяСтрока.Номенклатура;
                                        Сообщить(Имя); 
                
                                КонецЦикла;                             
                                
                        КонецЕсли;      
                                                        
                КонецЕсли;                                      
        КонецЦикла;  
 

Результат для документа Авансовый отчет:

Это табличное поле!! Товары
Количество строк: 4
Женские ботфорты коричневые
Ботинки женские демисезонные
Ботинки женские натуральная кожа
Женские босоножки       

Если надо получить значение всех колонок всех строк, то организуем дважды вложенный цикл:
Во внешнем цикле сканируются строки, во внутреннем — колонки:

 
        ДокСсылка = СсылкаНаДокумент(ТипДокумента, НомерДок);
        ДокОбъект = ДокСсылка.ПолучитьОбъект();
                                
        ФормаОбъекта = ДокОбъект.ПолучитьФорму("ФормаДокумента");
        Для Каждого Элемент Из ФормаОбъекта.ЭлементыФормы Цикл
                Если Тип(Элемент) = Тип("ТабличноеПоле") Тогда
                                                        
                        Если Элемент.Имя = "ВыданныеАвансы" Тогда //таб часть объекта
                                Сообщить(" Это табличное поле!! "  + Элемент.Имя );
                                
                                ТабПоле = Элемент.Значение;
                                Индекс = 0;
                                Для Каждого ТекущаяСтрока Из ТабПоле Цикл
                                        
                                        Сообщить("=======================");
                                        Для Каждого Колонка Из Элемент.Колонки Цикл
                                                
                                                ИмяКолонки = Строка(Колонка.Имя);
                                                Сообщить(ИмяКолонки);
                                                Имя = ТекущаяСтрока[ИмяКолонки];//сработает только если есть такое поле таб части объекта
                                                Сообщить("=== " + Имя); 
                                                
                                        КонецЦикла;
                                        
                                        Индекс = Индекс + 1;
                                        Если Индекс > 0 Тогда break КонецЕсли; //только первая строка
                                        
                                        
                                КонецЦикла;                             
                                
                                                        
                        КонецЕсли;      
                                                        
                КонецЕсли;                                      
        КонецЦикла;    
 

Результат для документа Авансовый отчет:

Это табличное поле!! ВыданныеАвансы
=======================
НомерСтроки 1
ДокументАванса Расходный кассовый ордер ТК000000004 от 15.02.2007 19:24:03
СуммаДокументаАванса 300
ВалютаДокументаАванса USD
Выдано 300
Сумма 174

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

Доступ к реквизиту формы

Я
   Просто Царь

12.04.14 — 12:47

Подскажите, имеем форму документа, на которую штатными средствами добавлен дополнительный реквизит, например Реквизит1. Как к нему обратиться именно как к реквизиту формы, собственно ссылку на форму имеем. Обращение как к элементу ТЧ объекта не подходит, так как в этот момент форма еще не записана.

  

Партнерская программа EFSOL Oblako

   NcSteel

1 — 12.04.14 — 12:49

Платформа? Конфигурация? Упр или толстые формы?

   GROOVY

2 — 12.04.14 — 12:50

Форма не может быть записана.

   Просто Царь

3 — 12.04.14 — 12:51

УТ 11, 8.3

   Просто Царь

4 — 12.04.14 — 12:53

(2)Нет, записывать не вариант. В этом то случае можно заполнять ТЧ объекта и не париться

   Просто Царь

5 — 12.04.14 — 12:57

Собственно что бы было понятней.

Создаем программно один документ на основе другого

СтруктураПараметров = Новый Структура;

               СтруктураПараметров.Вставить(«Основание»,Объект.ДокОбъект);

               ФормаАкта = ОткрытьФорму(«Документ.АктВыполненныхРабот.Форма.ФормаДокумента»,СтруктураПараметров,,Ложь,);

Далее через ФормаАкта.ЛюбойРеквизитФормы можно подставить нужные значения, но вот как тоже сделать с доп реквизитом?

   Wobland

6 — 12.04.14 — 13:01

1. Как к нему обратиться именно как к реквизиту формы

2. Далее через ФормаАкта.ЛюбойРеквизитФормы

а можно повторить вопрос?

   Просто Царь

7 — 12.04.14 — 13:02

Обратиться нужно не к обычному реквизиту а к дополнительному

   NcSteel

8 — 12.04.14 — 13:02

(5)

1. В 1С форму документа/справочник и т.д. записать в принципе невозможно. Так что Вы винимо не понимаете механизмом взаимодействия компонентов платформы.

2. Реквизиты необходимо проставлять не через элементы формы. а непосредственно через реквизиты объекта.

   Wobland

9 — 12.04.14 — 13:03

(7) кто все эти слова?

   Просто Царь

10 — 12.04.14 — 13:03

Имея при этом ссылку на не записанную форму на которую он собственно и выведен

   NcSteel

11 — 12.04.14 — 13:03

(7) Дополнительный хратися в таб части. К нему на прямую и обращайся Объект.ТЧ

   NcSteel

12 — 12.04.14 — 13:03

(10) У формы нет ссылки и форму нельзя записать в принципе.

   Wobland

13 — 12.04.14 — 13:05

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

   Просто Царь

14 — 12.04.14 — 13:10

Принцип работы работы платформы понимаю, и прекрасно знаю что записать можно элемент или документ. Попробую объяснить точнее

СтруктураПараметров = Новый Структура;

               СтруктураПараметров.Вставить(«Основание»,Объект.ДокОбъект);

               ФормаАкта = ОткрытьФорму(«Документ.АктВыполненныхРабот.Форма.ФормаДокумента»,СтруктураПараметров,,Ложь,);

Далее например

ФормаАкта.Менеджер = … Можем заменить например менеджера на нужного, а при создании там заполнен текущий пользователь. Так вот в Документе создан штатными средствами конфигурации дополнительный реквизит и вопрос  том, возможно ли его как то заполнить на данном этапе без записи документа, потому как записывать или нет принимает решение пользователь после открытия перед ним этой формы

   NcSteel

15 — 12.04.14 — 13:15

(14) Почему не хотим через объект работать?

   Просто Царь

16 — 12.04.14 — 13:18

(15)А как сработать через объект, если документ не записан?

   NcSteel

17 — 12.04.14 — 13:20

(16) А тут разве есть связь? Вы все же не понимаете взаимосвязи в платформе.

   Просто Царь

18 — 12.04.14 — 13:21

Допустим я что-то и упускаю в этом моменте. Подскажите раз уж так

   Просто Царь

19 — 12.04.14 — 13:28

пробовал и так

НовыйДопРеквизит = ФормаАкта.Объект.ДополнительныеРеквизиты.Добавить();

               НовыйДопРеквизит.Свойство = ВернутьПВХ («Мастер»);

               НовыйДопРеквизит.Значение = Объект.Мастер;

Но поле все равно пустое

   NcSteel

20 — 12.04.14 — 13:33

Посмотри как в УТ 11 закрывается смена. При нажатии кнопки выполняются процедуры по заполнению объекта на сервере. Объект передается на клиента и на клиенте получается форма.

   Просто Царь

21 — 12.04.14 — 13:53

Вот этого то и пытался избежать путем использования стандартной процедуры ввода на основании.

   Просто Царь

22 — 12.04.14 — 13:59

(20) И есть еще одно но, отчет о розничных продажах передается уже записанным

   Просто Царь

23 — 12.04.14 — 15:28

ЛАдно, объект иак объект

НовыйДопРеквизит = ФормаАкта.Объект.ДополнительныеРеквизиты.Добавить();

               НовыйДопРеквизит.Свойство = ВернутьПВХ («Мастер»);

               НовыйДопРеквизит.Значение = Объект.Мастер;

Но как заставить форму отобразить добавленное значение?

   Просто Царь

24 — 12.04.14 — 15:28

&НаСервере

Функция ВернутьПВХ (ИмяПВХ)

    Возврат ПланыВидовХарактеристик.ДополнительныеРеквизитыИСведения.НайтиПоНаименованию(ИмяПВХ);    

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

   Просто Царь

25 — 15.04.14 — 09:59

Собственно вопрос решил на половину. Вот код:

Процедура ЗаполнитьАктВРСервер(НовыйДок)

       РеквизитМастер = ПланыВидовХарактеристик.ДополнительныеРеквизитыИСведения.НайтиПоНаименованию(«Мастер»);

       РекМастер = НовыйДок.ДополнительныеРеквизиты.Добавить();

       РекМастер.Свойство = РеквизитМастер;

       РекМастер.Значение = Объект.Мастер;

                        
          НовыйДок.Комментарий = «123654»;

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

&НаКлиенте

Процедура ВвестиАктВР(Команда)

    СтруктураПараметров = Новый Структура;

            СтруктураПараметров.Вставить(«Основание»,Объект.ДокОбъект);

            ФормаАкта = ОткрытьФорму(«Документ.АктВыполненныхРабот.Форма.ФормаДокумента»,СтруктураПараметров,,Ложь,);

            ДанныеФормы = ФормаАкта.Объект;  

            ЗаполнитьАктВРСервер(ДанныеФормы);

            КопироватьДанныеФормы(ДанныеФормы, ФормаАкта.Объект);

            ФормаАкта.ОбновитьОтображениеДанных();

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

Дополнительный реквизит на сервере заполняется, но на форме в дальнейшем поле не заполнено. Как обновить отображение дополнительных реквизитов на форме.

   Drac0

26 — 15.04.14 — 10:03

(25) ОповеститьОбИзменении()

   Просто Царь

27 — 15.04.14 — 10:38

Документ не записан, а туда надо ссылку на измененный объект передавать.

  

Просто Царь

28 — 15.04.14 — 11:47

Не уж то никак не обновить?

Содержание:

1.    Реквизиты объекта и реквизиты формы в 1С

2.    Как получить значения из элементов формы 1С  

1.    Реквизиты объекта и реквизиты формы в 1С

В обычном приложении у элемента формы 1С 8.3 было свойство «Значение», доступное как для чтения, так и для записи. Какой аналог в управляемом приложении?

Элементы формы 1С 8.3 могут содержать реквизиты двух видов: реквизиты объекта 1С и реквизиты формы.

Красным помечен реквизит объекта 1С Контрагент, а зеленым – реквизит формы в 1С.

Интерактивно выберем эти элементы в пользовательском режиме 1С и попробуем прочитать их «программно» кнопкой «Прочитать».

Если читать значения реквизитов в клиентской процедуре, то код для 1С Предприятия будет следующий:


Все бы хорошо: мы получили на клиенте значения реквизитов объекта 1С и формы, но – не значения элементов формы 1С. На клиенте значение элементов формы 1С получить нельзя. 

2.    Как получить значения из элементов формы 1С

Чтобы получить значения из элементов формы 1С, нам потребуется серверный вызов:

Именно на сервере у элемента формы 1С 8.3 становится доступно свойство ПутьКДанным, по которому его можно извлечь либо из Объекта, который имеет тип ДанныеФормыСтруктура:

…либо из Формы, которая имеет тип ФормаКлиентскогоПриложения:


Форма и ее элементы не видны на сервере без контекста. То есть код для 1С:Предприятия выдаст множество ошибок.

Также Форму нельзя передать как параметр в процедуру и функцию на сервер или в общий модуль.


            Еще хочется разобрать момент, когда нам возможно увидеть состояние различающихся значений в элементе форме 1С и в объекте. Это возможно в событии элемента ОбработкаВыбора.
Например, при значении поля Контрагент — Ассоль, мы выбрали контрагента Бакалея:


Новое значение доступно как параметр процедуры ВыбранноеЗначение.


Система дает шанс что-то сделать в этой ситуации.

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

Добрыгин Михаил

0

19.04.2018 — 10:21


Подскажите плиз. Туплю. Есть форма обработки на управляемых формах. На ней реквизит — тип Документ. Как получить доступ к реквизитам данного документа?

1

19.04.2018 — 10:32

Документ.Реквизит

2

19.04.2018 — 10:33

тип ДокументСсылка ? ПолучитьОбъект() не ?

3

19.04.2018 — 10:35

на клиенте не дает через документ.реквизит, не видит реквизита

4

19.04.2018 — 10:36

Мойдокумент = Объект.НужныйМнеДокумент, но доступа к реквизитам нет.

5

19.04.2018 — 10:42

что за конфа ? БСП ОбщегоНазначения.ПолучитьРеквизитОбъекта
или проваливаться на сервер и получать весь объект

6

19.04.2018 — 11:04

3-kotmurlot > ну так чтоб получить что-то «через точку» от ссылки это нужно прочитать из базы данных. Никакое чтение данных из базы на клиенте невозможно.
Внеконтекстный вызов сервера. Или свой, или (5)

7

19.04.2018 — 11:11

Разобрался что все на сервере надо делать, а как сделать чтобы перебрать все строки документа на сервере передавая на клиент по одной и там ее обрабатывая?

8

19.04.2018 — 11:34

зачем?

9

19.04.2018 — 11:35

вызов серверный один должен быть, посмотри хэлп по РеквизитФормыВЗначение и ДанныеФормыВЗначение

10

19.04.2018 — 12:42

(8)+
и для чего?)

11

19.04.2018 — 12:51

(7) Попробуй значения реквизитов строки ТЧ документа в массив засунуть, а затем сформировать массив из этих строк и верни на клиента.

12

19.04.2018 — 13:32

7-kotmurlot >По-человечески — никак. Обрабатывай все сразу на сервере. Или получай с сервера массив структур, сформированный из данных строк, и с ним работай.

13

19.04.2018 — 15:33

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

14

19.04.2018 — 15:38

13-kotmurlot > Файл передавай через временное хранилище с сервера на клиент

15

19.04.2018 — 16:18

14-Uho > т.е. формировать его на сервере и передавать на клиент?

16

19.04.2018 — 16:19

14-Uho > а почему тогда сразу не сохранить его на сервере?

17

19.04.2018 — 18:13

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

18

24.04.2018 — 09:57

Получаю на сервере доступ к табличной части документа. В табличной части есть реквизит, но в данных документа его нет и когда обращаюсь к табличной части, то к нему доступа тоже нет. Как получить доступ к реквизиту формы обращаясь к самой табличной части?

19

24.04.2018 — 10:20

(18)
запросом, например? мало понятно, что нужно в итоге…

20

24.04.2018 — 10:43

я имею доступ напрямую к объекту на сервере, напрямую к табличной части. На форме документа в табличной части есть реквизит, но среди данных табличной части документа его нет. Когда я обращаюсь например МойДокумент.ТЧ то я вижу и получаю доступ к реквизитам, которые заведены в данных, но не могу получить доступ к нужному мне реквизиту.

21

24.04.2018 — 11:24

В реквизитах есть объект в нем табличная часть но этого реквизита ТЧ нет и есть в реквизитах отдельно типа эта табличная часть и в составе нее уже есть реквизит нужный мне. вот как получить доступ к нему? через форму? на сервере это сделать нельзя? только на клиенте?

22

24.04.2018 — 13:00

Кто на ком стоял?
Них… не понятно.
Что у тебя отображено на форме (см путь к данным для элемента управления)? данные объекта (что-то типа «Объект.ТабличнаяЧасть…») или реквизит формы (типа «Реквизит_ТаблицаЗначенийПоТЧ»)?
Если я правильно понимаю — последнее. И это последнее если найти его среди реквизитов формы (в правой верхней четверти окна формы в конфигураторе) имеет тип «(ТаблицаЗначений)». Именно так, со скобками. В этом случае нужно в контекстном серверном вызове с помощью РеквизитФормыВЗначение получить «настоящую» таблицу значений, обработать её и, если необходимо, вернуть обратно методом значениеВРеквизитФормы

23

24.04.2018 — 16:14

22-roma n >именно так, не у объекта, в правом верхнем углу. Мне нужно просто получить значения и все. Записывать их обратно в форму не надо.

24

24.04.2018 — 17:37

Цитата:

Сообщение от kotmurlot Посмотреть сообщение

есть в реквизитах отдельно типа эта табличная часть и в составе нее уже есть реквизит нужный мне

какой тип у этой «табличной части»? она показывается на форме через элемент «таблица»?

25

24.04.2018 — 18:21

автор, выложи уже скриншот что ли, раз словами написать не можешь

PS.
&НаСервере
Процедура ПрочитатьТЗ()
Для Каждого Строка ИЗ ТЗ Цикл
Сообщить(Строка.Реквизит1);
КОнецЦикла;
КонецПроцедуры

26

25.04.2018 — 15:16

У меня есть обработка. На ней есть объект типа документ. Мне нужно получить РеквизитФормыВзначение с его формы, как достучаться до формы объекта через обработку?

27

25.04.2018 — 15:30

Автор, в чем исходная задача? Объясни на предметном уровне, а не на уровне реквизитов формы

28

25.04.2018 — 15:36

Есть обработка. На ней реквизит типа Документ. В котором есть табличная часть. Мне необходимо эту табличную часть скинуть в таблицу значений через РеквизитФормыВзначение и обработать ее.

29

25.04.2018 — 15:41

28-kotmurlot > Нет такого типа «Документ», есть «ДокументСсылка», «ДокументОбъект»

30

25.04.2018 — 15:44

31

25.04.2018 — 15:52

29-Uho > сорри, ДокументСсылка

32

25.04.2018 — 15:53

30-user1C > все так плохо?)

33

25.04.2018 — 15:56

(32)
огу)
на сервере запросом получай табличную часть документа по ДокументСсылка в таблицу значений…

34

25.04.2018 — 15:59

31-kotmurlot >

&НаСервереБезКонтекста
Процедура ПрочитатьТЧДокументаНаСервере(РеквизитДокументСсыл ка)

Запрос = Новый Запрос(«ВЫБРАТЬ
| ТвойДокументТвояТабличнаяЧасть.РеквизитТЧ КАК РеквизитТЧ
|ИЗ
| Документ.ТвойДокумент.ТвояТабличнаяЧасть КАК ТвойДокументТвояТабличнаяЧасть
|ГДЕ
| ТвойДокументТвояТабличнаяЧасть.Ссылка = &Ссылка»);
Запрос.УстановитьПараметр(«Ссылка»,РеквизитДокумен тСсылка);
Выборка = Запрос.Выполнить().Выбрать();
Пока Выборка.Следующий() Цикл
Сообщить(Выборка.РеквизитТЧ);
КонецЦикла;

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

&НаКлиенте
Процедура ПрочитатьТЧДокумента()
ПрочитатьТЧДокументаНаСервере(РеквизитДокументСсыл ка);
КонецПроцедуры

35

25.04.2018 — 16:01

Или просто

&НаСервере
Процедура ПрочитатьТЧДокументаНаСервере()

Запрос = Новый Запрос(«ВЫБРАТЬ
| ТвойДокументТвояТабличнаяЧасть.РеквизитТЧ КАК РеквизитТЧ
|ИЗ
| Документ.ТвойДокумент.ТвояТабличнаяЧасть КАК ТвойДокументТвояТабличнаяЧасть
|ГДЕ
| ТвойДокументТвояТабличнаяЧасть.Ссылка = &Ссылка»);
Запрос.УстановитьПараметр(«Ссылка»,РеквизитДокумен тСсылка);
Выборка = Запрос.Выполнить().Выбрать();
Пока Выборка.Следующий() Цикл
Сообщить(Выборка.РеквизитТЧ);
КонецЦикла;

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

&НаКлиенте
Процедура ПрочитатьТЧДокумента()
ПрочитатьТЧДокументаНаСервере();
КонецПроцедуры

36

25.04.2018 — 16:06

(35)+
желанная таблица значений будет туто
ТЗ = Запрос.Выполнить().Выгрузить();

37

25.04.2018 — 16:15

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

38

25.04.2018 — 16:23

я объясняю через одно место — фточку :)
Ещё раз перечитал. Выдвигаю очередное предположение:
на форме документа отображается реквизит формы типа «(ТаблицаЗначений)». Необходимо получить эту самую ТаблицуЗначений не имея под рукой контекста формы документа, но имея ссылку на документ. Угадал?

39

25.04.2018 — 16:25

все, я пас)))

Реквизиты формы в запросе

Автор denis-moscow1987, 27 июн 2014, 11:31

0 Пользователей и 1 гость просматривают эту тему.

Здравствуйте, имеется форма документа в ней создан реквизит в самой форме, как в запросе достучаться до него?
Может кто то сталкивался и знает как?
Спасибо


Передать его значение как параметр в запрос.

xxx: Спасибо! Я бы загуглил, но ты интересней. Материшься. Злишься. Послать можешь…

Мысль — это оргазм мозга. Кто способен его испытать — получают истинное наслаждение, остальным приходится имитировать



Передача ЗНАЧЕНИЯ реквизита формы в запрос:
В запросе используете параметр &ЮрАдрес, затем

Запрос.УстановитьПараметр("ЮрАдрес",ЮрАдрес);

xxx: Спасибо! Я бы загуглил, но ты интересней. Материшься. Злишься. Послать можешь…

Мысль — это оргазм мозга. Кто способен его испытать — получают истинное наслаждение, остальным приходится имитировать


Цитата: Klyacksa от 27 июн 2014, 11:56
Передача ЗНАЧЕНИЯ реквизита формы в запрос:
В запросе используете параметр &ЮрАдрес, затем
Запрос.УстановитьПараметр("ЮрАдрес",ЮрАдрес);

Так я в консоле пишу…как там сделать?


Да посмотрите как в форме этот реквизит заполняется, вообще это скорее всего данные из РегистаСведений КонтактнаяИнформация, сторойте запрос к нему, с отбором по нужному контрагенту.

если помогло нажмите: Спасибо!


Цитата: LexaK от 27 июн 2014, 12:08
Да посмотрите как в форме этот реквизит заполняется, вообще это скорее всего данные из РегистаСведений КонтактнаяИнформация, сторойте запрос к нему, с отбором по нужному контрагенту.

Данные берет из адресного классификатора

Добавлено: 27 июн 2014, 12:28


Цитата: LexaK от 27 июн 2014, 12:08
Да посмотрите как в форме этот реквизит заполняется, вообще это скорее всего данные из РегистаСведений КонтактнаяИнформация, сторойте запрос к нему, с отбором по нужному контрагенту.

в БП 3.0 нет регистра контактная информация в этом и проблема


Помотрите еще, куда этот реквизит из формы записывается, при сохранении данных по контрагенту (нопка ОК на форме) ?

если помогло нажмите: Спасибо!


Цитата: LexaK от 27 июн 2014, 12:34
Помотрите еще, куда этот реквизит из формы записывается, при сохранении данных по контрагенту (нопка ОК на форме) ?

Поле юр адрес в Справочник.ВидыКонтактнойИнформации
А откудова получить сами значения Юр адреса?


В БП3.0 контактная информация хранится в самом справочнике Контрагенты, табличная часть КонтактнаяИнформация !!! :D

если помогло нажмите: Спасибо!


Получаем доступ к событиям элементов формы дополнительных реквизитов на примере конфигурации «Управление торговлей 11.2».

Допустим, для документа «Поступление услуг и прочих активов» у нас создан дополнительный реквизит «Не выгружать при синхронизации» с типом «Булево». Задача: использовать событие элемента формы «При изменении».

Дополнительные реквизиты – штука тонкая. Они могут присутствовать на форме объекта, а могут и не присутствовать. Например, в конфигурации «Управление торговлей 11.2», когда мы открываем форму документа «Поступление услуг и прочих активов», дополнительные реквизиты там отсутствуют. Это можно видеть в отладчике. И только когда мы переходим на вкладку «Дополнительно», происходит отложенная инициализация формы и после этого дополнительные реквизиты появляются в форме.

В связи с таким поведением формы, нам придётся назначать обработчик для события элемента формы дополнительного реквизита программно. Сделаем это с помощью метода УстановитьДействие () .

Как мы уже отметили, в УТ 11.2 в документе «Поступление услуг и прочих активов» дополнительные реквизиты появляются на форме при переходе на вкладку «Дополнительно». Переход обрабатывается в следующей процедуре, которая расположена в модуле формы документа:

В этой процедуре дополнительные реквизиты уже должны появиться на форме. Воспользуемся отладчиком. Поставим точку останова в конце процедуры и запустим отладку. Создадим условия для захода в точку останова. Далее в «Табло» найдём элемент формы необходимого нам дополнительного реквизита. Примерный его вид и расположение:

Метод УстановитьДействие () выполняется в контексте «На сервере», поэтому мы не можем использовать его в процедуре ГруппаСтраницыПриСменеСтраницы () , так как её контекст – «На клиенте». Значит, в конце процедуры мы дописываем вызов своей, серверной, процедуры, которая, собственно, и будет устанавливать обработчик для события «ПриИзменении» элемента формы.

В модуле формы создаём серверную процедуру:

В этой процедуре мы задали, что событие элемента формы «ПриИзменении» будет обрабатываться в процедуре с названием «МойОбработчик». Нам осталось только создать эту процедуру. Нужно учесть, что контекст её выполнения должен быть «На клиенте».

Если реквизит объекта «вытащен» на форму, то реквизит формы можно получить через объект ЭлементыФормы , который содержит коллекцию элементов формы, сканируя ее в цикле:

Этот цикл позволяет просмотреть имена а так же типы всех реквизитов формы, в том числе такие реквизиты как надписи, командные панели и тд.

Реквизиты формы могут быть различных типов. Поставив фильтр в виде типа реквизита мы можем просмотреть реквизиты определенного типа.

Если реквизит формы имеет тип «ТабличноеПоле», то можно такой элемент просканировать во вложенном цикле и узнать имена колонок таблицы:

Как получить значение отдельного реквизита формы?

Чаще требуется получать не массив реквизитов формы, а значение отдельных конкретных реквизитов формы. Например реквизиты «Шапки» или «Подвала» формы документа.

Реквизиты шапки могут иметь различные типы: Дата, СправочникСсылка, ЧекБокс, элемент раскрывающегося списка и др.

Доступ к табличной части формы через объект

Доступ к табличной части формы (например: Товары) можно получить через объект:

Здесь ДокОбъект.Товары — это табличная часть «Товары» объекта. Далее в цикле табличная часть построчно сканируется!
В каждой итерации цикла можно получить доступ к любому полю строки указав через точку имя этого поля:

Доступ к табличной части формы через ЭлементыФормы

Табличная часть объекта и табличная часть формы объекта — это не одно и то же!

Для того, чтобы код работал правильно, надо чтобы колонка формы табчасти объекта в свойстве данные ссылалась на реквизит табличной части объекта. Этим определяется тип колонки таб части формы.

То есть должна быть установлена связь между реквизитом табчасти объекта и реквизитом табчасти формы. Форм у объекта метаданных может быть много мы знаем. Табличную часть формы объекта можно получить через объект ЭлементыФормы :

Объект ЭлементыФормы используется для доступа к элементам управления, расположенным на форме, в частности к таб части документа.

Результат для документа Авансовый отчет:

Это табличное поле!! Товары
Количество строк: 4
Женские ботфорты коричневые
Ботинки женские демисезонные
Ботинки женские натуральная кожа
Женские босоножки

Если надо получить значение всех колонок всех строк, то организуем дважды вложенный цикл:
Во внешнем цикле сканируются строки, во внутреннем — колонки:

Результат для документа Авансовый отчет:

Это табличное поле!! ВыданныеАвансы
=======================
НомерСтроки 1
ДокументАванса Расходный кассовый ордер ТК000000004 от 15.02.2007 19:24:03
СуммаДокументаАванса 300
ВалютаДокументаАванса USD
Выдано 300
Сумма 174

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

Пользователь не должен видеть этот реквизит

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

Настраиваем роль

Итак, приступим. В тестовой конфигурации создадим наш «Тестовый документ» с несколькими реквизитами и три роли (см. следующий скриншот).

Обратите внимание на роли «ДоступКомментарий» и «БезДоступаККомментарию». Обе роли имеют доступ к документу «Тестовый документ». Различие между ним лишь в настройке права доступа к реквизиту «Комментарий». На следующем скриншоте представлено различие между ними.

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

Тестируем

Запустим программу в режиме 1С:Предприятие под пользователем «Без доступа к комментарию». Откроем документ и увидим результат наших действий:

Как мы видим, реквизит «Комментарий» не отображается как в форме документа, так и в форме списка. Теперь запустим программу от имени пользователя «Доступ к комментарию». Тогда мы получим следующий результат:

Теперь реквизит «Комментарий» доступен во всех открытых формах. В принципе, механизм работает.

Данная настройка действует на все формы, открываемые в режиме предприятия. Но у механизма разграничения прав по реквизитам есть некоторые нюансы работы, о которых стоит упомянуть.

Подводный камень

Настраивать права для отдельных реквизитов очень удобно, но на самом деле этот механизм трудно отнести к настрокам прав доступа. И вот почему:

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

2) При формировании SQL-запросов к базе данных в клиент-серверном варианте работы, платформа не учитывает настройки доступа на уровне реквизитов.

На следующем скриншоте представлен текст SQL-запроса, формируемый платформой при открытии документа при обоих вариантах настройки доступа к полю «Комментарий».

Как мы видим, в запросе присутствует выборка поля «_Fld17», в которм присутствует значение комментария.

3) Механизм разграничения прав на уровне реквизитов работает только для управляемых форм.

Если открыть обычную форму в управляемом или обычном приложении, то настройка прав в ролях на реквизиты объектов не будет действовать.

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

Подведем итог

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

Наиболее правильными механизмами для разраничения прав доступа на объекты конфигурации — это настрока прав на отдельные объекты в ролях и механизм RLS .

Понравилась статья? Поделить с друзьями:
  • Как получить реквизиты банка через терминал
  • Как получить реквизиты карты рнкб с печатью
  • Как получить реквизиты сбербанковской карты
  • Как получить реквизиты своей карты открытие
  • Как получить реквизиты счета в банке онлайн