Главная и подчиненная таблицы в 1С - связывание, дополненное управляемыми формами для 8.2 и 8.3

14.08.20

Разработка - Механизмы платформы 1С

Главная и подчиненная таблицы в 1С - связывание для управляемых форм 8.2 и 8.3

Скачать исходный код

Наименование Файл Версия Размер
Главная и подчиненная таблицы в 1С - связывание, дополненное для 8.2 :
.epf 7,51Kb
2
.epf 7,51Kb 2 Скачать

Связывание главной и подчиненной таблиц для обычных форм описано в публикации infostart.ru/public/186522/. Для использования на управляемых формах код нужно изменить.

 

Ниже привожу работоспособный код для управляемого приложения:
 

&НаКлиенте
Процедура ГлавнаяТаблицаПриНачалеРедактирования(Элемент, НоваяСтрока, Копирование)
    
    Данные = Элементы.ГлавнаяТаблица.ТекущиеДанные;
    Если НоваяСтрока Тогда
        Данные.КлючСвязи = Новый УникальныйИдентификатор;
    КонецЕсли;
    
КонецПроцедуры

&НаКлиенте
Процедура ПодчиненнаяТаблицаПриНачалеРедактирования(Элемент, НоваяСтрока, Копирование)
        
    Данные = Элементы.ГлавнаяТаблица.ТекущиеДанные;
    ТекДанные = Элементы.ПодчиненнаяТаблица.ТекущиеДанные;
    Если НоваяСтрока Тогда
        ТекДанные.КлючСвязи = Данные.КлючСвязи;
    КонецЕсли;
    СтрОтбора = Новый ФиксированнаяСтруктура("КлючСвязи", Данные.КлючСвязи);
    Элементы.ПодчиненнаяТаблица.ОтборСтрок = СтрОтбора;

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

&НаКлиенте
Процедура ГлавнаяТаблицаПередУдалением(Элемент, Отказ)
    
    Данные = Элементы.ГлавнаяТаблица.ТекущиеДанные;
    Отбор = Новый Структура("КлючСвязи",Данные.КлючСвязи);
    Масс = Объект.ПодчиненнаяТаблица.НайтиСтроки(Отбор);
    Для каждого Строка из Масс Цикл
         Объект.СкидкиНаценки.Удалить(Строка);
    КонецЦикла;

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

&НаКлиенте
Процедура ГлавнаяТаблицаПриАктивизацииСтроки(Элемент)
    
    Данные = Элементы.ГлавнаяТаблица.ТекущиеДанные;
    Если Данные = Неопределено Тогда
        Возврат;
    КонецЕсли;
    СтрОтбора = Новый ФиксированнаяСтруктура("КлючСвязи", Данные.КлючСвязи);
    Элементы.ПодчиненнаяТаблица.ОтборСтрок = СтрОтбора;
    
    
КонецПроцедуры

чтобы не выдавало ошибки при добавлении строки в подчиненную таблицу при пустой основной таблице надо добавить :

&НаКлиенте
Процедура ПодчиненнаяТаблицаПередНачаломДобавления(Элемент, Отказ, Копирование, Родитель, Группа)
    
    Данные = Элементы.ГлавнаяТаблица.ТекущиеДанные;   
    Если Данные = Неопределено Тогда
      Отказ = Истина;
    КонецЕсли;

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

В файле пример для Управляемого приложения. Работоспособность обработки тестировалась на версии платформы 8.3.4+.  Будет работать на всех конфигурациях управляемых форм.

Пример Главная и подчиненная таблицы в для управляемых форм 8.2 8.3

См. также

Сервисы интеграции без Шины и интеграции

Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Пример использования «Сервисов интеграции» без подключения к Шине и без обменов.

13.03.2024    2567    dsdred    16    

59

Поинтегрируем: сервисы интеграции – новый стандарт или просто коннектор?

Обмен между базами 1C Администрирование СУБД Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

В платформе 8.3.17 появился замечательный механизм «Сервисы интеграции». Многие считают, что это просто коннектор 1С:Шины. Так ли это?

