Управляемые формы 1С » История » Версия 16
Всеволод Дорофеев, 07.12.2018 07:57
1 | 1 | Всеволод Дорофеев | h1. Управляемые формы 1С |
---|---|---|---|
2 | 1 | Всеволод Дорофеев | |
3 | 6 | Всеволод Дорофеев | h3. 1. Как программно удалить текущую строку из табличной части документа? |
4 | 3 | Всеволод Дорофеев | |
5 | 1 | Всеволод Дорофеев | Для этого следует воспользоваться методом Удалить() того объекта, который является источником данных для табличной части документа. Например, для документа "ПриходнаяНакладная" с табличной частью "Товары" это будет объект ДокументТабличнаяЧасть.ПриходнаяНакладная.Товары. В модуле формы этого документа удаление текущей строки табличной части будет выглядеть следующим образом: |
6 | 1 | Всеволод Дорофеев | |
7 | 7 | Всеволод Дорофеев | <pre> |
8 | 1 | Всеволод Дорофеев | ДокументОбъект.Товары.Удалить(ЭлементыФормы.Товары.ТекущаяСтрока); |
9 | 7 | Всеволод Дорофеев | </pre> |
10 | 1 | Всеволод Дорофеев | |
11 | 1 | Всеволод Дорофеев | В качестве параметра метода Удалить() передается текущая строка табличной части. |
12 | 1 | Всеволод Дорофеев | |
13 | 1 | Всеволод Дорофеев | Обратите внимание, что для удаления (как и для добавления) строк табличной части документа следует использовать методы табличной части (ДокументОбъект.Товары), а не методы табличного поля, отображающего эту табличную часть (ЭлементыФормы.Товары). |
14 | 1 | Всеволод Дорофеев | http://its.1c.ru/db/metod8dev/content/2481/hdoc |
15 | 4 | Всеволод Дорофеев | |
16 | 6 | Всеволод Дорофеев | h3. 2. Замена "Сообщить()" |
17 | 5 | Всеволод Дорофеев | |
18 | 2 | Всеволод Дорофеев | Вариант 1. |
19 | 2 | Всеволод Дорофеев | <pre> |
20 | 2 | Всеволод Дорофеев | ПоказатьОповещениеПользователя( |
21 | 2 | Всеволод Дорофеев | НСтр("ru = 'Изменения не зарегистрированы.'") |
22 | 2 | Всеволод Дорофеев | ,,, |
23 | 2 | Всеволод Дорофеев | БиблиотекаКартинок.Информация32); |
24 | 2 | Всеволод Дорофеев | </pre> |
25 | 2 | Всеволод Дорофеев | |
26 | 2 | Всеволод Дорофеев | Вариант 2. |
27 | 2 | Всеволод Дорофеев | <pre> |
28 | 2 | Всеволод Дорофеев | Сообщение = Новый СообщениеПользователю(); |
29 | 2 | Всеволод Дорофеев | Сообщение.Текст = "В строке 11 табличной части ""Номенклатура"" не хватает "; |
30 | 2 | Всеволод Дорофеев | Сообщение.Поле = "Номенклатура"; |
31 | 2 | Всеволод Дорофеев | |
32 | 2 | Всеволод Дорофеев | // Привязка объекта к реквизиту формы произойдет за счет |
33 | 2 | Всеволод Дорофеев | // установленного выше по стеку соответствия методом |
34 | 2 | Всеволод Дорофеев | // УстановитьСоответствиеОбъектаИРеквизитаФормы |
35 | 2 | Всеволод Дорофеев | Сообщение.УстановитьДанные(ОбъектДанных); |
36 | 2 | Всеволод Дорофеев | // Теперь у сообщения заполнено поле ПутьКДанным (установлено имя реквизита формы, до этого была пустая строка), |
37 | 2 | Всеволод Дорофеев | // и свойство КлючДанных (установлена ссылка на документ, до этого было Неопределено) |
38 | 2 | Всеволод Дорофеев | |
39 | 2 | Всеволод Дорофеев | // Сообщение выводится пользователю |
40 | 2 | Всеволод Дорофеев | Сообщение.Сообщить(); |
41 | 5 | Всеволод Дорофеев | </pre> |
42 | 8 | Всеволод Дорофеев | |
43 | 9 | Всеволод Дорофеев | h3. 3. Открытие управляемой формы не записанного документа в 1С 8.2/8.3 |
44 | 8 | Всеволод Дорофеев | |
45 | 8 | Всеволод Дорофеев | <pre> |
46 | 8 | Всеволод Дорофеев | &НаКлиенте |
47 | 8 | Всеволод Дорофеев | Процедура КомандаОткрытьФорму(Команда) |
48 | 8 | Всеволод Дорофеев | Форма = ПолучитьФорму("Справочник.Пользователи.ФормаОбъекта"); |
49 | 8 | Всеволод Дорофеев | ДанныеФормы = Форма.Объект; |
50 | 8 | Всеволод Дорофеев | ЗаполнитьНаСервере(ДанныеФормы); |
51 | 8 | Всеволод Дорофеев | КопироватьДанныеФормы(ДанныеФормы, Форма.Объект); |
52 | 8 | Всеволод Дорофеев | Форма.Открыть(); |
53 | 8 | Всеволод Дорофеев | КонецПроцедуры |
54 | 8 | Всеволод Дорофеев | |
55 | 8 | Всеволод Дорофеев | &НаСервереБезКонтекста |
56 | 8 | Всеволод Дорофеев | Процедура ЗаполнитьНаСервере(НовыйОбъект); |
57 | 8 | Всеволод Дорофеев | НовыйОбъект.Наименование = "Новый элемент"; |
58 | 8 | Всеволод Дорофеев | Для К=1 По 100 Цикл |
59 | 8 | Всеволод Дорофеев | НоваяСтрока = НовыйОбъект.ТЧ.Добавить(); |
60 | 8 | Всеволод Дорофеев | НоваяСтрока.РеквизитТЧ = К; |
61 | 8 | Всеволод Дорофеев | КонецЦикла; |
62 | 8 | Всеволод Дорофеев | КонецПроцедуры |
63 | 8 | Всеволод Дорофеев | </pre> |
64 | 10 | Всеволод Дорофеев | |
65 | 10 | Всеволод Дорофеев | h3. 4. Передача параметров в управляемых формах |
66 | 10 | Всеволод Дорофеев | |
67 | 10 | Всеволод Дорофеев | Параметры передаются в виде структуры: |
68 | 10 | Всеволод Дорофеев | |
69 | 10 | Всеволод Дорофеев | <pre> |
70 | 10 | Всеволод Дорофеев | Параметры = Новый Структура("ТекущееЗначение",ПоследнийЭлемент); |
71 | 10 | Всеволод Дорофеев | ФормаВыбора = ПолучитьФорму("Справочник.Номенклатура.ФормаВыбора",Параметры); |
72 | 10 | Всеволод Дорофеев | НайденыйЭлемент = ФормаВыбора.ОткрытьМодально(); |
73 | 10 | Всеволод Дорофеев | </pre> |
74 | 10 | Всеволод Дорофеев | |
75 | 10 | Всеволод Дорофеев | Также у управляемой формы появились «расширения формы» (объект, справочник, документ, отчет). В зависимости от типа объекта определяется состав доступных параметров. Например, если в форме выбора справочника нужно позиционироваться на определенном элементе, то используется параметр «ТекущееЗначение». Большим плюсом является, что в самой форме не требуется писать обработчиков для предопределенных параметров, сокращает количество кода. |
76 | 10 | Всеволод Дорофеев | |
77 | 10 | Всеволод Дорофеев | Также у разработчика появилась возможность определять свои параметры (в конструкторе управляемой формы вкладка «Параметры»). Время жизни параметров ограничено обработчиком ПриСозданииНаСервере, что логично т.к. параметры требуются только при создании формы, но если данный параметр определяет уникальность формы (установлен флаг «ключевой параметр» в свойствах параметра) он будет доступен и в других обработчиках. |
78 | 10 | Всеволод Дорофеев | |
79 | 10 | Всеволод Дорофеев | Для передачи специфического параметра манипуляций требуется сделать немного больше: |
80 | 10 | Всеволод Дорофеев | |
81 | 10 | Всеволод Дорофеев | 1. Определить в управляемой форме параметр. |
82 | 10 | Всеволод Дорофеев | |
83 | 10 | Всеволод Дорофеев | В обработчике ПриСозданииНаСервере определить обработку данного параметра (обращение к переданным параметрам через свойство «Параметры», имеющее тип ДанныеФормыСтруктура) |
84 | 10 | Всеволод Дорофеев | |
85 | 10 | Всеволод Дорофеев | 1. Описать получение формы и передать значение нового параметра в параметрах функции ПолучитьФорму. |
86 | 10 | Всеволод Дорофеев | |
87 | 10 | Всеволод Дорофеев | Таким образом код будет иметь вид: |
88 | 10 | Всеволод Дорофеев | |
89 | 10 | Всеволод Дорофеев | В месте получения формы |
90 | 10 | Всеволод Дорофеев | <pre> |
91 | 10 | Всеволод Дорофеев | Параметры = Новый Структура("НовыйПараметр",ПоследнийЭлемент); |
92 | 10 | Всеволод Дорофеев | ФормаВыбора = ПолучитьФорму("Справочник.Номенклатура.ФормаВыбора",Параметры); |
93 | 10 | Всеволод Дорофеев | </pre> |
94 | 10 | Всеволод Дорофеев | |
95 | 10 | Всеволод Дорофеев | В модуле управляемой формы |
96 | 10 | Всеволод Дорофеев | <pre> |
97 | 10 | Всеволод Дорофеев | &НаСервере |
98 | 10 | Всеволод Дорофеев | Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка) |
99 | 10 | Всеволод Дорофеев | Если Параметры.Свойство("НовыйПараметр") Тогда |
100 | 10 | Всеволод Дорофеев | // здесь код обработки параметра |
101 | 10 | Всеволод Дорофеев | КонецЕсли; |
102 | 10 | Всеволод Дорофеев | КонецПроцедуры |
103 | 10 | Всеволод Дорофеев | </pre> |
104 | 11 | Всеволод Дорофеев | |
105 | 12 | Всеволод Дорофеев | h3. 4. Отбор в таблице значений, расположенной на форме |
106 | 11 | Всеволод Дорофеев | |
107 | 11 | Всеволод Дорофеев | Например, отбор строк в подчиненной таблице при смене "Владельца" в основной таблице |
108 | 11 | Всеволод Дорофеев | <pre> |
109 | 11 | Всеволод Дорофеев | &НаКлиенте |
110 | 11 | Всеволод Дорофеев | Процедура ИсходнаяНоменклатураПриАктивизацииСтроки(Элемент) |
111 | 11 | Всеволод Дорофеев | |
112 | 11 | Всеволод Дорофеев | Структура = Новый Структура("ИсходнаяНоменклатура", Элементы["ИсходнаяНоменклатура"].ТекущиеДанные.Номенклатура); |
113 | 11 | Всеволод Дорофеев | НовыйОтбор = Новый ФиксированнаяСтруктура(Структура); |
114 | 11 | Всеволод Дорофеев | Элементы["НоваяНоменклатура"].ОтборСтрок=НовыйОтбор; |
115 | 11 | Всеволод Дорофеев | |
116 | 11 | Всеволод Дорофеев | КонецПроцедуры |
117 | 11 | Всеволод Дорофеев | |
118 | 11 | Всеволод Дорофеев | </pre> |
119 | 13 | Всеволод Дорофеев | |
120 | 13 | Всеволод Дорофеев | h3. Вопрос в управляемых формах |
121 | 13 | Всеволод Дорофеев | |
122 | 13 | Всеволод Дорофеев | Замена функции "Вопрос(...)" |
123 | 13 | Всеволод Дорофеев | |
124 | 13 | Всеволод Дорофеев | <pre> |
125 | 13 | Всеволод Дорофеев | &НаКлиенте |
126 | 13 | Всеволод Дорофеев | Процедура ЗадатьВопрос(Команда) |
127 | 13 | Всеволод Дорофеев | |
128 | 13 | Всеволод Дорофеев | ПоказатьВопрос(Новый ОписаниеОповещения("ОбработкаОтветаЗавершение", ЭтотОбъект), "Табличная часть будет очищена. Продолжить?", РежимДиалогаВопрос.ДаНет); |
129 | 13 | Всеволод Дорофеев | |
130 | 13 | Всеволод Дорофеев | КонецПроцедуры |
131 | 13 | Всеволод Дорофеев | |
132 | 13 | Всеволод Дорофеев | &НаКлиенте |
133 | 13 | Всеволод Дорофеев | Процедура ОбработкаОтветаЗавершение(РезультатВопроса, ДополнительныеПараметры) Экспорт |
134 | 13 | Всеволод Дорофеев | |
135 | 13 | Всеволод Дорофеев | Ответ = РезультатВопроса; |
136 | 13 | Всеволод Дорофеев | |
137 | 13 | Всеволод Дорофеев | Если Ответ <> КодВозвратаДиалога.Да Тогда |
138 | 13 | Всеволод Дорофеев | |
139 | 13 | Всеволод Дорофеев | Возврат; |
140 | 13 | Всеволод Дорофеев | |
141 | 13 | Всеволод Дорофеев | КонецЕсли; |
142 | 13 | Всеволод Дорофеев | |
143 | 13 | Всеволод Дорофеев | //Выполнение действий на положительный ответ |
144 | 13 | Всеволод Дорофеев | |
145 | 13 | Всеволод Дорофеев | КонецПроцедуры |
146 | 13 | Всеволод Дорофеев | |
147 | 13 | Всеволод Дорофеев | </pre> |
148 | 14 | Всеволод Дорофеев | |
149 | 14 | Всеволод Дорофеев | h3. Подключение внешней компоненты из макета внешней обработки |
150 | 14 | Всеволод Дорофеев | |
151 | 14 | Всеволод Дорофеев | Стандартное подключение макета из встроенной обработки: |
152 | 14 | Всеволод Дорофеев | <pre> |
153 | 14 | Всеволод Дорофеев | ПодключениеВыполнено = ПодключитьВнешнююКомпоненту("Обработка.ВстроеннаяОбработка.Макет.КомпонентаПечатиШтрихкодовLinux64", "КартинкаШтрихкода", ТипВнешнейКомпоненты.Native); |
154 | 14 | Всеволод Дорофеев | </pre> |
155 | 14 | Всеволод Дорофеев | |
156 | 14 | Всеволод Дорофеев | Подключение внешней компоненты из макета внешней обработки |
157 | 14 | Всеволод Дорофеев | <pre> |
158 | 14 | Всеволод Дорофеев | ПодключениеВыполнено = ПодключитьВнешнююКомпоненту(ПоместитьВоВременноеХранилище(ПолучитьМакет("КомпонентаПечатиШтрихкодовLinux64")), "КартинкаШтрихкода", ТипВнешнейКомпоненты.Native); |
159 | 14 | Всеволод Дорофеев | </pre> |
160 | 15 | Всеволод Дорофеев | |
161 | 15 | Всеволод Дорофеев | h3. Методы ПоместитьВоВременноеХранилище и ПолучитьИзВременногоХранилища |
162 | 15 | Всеволод Дорофеев | |
163 | 15 | Всеволод Дорофеев | источник http://catalog.mista.ru/public/198766/ |
164 | 15 | Всеволод Дорофеев | |
165 | 15 | Всеволод Дорофеев | Временное хранилище – секретное оружие |
166 | 15 | Всеволод Дорофеев | |
167 | 15 | Всеволод Дорофеев | При работе с управляемыми формами быстро становится ясно, что ограничения клиент-серверного взаимодействия очень сильно сужают возможности разработчика. Поэтому, платформа 1С предоставляет хитрый секретный ход под названием «ВременноеХранилище». Эта сущность позволяет сохранить на сервере некоторое состояние между двумя серверными вызовами. Я слышу возгласы: «А кто сказал, что состояние нельзя хранить!» Справедливое замечание, состояние хранить все-таки можно, но недолго. |
168 | 15 | Всеволод Дорофеев | |
169 | 15 | Всеволод Дорофеев | Временное хранилище позволяет оставить на сервере некоторые данные, а вместо них получить короткую строку – адрес временного хранилища. Этот адрес можно передать на клиента, там он будет спокойно лежать, а когда понадобятся данные из хранилища, то мы по этому адресу сможем их получить. |
170 | 15 | Всеволод Дорофеев | |
171 | 15 | Всеволод Дорофеев | Для работы со временным хранилищем используются методы ПоместитьВоВременноеХранилище и ПолучитьИзВременногоХранилища. |
172 | 15 | Всеволод Дорофеев | |
173 | 15 | Всеволод Дорофеев | С методом «Получить» все просто, он по заданному адресу возвращает значение, которое лежит в хранилище. |
174 | 15 | Всеволод Дорофеев | |
175 | 15 | Всеволод Дорофеев | С методом «Поместить» несколько сложнее. Дело в том, что помещать можно в 2 разных хранилища – простое и хранилище формы. Хранилище формы живет на сервере столько, сколько живет сама форма. Простое хранилище живет ровно 2 серверных вызова. В синтакс-помощнике об этом написано целых несколько умных строк. Я никогда не понимал, что они означают. Опытным путем было установлено, что срок жизни – 2 серверных вызова. |
176 | 15 | Всеволод Дорофеев | |
177 | 15 | Всеволод Дорофеев | Первый – мы помещаем что-то в хранилище и возвращаем адрес на клиента. |
178 | 15 | Всеволод Дорофеев | Клиент делает второй вызов и по этому адресу может получить данные. |
179 | 15 | Всеволод Дорофеев | В третьем вызове по этому адресу уже ничего не будет. Платформа очистит хранилище |
180 | 15 | Всеволод Дорофеев | |
181 | 15 | Всеволод Дорофеев | С хранилищем формы ситуация более интересная. Если вторым параметром метода «ПоместитьВоВременноеХранилище» передать идентификатор формы (ЭтаФорма.УникальныйИдентификатор), то данные в хранилище будут привязаны к сроку жизни формы и не будут удалятся ни в первых, ни во вторых, ни во всех прочих вызовах сервера. |
182 | 15 | Всеволод Дорофеев | |
183 | 15 | Всеволод Дорофеев | Таким образом, временное хранилище, это еще одно место, в котором (помимо реквизитов формы) можно сохранять состояние на сервере. Причем, в хранилище можно хранить даже данные, которые на клиенте недоступны, а стало быть, в реквизитах формы их разместить нельзя. |
184 | 16 | Всеволод Дорофеев | |
185 | 16 | Всеволод Дорофеев | |
186 | 16 | Всеволод Дорофеев | h3. Динамический список? Обработка выделенных строк |
187 | 16 | Всеволод Дорофеев | |
188 | 16 | Всеволод Дорофеев | <pre> |
189 | 16 | Всеволод Дорофеев | Для каждого Эл из Элементы.СписокСпецификаций.ВыделенныеСтроки Цикл |
190 | 16 | Всеволод Дорофеев | Сообщить(Элементы.СписокСпецификаций.ДанныеСтроки(Эл).СпецификацияСсылка); |
191 | 16 | Всеволод Дорофеев | КонецЦикла; |
192 | 16 | Всеволод Дорофеев | </pre> |