Как программно установить тип реквизита
Автор Алексей_1985_06, 24 мая 2022, 20:08
0 Пользователей и 1 гость просматривают эту тему.
Уважаемые товарищи, подскажите вот с таким вопросом:
1. Создан реквизит «Комплекс» с составным типом данных (СправочникСсылка.ТехническиеКомплексы, СправочникСсылка.СтартовыеКомплексы)
2. Созданы два реквизита формы ТК (булево) и СК (булево)
3. Необходимо что бы при ТК = Истина, реквизит «Комплекс» — имел тип СправочникСсылка.ТехническиеКомплексы, а при СК = Истина реквизит «Комплекс» — имел тип СправочникСсылка.СтартовыеКомплексы.
Или кто подскажет может по другому как-то реализуется процесс определения типа данных реквизита в зависимости от значения другого реквизита (типа Булево)
Непонятно, зачем переустанавливать типы? У вас они уже назначены составным типом. При записи элементов справочника в этот реквизит, тип сам будет устанавливаться в нужный.
Я бы действовал в обратную сторону. При записи в реквизит «Комплекс» элемент из СправочникСсылка.ТехническиеКомплексы, присваивать ТК = Истина. А при записи СправочникСсылка.СтартовыеКомплексы — СК = Истина.
Алексей_1985_06, сильно зависит от того какие формы, управляемые или обычные, действительно, когда у реквизита составной тип
(и не два как у вас а десяток) до задалбывает каждый раз для перевыбора элемента того-же типа, сначала выбирать этот-же тип а затем и сам элемент
для избежания этого, использую такой код
&НаКлиенте
в вашем случае
Процедура ТаблицаОбработкиДубльНачалоВыбора(Элемент, ДанныеВыбора, СтандартнаяОбработка)
лкТекушаяСтрока = Элементы.СсылкиДублей.ТекущиеДанные;
Если лкТекушаяСтрока <> Неопределено Тогда
Элемент.ВыбиратьТип = Не ЗначениеЗаполнено(лкТекушаяСтрока.Значение);
КонецЕсли;
КонецПроцедуры
вообще отключите возможность выбора Типа,
а при использовании булевых переключателей в их событии ПриИзменении(..), реквизиту Комплекс присваивайте Пустую ссылку нужного справочника!
тогда по кнопке Выбор, будут выбираться элементы из этого справочника.
- 3 пользователя сказали спасибо!
если помогло нажмите: Спасибо!
LexaK, Большое Вам спасибо за помощь!!!!
|
|||
dart909
28.07.15 — 15:04 |
Добрый день, подскажите пожалуйста Как у значения реквизита формы программно задать произвольный тип? |
||
grigo
1 — 28.07.15 — 15:05 |
Не уверен, но, кажется, никак |
||
Kondarat
2 — 28.07.15 — 15:07 |
(0) ПривестиЗначение()? |
||
dart909
3 — 28.07.15 — 15:07 |
(2) Вы меня спрашиваете?) Это я задал такой вопрос) |
||
DmitrO
4 — 28.07.15 — 15:10 |
Реквизит = Новый РеквизитФормы(«Реквизит1», Новый ОписаниеТипов); |
||
Nuobu
5 — 28.07.15 — 15:23 |
(4) ОТ_Произвольный = Новый ОписаниеТипов(«Неопределено»); |
||
DmitrO
6 — 28.07.15 — 15:34 |
(5)так тоже можно. |
||
grigo
7 — 28.07.15 — 15:35 |
хм. а существующему реквизиту можно перезадать тип? просто интересно. |
||
Nuobu
8 — 28.07.15 — 15:42 |
(7) Нет. |
||
grigo 9 — 28.07.15 — 15:46 |
(8) ясно, спс. |
TurboConf — расширение возможностей Конфигуратора 1С
Для этого можно присвоить реквизиту формы значение пустой ссылки нужного типа. Одного из тех типов, которые входят в составной тип.
Например, для поля ввода, связанного с реквизитом, который может принимать значение ссылки на справочники физических и юридических лиц, назначение нужного типа может выглядеть следующим образом:
Объект.ОтветЛицо = ПредопределенноеЗначение("Справочник.ФизическиеЛица.ПустаяСсылка");
Если запретить выбор типа в поле ввода (свойство ВыбиратьТип), то реквизиту ОтветЛицо будет назначен тип ссылки на справочник ФизическиеЛица, и для выбора будут предлагаться значения только этого справочника.
Также можно использовать свойство поля ввода ОграничениеТипа, задающее возможные типы данных, которые могут быть введены в поле ввода, и приводить значение соответствующего реквизита к нужному типу:
Массив = Новый Массив(); Массив.Добавить(Тип("СправочникСсылка.ФизическиеЛица")); НашеОписание = Новый ОписаниеТипов(Массив);
Элементы.ОтветЛицо.ОграничениеТипа = НашеОписание; Объект.ОтветЛицо = НашеОписание.ПривестиЗначение(Объект.ОтветЛицо);
Показывать по
10
20
40
сообщений
Новая тема
Ответить
Мозголом
Дата регистрации: 27.02.2007
Сообщений: 145
Платформа: 1С 8.2<br>Конфигурация: 1С УТ 10.3, 1С: Розница<br> <br>Описание: на форме имеется табличная часть, у которой есть некоторый реквизит. Он составной. По умолчанию я его делаю Номенклатурой и документом Установка Цен. При работе просто выбираю необходимый мне тип и заполняю значение в каждой строке.<br> <br>Вопрос: как программно назначать тип реквизиту. нужно чтобы обработка была универсальна, а для этого нужно чтобы для УТ типы были Номенклатура и становка Цен, а для Розницы Номенклатура и Установка цен в магазине (это документ). Вот собственно вопрос: можно ли программно в зависимости от того, какая конфигурация загружена, назначать тип выбираемого реквизита в таблице?<br> <br>P.S.: Прошу в ответе не учитывать метод определения конфигурации, это моя проблема и я ее решил.
Prikum
активный пользователь
офлайн
Дата регистрации: 18.02.2002
Сообщений: 20842
«<pre>// установим тип Справочник.Контрагенты<br>МойРеквизит = Справочники.Контрагенты.ПустаяСсылка(); <br></pre>»
Мозголом
Дата регистрации: 27.02.2007
Сообщений: 145
А если мне нужно чтобы назначалось 2 типа? справочник и документ? чтобы потом при работе уже выбирать нужный тип для каждой строки
Prikum
активный пользователь
офлайн
Дата регистрации: 18.02.2002
Сообщений: 20842
Мозголом
Дата регистрации: 27.02.2007
Сообщений: 145
При создании обработки для реквизита я могу казать, что он составного типа, и выбрать для него типы «СправочникСсылка.Номенклатура» и «ДокументСсылка.УстановкаЦенНоменклатуры». При интерактивном вводе строки я сначала выбираю значение какого типа мне нужно добавить в таблицу, а потом выбираю уже непосредственно нужный мне элемент, исходя из типа.<br>Так вот собственно вопрос: можно ли программным способом назначать, какие типы мне можно будет выбрать при добавлении строки в таблицу?<br> <br>Можно конечно просто добавить типы «СправочникСсылка» и «ДокументСсылка», но тогда конечный пользователь может запутаться при добавлении строки. Поэтому выбор типа нужно ограничить.
Мозголом
Дата регистрации: 27.02.2007
Сообщений: 145
«А все, разгадал загадку. Вот такое решение я принял:<br> <br><br><pre>Процедура ТабличнаяЧасть1Реквизит1НачалоВыбора(Элемент, СтандартнаяОбработка) // Вставить содержимое обработчика. ТипСпр = Тип(«СправочникСсылка.Номенклатура»); ТипДок = Тип(«ДокументСсылка.УстановкаЦенНоменклатуры»); Если ТипЗнч(Элемент.Значение) <> ТипСпр И ТипЗнч(Элемент.Значение) <> ТипДок Тогда Массив = Новый Массив; Массив.Добавить(ТипСпр); Массив.Добавить(ТипДок); ОписаниеТипов = Новый ОписаниеТипов(Массив); Элемент.ОграничениеТипа = ОписаниеТипов; КонецЕсли;КонецПроцедуры </pre><br><br> <br>ТипДок могу менять в зависимости от конфигурации и настроек обработки.<br> <br>Статья, где нашел примерный метод: http://v8.1c.ru/metod/faq/answer.jsp?id=176″
Показывать по
10
20
40
сообщений
Просматривая Волшебный форум, наткнулся на тему, в которой коллега интересовался возможностью отключения выбора типа в элементе табличной части справочника при программной установке значения в реквизите составного типа. Приведу часть своего кода, всю тему можно посмотреть здесь.
&НаКлиенте Процедура ДобавитьВалюту(Команда) ТС = Объект.ТЧ.Добавить(); ТС.Имя = "Валюта"; ТС.Значение = ПредопределенноеЗначение("Справочник.Валюты.ПустаяСсылка"); Элементы.ТЧ.ПодчиненныеЭлементы.ТЧЗначение.ВыбиратьТип = Ложь; КонецПроцедуры
После решил добавить решению универсальности и реализовать программное формирование контекстного меню для табличной части справочника с составным реквизитом с заранее неизвестным перечнем типов.
Создаем справочник, имя произвольное. Добавляем табличную часть ТЧ, реквизиты Имя, тип Строка, Значение, тип составной. Для своего примера я установил Строка, Дата, Число, СправочникСсылка. В форме элемента добавляем реквизит ФормаТипы, тип ОписаниеТипов.
Остальное за нас сделает код:
&НаСервере Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка) //формируем массив типов и удаляем тип текущего справочника, //поскольку у нас тип значения включает все справочники фТипы = РеквизитФормыВЗначение("Объект").Метаданные().ТабличныеЧасти.ТЧ.Реквизиты.Значение.Тип.Типы(); фИндекс = фТипы.Найти(ТипЗнч(Объект.Ссылка)); фТипы.Удалить(фИндекс); //помещаем новое описание типов в реквизит формы ФормаТипы = Новый ОписаниеТипов(фТипы); //формируем группу контекстного меню фГруппа = Элементы.Добавить("ГруппаДополнительно", Тип("ГруппаФормы"), Элементы.ТЧКонтекстноеМеню); фГруппа.Заголовок = "Добавить..."; мТипы = ФормаТипы.Типы(); Для сч = 0 По мТипы.ВГраница() Цикл //создаем команды формы, имена формируются с учетом индекса текущего типа в массиве типов //потом по этому индексу в имени будем определять необходимый тип данных ИндексКоманды = Формат(сч, "ЧН=0; ЧГ=0"); фКоманда = Команды.Добавить("КомандаДобавитьТипСтроки_" + ИндексКоманды); фКоманда.Действие = "ДобавитьЭлементТипа"; кЭлемент = Элементы.Добавить("ДобавитьТипСтроки_" + ИндексКоманды, Тип("КнопкаФормы"), фГруппа); кЭлемент.Заголовок = Строка(мТипы[сч]); кЭлемент.Вид = ВидКнопкиФормы.КнопкаКоманднойПанели; кЭлемент.ИмяКоманды = фКоманда.Имя; КонецЦикла; КонецПроцедуры &НаКлиенте Процедура ДобавитьЭлементТипа(Команда) //определяем индекс для массива типов ИндексТипа = Число(СтрЗаменить(Команда.Имя, "КомандаДобавитьТипСтроки_", "")); сТип = ФормаТипы.Типы()[ИндексТипа]; ТС = Объект.ТЧ.Добавить(); ТС.Имя = Строка(сТип); мТипы = Новый Массив; мТипы.Добавить(сТип); //формируем новое описание типов и приводим к пустому значению этого типа ТипТС = Новый ОписаниеТипов(мТипы); ТС.Значение = ТипТС.ПривестиЗначение(); Элементы.ТЧЗначение.ВыбиратьТип = Ложь; КонецПроцедуры &НаКлиенте Процедура ТЧПередНачаломДобавления(Элемент, Отказ, Копирование, Родитель, Группа) //при добавлении через стандартную команду формы будем выбирать тип Элементы.ТЧЗначение.ВыбиратьТип = Истина; КонецПроцедуры
Теперь запускаем конфигурацию и добавляем элемент нашего справочника. При использовании стандартной команды формы Добавить перед выбором значения мы будем выбирать его тип. При добавлении через программно сформированные пункты контекстного меню значение будет приводиться к необходимому типу.
Задача.
Например, есть табличная часть с двумя колонками «ВидПоступленияДС» и «Аналитика». Поле «Аналитика» может содержать значения составного типа. Необходимо, в зависимости от введенного значения в поле «ВидПоступленияДС», установить нужный тип для поля «Аналитика».
Решение.
В событии «ПриИзменении» поля ввода «ВидПоступленияДС» пропишем следующий код:
&НаКлиенте
Процедура ОсновнаяВидПоступленияДСПриИзменении(Элемент)
ТекСтрока = Элементы.Основная.ТекущиеДанные;
Если ТекСтрока.ВидПоступленияДС = ПредопределенноеЗначение("Перечисление.ВидыПоступленияДС.ОплатаОтКлиента") Тогда
ОписаниеТипов = Новый ОписаниеТипов("СправочникСсылка.Контрагенты");
ИначеЕсли ТекСтрока.ВидПоступленияДС = ПредопределенноеЗначение("Перечисление.ВидыПоступленияДС.ПрочиеПоступленияДС") Тогда
ОписаниеТипов = Новый ОписаниеТипов("СправочникСсылка.СтатьиПриходаДС");
Иначе
ТекСтрока.Аналитика = Неопределено;
Возврат;
КонецЕсли;
ТекСтрока.Аналитика = ОписаниеТипов.ПривестиЗначение(ТекСтрока.Аналитика);
КонецПроцедуры
barracuda1991 1 / 1 / 1 Регистрация: 30.07.2015 Сообщений: 121 |
||||
1 |
||||
1C 8.x Интерактивное изменение типа значения поля ввода на форме07.09.2016, 12:30. Показов 17166. Ответов 4 Метки нет (Все метки)
Здравствуйте! Подскажите, можно ли программно прописать, чтобы после выбора типа значения в поле списка (на форме) автоматически менялся тип значения в поле ввода (имеющий составной тип данных в конфигураторе)?
Миниатюры
0 |
Dethmontt Модератор 3708 / 2905 / 572 Регистрация: 10.03.2011 Сообщений: 11,442 Записей в блоге: 1 |
||||
07.09.2016, 17:15 |
2 |
|||
barracuda1991, да, присвоив пустое значение нужного типа полюВвода Добавлено через 3 минуты
1 |
barracuda1991 1 / 1 / 1 Регистрация: 30.07.2015 Сообщений: 121 |
||||
08.09.2016, 09:33 [ТС] |
3 |
|||
{Форма.Форма.Форма(492)}: Поле объекта недоступно для записи (ПолеВвода1)
Спасибо.
0 |
Модератор 3708 / 2905 / 572 Регистрация: 10.03.2011 Сообщений: 11,442 Записей в блоге: 1 |
|
08.09.2016, 23:26 |
4 |
ЭлементыФормы.ПолеВвода1 = ОТ.ПривестиЗначение(); зачем ЭлементыФормы ???
ПолеВвода1 = ОТ.ПривестиЗначение(); Где я тут что то писал про элементыФормы ??? Добавлено через 39 секунд
0 |
0 / 0 / 0 Регистрация: 12.11.2015 Сообщений: 1 |
|
17.05.2017, 21:39 |
5 |
Добавлено через 24 секунды
Сообщение от barracuda1991 Если ограничивать тип для ЭлементыФормы.ПолеВвода1 тогда не «слетает» значение реквизита ПолеВвода1 если она уже правильного типа, ИМХО лучше через ЭлементыФормы
0 |