В числе таких слабостей, к примеру, невозможность подписки на события обычных форм (смотри следующую статью Трюки 1С 8 – Управление обычными формами из общего модуля ) или на событие изменения показателей любого регистра накопления(статья еще не написана).
Для затравки начну с небольшого трюка, связанного со штатным механизмом выбора из подчиненного справочника. Покажу его на реальном примере в конфигурации Комплексная Автоматизация.
При выборе серии номенклатуры по кнопке выбора в табличной части Товары документов СчетНаОплатуПокупателю или РеализацияТоваровУслуг штатный механизм связи (через указание номенклатуры-владельца) выводит на экран все серии для номенклатуры из текущей строки табличной части. Хотя логично было бы ожидать только серии, зарегистрированные на складе, который указан в соответствующем документе.
Казалось бы, напрашивается очевидная и простейшая доработка – добавить в отбор списка серий номенклатуры в форме выбора элемент отбора по нашему складу. Но не все так просто - в форме выбора извне доступно только значение ВладелецФормы, которое является полем ввода серии номенклатуры в форме документа. Платформа не позволяет перейти от элемента управления к форме документа, которая его содержит (наряду с нужным нам полем ввода Склад в шапке формы). К тому же в справочнике серий номенклатуры нет реквизита Склад.
Воспользуемся тем, что предопределенность объектов конфигурации влечет за собой некоторую избыточность их состава. Из нескольких десятков реквизитов любого объекта конфигурации обычно реально используются и инициализируются программистом не более десятка. Посмотрим пристальнее на поле ввода серии номенклатуры и увидим в нем строковый реквизит Подсказка, который обычно пуст и вполне может сгодиться на роль контрабандиста для наших реквизитов.
Суть трюка – перед переходом в форму выбора серий номенклатуры из поля ввода мы добавляем в его реквизит Подсказка ссылку на текущий документ, добавив обработчик события НачалоВыбора:
Процедура ТоварыСерияНоменклатурыНачалоВыбора(Элемент, СтандартнаяОбработка)
Элемент.Подсказка = Элемент.Подсказка + "$Link$" + ЗначениеВСтрокуВнутр(Ссылка);
КонецПроцедуры
Теперь в форме выбора можно обратиться к форме документа и любым ее элементам, например, реквизиту Склад (и заодно восстановить исходную подсказку):
Процедура ПриОткрытии()
…
ЭлементУправления = ЭтаФорма.ВладелецФормы;
ТекстПодсказки = ЭлементУправления.Подсказка;
ПозицияСсылки = Найти(ТекстПодсказки, "$Link$");
Если ПозицияСсылки > 0 Тогда
ДокСсылка = ЗначениеИзСтрокиВнутр(Сред(ТекстПодсказки, ПозицияСсылки + 6));
Склад = ДокСсылка.ПолучитьФорму().Склад;
ЭлементУправления.Подсказка = Лев(ТекстПодсказки, ПозицияСсылки - 1);
КонецЕсли;
…
Используя значение Склад, можно запросом выбрать список кодов нужных серий номенклатуры и использовать его в дополнительном элементе отбора:
СправочникСписок.Отбор.Код.Использование = Истина;
СправочникСписок.Отбор.Код.ВидСравнения = ВидСравнения.ВСписке;
СправочникСписок.Отбор.Код.Значение = СписокКодовСерийНоменклатуры;
В приложенном файле – полный код процедуры ПриОткрытии формы выбора (КА 1.1, 1С 8.2).
Штатный подход в обычных формах, как отметил в комментарии awk, более прямолинейный:
Процедура ТоварыСерияНоменклатурыНачалоВыбора(Элемент, СтандартнаяОбработка)
СтандартнаяОбработка = Ложь;
Форма = Справочники.СерииНоменклатуры.ПолучитьФорму(,Элемент);
Форма.СправочникСписок.Отбор.Код.Использование = Истина;
Форма.СправочникСписок.Отбор.Код.ВидСравнения = ВидСравнения.ВСписке;
Форма.СправочникСписок.Отбор.Код.Значение = СписокКодовСерийНоменклатуры;
// и т.п.
Форма.Открыть();
КонецПроцедуры
т.е. мы отказываемся от стандартной обработки, инициализируем и открываем форму выбора самостоятельно.
Если же обратиться к управляемым формам, то там инструментарий стал еще более обширным (см. комментарий Поручика или, более развернуто, статью //infostart.ru/public/198797/).