11.03.2024    5924    dsdred    55    

83

Как готовить и есть массивы

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

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

24.01.2024    5876    YA_418728146    25    

68

Планы обмена VS История данных

Обмен между базами 1C Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Вы все еще регистрируете изменения только на Планах обмена и Регистрах сведений?

11.12.2023    6979    dsdred    36    

113

1С-ная магия

Механизмы платформы 1С Бесплатно (free)

Язык программирования 1С содержит много нюансов и особенностей, которые могут приводить к неожиданным для разработчика результатам. Сталкиваясь с ними, программист начинает лучше понимать логику платформы, а значит, быстрее выявлять ошибки и видеть потенциальные узкие места своего кода там, где позже можно было бы ещё долго медитировать с отладчиком в поисках источника проблемы. Мы рассмотрим разные примеры поведения кода 1С. Разберём результаты выполнения и ответим на вопросы «Почему?», «Как же так?» и «Зачем нам это знать?». 

06.10.2023    19077    SeiOkami    46    

118

Дефрагментация и реиндексация после перехода на платформу 8.3.22

Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Начиная с версии платформы 8.3.22 1С снимает стандартные блокировки БД на уровне страниц. Делаем рабочий скрипт, как раньше.

14.09.2023    12781    human_new    27    

76

Валидация JSON через XDTO (включая массивы)

WEB-интеграция Универсальные функции Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

При работе с интеграциями рано или поздно придется столкнуться с получением JSON файлов. И, конечно же, жизнь заставит проверять файлы перед тем, как записывать данные в БД.

28.08.2023    9408    YA_418728146    6    

143

Внешние компоненты Native API на языке Rust - Просто!

Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Внешние компоненты для 1С можно разработывать очень просто, пользуясь всеми преимуществами языка Rust - от безопасности и кроссплатформенности до удобного менеджера библиотек.

20.08.2023    6528    sebekerga    54    

95
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. yuraos 991 23.05.13 14:22 Сейчас в теме
2. yuraos 991 23.05.13 14:27 Сейчас в теме
(1), плюс за находчивость!
дополнил побыстрому чужую статью.
а первый пост к статье советую всегда заполнять самому...
3. alex_shkut 62 15.08.13 10:53 Сейчас в теме
Правильно сделал. Я с управляемыми формами не работал, поэтому и писал "по старинке". А человек переписал грамотно и доделал недоделанное.
4. kirillbul 06.01.14 15:13 Сейчас в теме
Отличное дополнение статьи!
5. Vlad_kansk 2 29.02.16 07:20 Сейчас в теме
6. mikl79 118 21.03.16 15:16 Сейчас в теме
Добрый день.
В 3-й процедуре вы удаляете строку Объект.СкидкиНаценки, что это?
Наверное так Объект.ПодчиненнаяТаблица
7. bayce 45 27.08.20 18:29 Сейчас в теме
(6)можете протестировать на обработке, приложенной к публикации.
8. mikl79 118 28.08.20 11:35 Сейчас в теме
(7), Долго пришлось ждать ответа )))
9. v.a.ryag 37 16.02.24 12:29 Сейчас в теме
Немного предложений по коду:
1. В нескольких методах вы получаете значение до условия, а используете его только в условии. В этом случае целесообразнее и значение получать в условии. Вместо
    Данные = Элементы.ГлавнаяТаблица.ТекущиеДанные;
    Если НоваяСтрока Тогда

пишем
    Если НоваяСтрока Тогда
    Данные = Элементы.ГлавнаяТаблица.ТекущиеДанные;

2. Фрагмент кода с отбором можно вынести в отдельную процедуру УстановитьОтборВПодчиненнойТаблице(КлючСвязи) и передавать туда только КлючСвязи
    СтрОтбора = Новый ФиксированнаяСтруктура("КлючСвязи", Данные.КлючСвязи);
    Элементы.ПодчиненнаяТаблица.ОтборСтрок = СтрОтбора;
Оставьте свое сообщение