Серверные вызовы, которые нельзя вызывать

Публикация № 1225834

Разработка - Практика программирования

код ПриАктивацииСтроки уф сп баг цикл ошибка

Не баян, а классика. Рассмотрим особенность платформы настолько же древнюю, как сами УФ.

Встречали ли такое? Создаёшь себе событие у таблицы формы. Никого не трогаешь.

 

А тут бац - нельзя создать процедуру на сервере. Неожиданно

 

Почему? Можно, конечно, почитать в Синтаксис Помощнике... Но зачем? Опять, небось, платформа косячит! Поэтому часто разработчики пытаются её перехитрить:

Выбирают создание "на сервере без контекста"

 

и удаляют текст "БезКонтекста"

 

Платформа не ругается, проверки синтаксиса проходят. Profit!!!

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

Обратимся всё же к Синтаксис Помощнику:

 

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

Более того:

В обработчике данного события нельзя использовать серверные методы формы с директивой компиляции &НаСервере, а также изменять свойства, которые могут привести к серверному вызову

Что это значит? Что в ПриАктивацииСтроки() нельзя изменять Заголовок, Доступность, Подсказку и т.д. Проверить это легко:

 

Так а почему? Самый быстрый пример:

 

Изменение заголовка колонки приводит к обращению к серверу. На этой гифке можно лицезреть результат - бесконечный цикл платформы:

 

Как это работает? Событие ПриАктивацииСтроки изменяет свойство, которое выполняет обращение к серверу, что снова вызывает событие ПриАктивизацииСтроки. И так до бесконечности (или же до падения платформы).

А вот ещё одно интересное поведение. Допустим, в ПриАктивацииСтроки() код выпал в ошибку:

 

Если это произойдёт в клиентском методе, то всё хорошо. Пользователь закроет окошко с ошибкой и продолжит работать:

 

То же произойдёт в методе НаСервереБезКонтекста

 

Но стоит применить директиву &НаСервере, как будет интересное поведение.

 

Теперь ошибка будет повторяться бесконечно. И ничего, кроме завершения работы сеанса, не поможет пользователю избавиться от неё.

 

Вот такая незадача.

Но проблема не только в ПриАктивацииСтроки(). Есть и другие методы, например, ПередНачаломИзменения(). В каждом из таких методов будет описан соответствующий комментарий в Синтаксис Помощнике. Что будет, если нарушить его указания?

Вот такое поведение нам удалось поймать на "продуктиве".

Суть кода: ПередНачаломИзменения() код обращается на сервер, делает запрос и получает строку, которую нужно присвоить в свойство поля формы "ПодсказкаВвода".

Мы же для примера приведем упрощенную реализацию без запроса.

В нашей тестовой обработке ПередНачаломИзменения() у нас срабатывает процедура:

 

 

Далее: в обработке имеется ОбязательнаяКолонка. И, если её не заполнить, произойдёт такое:

 

Ничего не обычного, всё работает. Но! Если вдруг пользователь откроет обработку и, не кликая на таблицу, нажмёт на кнопку проверки, то произойдёт падение с записью дампа:

 

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

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

 

1. Не обращаемся к серверу

Часто разработчики делают то, что им не нужно (или так, как нет нужды). Далеко не всегда нужно обращаться на сервер. И далеко не всегда нужно производить действия, которые к этому приведут. Можно пересмотреть код в таких событиях. Например, в нашей ситуации с бесконечным изменением заголовка группы формы, можно воспользоваться свойством "ПутьКДаннымЗаголовка".

Для этого добавляем строковый реквизит:

 

А в свойствах группы указываем его:

 

А в коде меняем не заголовок группы, а значение строкового реквизита:

 

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

2. Используем &НаСервереБезКонтекста

Чаще всего обращения к серверу в подобных событиях можно сделать &НаСервереБезКонтекста. Просто далеко не всегда разработчик задумывается об этом заранее. Нужны данные формы в методе? Можно их передать. Чаще всего этого достаточно, главное - не лениться.

3. Запоминаем обработанную строку

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

Добавляет числовой реквизит формы (или общую переменную формы "ТекущаяСтрока"). И дорабатываем наш метод:

 

4. Обработчик ожидания

Можно использовать обработчик ожидания. Например, в ПриАктивацииСтроки() не выполнять серверный код напрямую, а выполнять одноразовое выполнение обработчика ожидания, в котором уже происходят нужные действия.

 

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

 

Выводы

При разработке, старайтесь внимательно читать СП\ИТС и следовать рекомендациям. Можно, конечно, следовать принципу "главное работает". А в какой-то момент столкнуться с неожиданным поведением платформы. Потому что, в описанных нами примерах, ошибки могут вылезти в самый неожиданный момент. И уже на продуктиве =)

P.S.: А вообще, раз уж описан такой запрет в СП, то почему бы не сделать его на уровне проверки синтаксиса платформы? ¯\_(-_-)_/¯

 

Понравилась статья?

Не будьте равнодушными! Поставьте лайк плюс и переходите к другим статьям:

Специальные предложения

Комментарии
Избранное Подписка Сортировка: Древо развёрнутое
Свернуть все
1. Rustig 1415 12.05.20 09:12 Сейчас в теме
(0) интересное исследование. спасибо.
"Меньше копипаста!", или как Вася универсальную процедуру писал

хочу спросить про старую публикацию: Вася в конце концов дописал свою универсальную процедуру или нет?
gubanoff; +1 Ответить
2. SeiOkami 1461 12.05.20 09:14 Сейчас в теме
(1) Да, там в самом конце есть спойлер с "Окончательная Васина процедура"
adhocprog; +1 Ответить
3. Darklight 22 12.05.20 09:52 Сейчас в теме
Отличная статья на малоизвестную тему ситуации, с которой легко столкнуться,но очень трудно понять в чём дело и открыть правильный раздел в синтаксис помощнике! Я, вот, сталкивался с такой проблемой, но как-то не задумывался в её причинах и не удосужился об этом прочитать в синтаксис помощнике.
ТЕПЕРЬ БУДУ ЗНАТЬ!
Статья МАСТ РИД всем!
Решал ранее переменной флагом мТакоеТоСобытиеВызвано - когда обработчик вызывался первый раз - флаг выставлял и выполнял серверный вызов - когда второй раз - сбрасывал флаг и выходил из обработчика.
Кстати в статье тут единственное место - к чему я бы придрался - плохо описано в п.3 применение переменной "ТекущаяСтрока" - надо было указать что это глобальная переменная моудля формы (или реквизит формы) и если это переменная то правильно было назвать её с префиксом м "мТекущаяСтрока" - но это мелочи.

Вот бы ещё проблему ошибки "Неизвестный идентификатор формы" побороть, когда после некоторых серверных вызовов при очередном серверном вызове возникает такая ошибка (встречал частенько в разных управляемых формах)
Вот этот, последний, случай возникает при применении общей типовой формы отчета в ЗУП 3.1 во внешнем отчёта (сначала формирую отчет с одним вариантом, а затем переключаю на другой - и ошибка):

Неизвестный идентификатор формы
{ОбщаяФорма.ФормаОтчета.Форма(886)}: ЗагрузитьВариант(ВариантФормы.КлючВарианта);

по причине:
Неизвестный идентификатор формы


Повторное формирование отчета уже закрывает форму с ошибкой

Информация для технической поддержки



Причём когда сделал свою форму с таким вот обработчиков формирования (из общей формы)

&НаКлиенте
Процедура Сформировать()
	ВыполнятьЗамеры = НастройкиОтчета.ВыполнятьЗамеры И ЗначениеЗаполнено(НастройкиОтчета.КлючЗамеров);
	Если ВыполнятьЗамеры Тогда
		Комментарий = НастройкиОтчета.ПрефиксЗамеров + "; " + НСтр("ru = 'Непосредственно:'") + " " + Строка(Непосредственно);
		МодульОценкаПроизводительностиКлиент = ОбщегоНазначенияКлиент.ОбщийМодуль("ОценкаПроизводительностиКлиент");
		ИдентификаторЗамера = МодульОценкаПроизводительностиКлиент.ЗамерВремени(
			НастройкиОтчета.КлючЗамеров + ".Формирование",
			Ложь, Ложь);
		МодульОценкаПроизводительностиКлиент.УстановитьКомментарийЗамера(ИдентификаторЗамера, Комментарий);
	КонецЕсли;
	
	Результат = РезультатФормированияОтчета(ФормированиеПриОткрытии, НастройкиОтчета.Внешний Или НастройкиОтчета.Безопасный);
	Если Результат = Неопределено Тогда 
		Возврат;
	КонецЕсли;
	
	Если Результат.Статус <> "Выполняется" Тогда 
		ПослеФормирования(Результат, Ложь);
		Возврат;
	КонецЕсли;
	
	Обработчик = Новый ОписаниеОповещения("ПослеФормирования", ЭтотОбъект, Истина);
	ПараметрыОжидания = ДлительныеОперацииКлиент.ПараметрыОжидания(ЭтотОбъект);
	ПараметрыОжидания.ВыводитьОкноОжидания = Ложь;
	
	ДлительныеОперацииКлиент.ОжидатьЗавершение(Результат, Обработчик, ПараметрыОжидания);
КонецПроцедуры
Показать


Проблема сохоранилась (и кстати, обработчики объекта отчета "ПриКомрпоновкеРезультат" вообще не запускался.

Решил только переходом на классическое формирование отчета через встроенную команду формы "Сформировать" (ну или через программный вызов метода формирования у формы).

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

Конечно - это может быть другая проблема не правильной работы в управляемых формах, достойная отдельной статьи, а может быть и следствием проблемы не правильного вызова обработчиков событий. Но тогда как она проявляется в типовой общей форме, ведь я в ней ничего не трогал, а просто применил в своё внешнем отчёте (причём неявно - просто как форму по умолчанию)
SeiOkami; +1 Ответить
4. SeiOkami 1461 12.05.20 10:15 Сейчас в теме
(3)

Вот бы ещё проблему ошибки "Неизвестный идентификатор формы" побороть, когда после некоторых серверных вызовов при очередном серверном вызове возникает такая ошибка (встречал частенько в разных управляемых формах)


Да, натыкался на этот баг. Даже где-то себе сохранил заметку с небольшим исследованием. Нужно будет вернуться и разобраться в ситуации подробнее. Спасибо за наводку 👍
7. Darklight 22 12.05.20 17:34 Сейчас в теме
(4)Кстати в том же (уже "исправленном" отчёте) у меня ещё периодически и такая ошибка "Ошибка создания источника доступных настроек компоновки данных" возникает (при повторной компоновке отчёта - тестировал на копии, на рабочей серверной базе то же самое) при повторном формировании отчета (после того как открываю типовую форму настроек отчета):
Информация для технического специалиста

И сеанс закрывается!
Перед этим ещё и слетает настройка параметров отчета СКД.
Что-то со значением параметра - я в список добавил значение перечисления
8. Darklight 22 13.05.20 18:35 Сейчас в теме
(7)Всё стало ещё хуже.
Во-первых, эта ошибка проявляется только из под отладки
Во-вторых, я взял предыдущую версию отчета (где проблемы нет) - сохранил её в отдельный файл (без изменений) и в нём эта проблема ПОЯВИЛАСЬ!
Причём пробовал на нескольких релизах - последний, который удалось скачать 8.3.16.1224 для windows - та же фигня (достаточно один раз сформировать отчёт из формы настроек, при повторном формировании - ошибка):

Платформа: 1С:Предприятие 8.3 (8.3.16.1224)
Конфигурация: Зарплата и управление персоналом, редакция 3.1 (3.1.13.146) (http://v8.1c.ru/hrm/)
Copyright © ООО "1С-Софт", 2010 - 2020. Все права защищены
(http://www.1c.ru)
Режим: Файловый (без сжатия)
Приложение: Тонкий клиент
Локализация: Информационная база: русский (Россия), Сеанс: русский
Вариант интерфейса: Такси

Ошибки:
--------------------------------------------------------------------------------
13.05.2020 18:33:46
Ошибка создания источника доступных настроек компоновки данных
397873d4-1833-4fd3-a7cf-29c08d162916


И настройки СКД слетают


(кстати, а что там с релизами - скачивая архивы с более поздними релизами получают какую-то лабуду внутри архивов - какие-то JAVA пакеты утилиты Ring, причём архивы дистрибутивов весят по пол гига, а 7zip показывает что внутри всего 12 мегабайт)!
10. Darklight 22 14.05.20 17:40 Сейчас в теме
(8)С дистрибутивом 1С разобрался - оказалось 1С сменил версию архиватора RAR с 2.9 на 5.0, а я распаковывал старой версией 7zip - обновил его - и всё нормально распаковалось - соответственно - попробовал последний (на текущий момент) релиз платформы 1С 8.3.17.1386 - проблема осталась.
Заодно понял что проблема связана была с тем, что при возврате из типовой формы настроек в типовую (копию) форму отчёта запускался встроенный в неё алгоритм формирования отчёта

Процедура Сформировать()


- а он, по непонятным пока мне причинам, выводит мой отчёт из строя.
Поэтому заменил его вот таким кодом (вызываю из начала вышеназванной процедуры и выхожу из неё)

Процедура СформироватьСервер()


Но не могу понять почему работает предыдущая версия отчёта! И почему она перестаёт работать если её просто сохранить в новый файл.
Могут только предположить, что тут что-то связано с системой учета вариантов отчётов в БСП. В отчёте есть два встроенных варианта (иные не используются), правда в отчёте есть алгоритм, запускаемый после загрузки варианта, на севере, меняющий в нём настройки параметров на фиксированные. Но при закрытии окна настроек (сохранить и сформировать) этот алгоритм не запускается.
Не могу понять - что такого трансендентного у меня в отчёте сделано!
13. FlyVodolaz 21.05.20 19:12 Сейчас в теме
(8) Если это форма внешнего отчета/обработки то серверная часть 1С, при отсутствии серверных вызовов какое-то время, может "забыть" эту форму. Соответственно и адрес во временном хранилище становится недействительным. Но из-за этого не только теряются данные во временном хранилище. Но и любой серверный вызов приведет к ошибке идентификатора формы. Попробуйте нечто такое добавить:
&НаКлиенте
Процедура Пинг()
	ПингСервер();
КонецПроцедуры

&НаСервереБезКонтекста
Процедура ПингСервер()
	Жив=Истина;
КонецПроцедуры

&НаКлиенте
Процедура ПриОткрытии(Отказ)
	ПодключитьОбработчикОжидания("Пинг", 60, Ложь);
КонецПроцедуры
Показать
14. Darklight 22 21.05.20 22:45 Сейчас в теме
(13)Да внешний отчёт. Но в остальном - не вариант - ошибка стабильна - срабатывает сразу как открыть отчёт и выполнить в нём вышеназванный код (первый раз он отрабатывает хорошо - ну а потом любые серверные вызовы приводят к указанной ошибке). Причём есть работающая версия отчёта (где как ни странно этот типовой код в типовой форме работает) - ничего в нём не трогаю - просто сохраняют его из конфигуратора повторно - и всё - больше он не работает!
15. SeiOkami 1461 22.05.20 06:40 Сейчас в теме
(14) а если сохранить отчёт как внешний, проверить его "сломанность", а потом поместить его же в конфу?
Дело ли в том, что падает именно будучи внешним?
23. Darklight 22 22.05.20 17:01 Сейчас в теме
(15)Вставил отчёт в конфигурацию - обновил вспомогательные данные - запустил - проблемы нет :-|
Правда перед этим ещё рабочая старая копия, таки, тоже перестала работать :-( хотя я её не трогал а ранее она точно работала - вообще мистика!
Предыдущая копия тоже перестала работ как внешний отчёт.
Но, будучи, вставленным в конфигурацию - отчет таких ошибок не выдаёт, варианты СКД подключились и тоже работают!
Но почему не работает внешний отчёт (именно указанный типовой код)?
Не... ну могут тоже попробовать сам что-нибудь переместить во временное хранилище и просмотреть что будет дальше с внешним отчётом и вне данного типового кода....
24. FlyVodolaz 22.05.20 17:52 Сейчас в теме
(23)
Но почему не работает внешний отчёт

Я же писал, при отсутствии серверных вызовов какое-то время, может "забыть" эту форму. Время забытия зависит от многих факторов и 1С их не документирует. Основное скорее всего наличие свободной памяти. В общем это как с повторно возвращаемыми значениями, никто не знает сколько они будут жить. В вашем случае в форме вариантов отчетов скорее всего разворачиваются настройки схемы компоновки, что достаточно затратно по памяти
26. Darklight 22 25.05.20 09:38 Сейчас в теме
(24)Уверен на 100% что дело не в этом!
Во-первых, как уже писал, проблема проявляется и под файловой базой.
Во-вторых, как уже писал, проблема проявляется только из под отладки (а сейчас уточняю - сама отладка оказалась не причём - проблема возникает только если 1С: Предприятие запускается с параметром (аргументом командной строки) "РежимОтладки" - т.е. в типовых алгоритмах формирования отчёта (см мой пост (3))) что-то отрабатывает по-разному (возможно разница в том, что в режиме "РежимОтладки" не используются фоновые задания).
В-третьих, проблема возникает только в типовом коде из поста (3), когда меняю на свой - проблемы нет
В-четвёртых, у Вас в посте (13) идёт пинг сервера каждые 60 - мне чтобы дажды сформировать отчёт хватает и 30 секунд - проблема успевают возникнуть
В-пятых, я применил Ваш код из (13) и даже уменьшил период опроса до 5 секунд - проблема ОСТАЛАСЬ!
В-шестых, памяти на компьютере у меня доффига - схема СКД не такая уж большая и данные в ней тоже занимают не много (там нет больших таблиц в параметрах и отборах)
5. -vito- 452 12.05.20 11:16 Сейчас в теме
Виталий, предлагаю включить сюда же информацию и о внешне безобидном коде
&НаКлиенте
...
ДанныеСтроки = Элементы.Список.ТекущиеДанные;


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

Существуют как минимум 2 альтернативных способа получить данные строки списка на клиенте, без серверного вызова.

а) поиском нужной строки в таблице (реквизит)
ТекущиеДанные = КроссТаблица.НайтиПоИдентификатору(Элементы.КроссТаблица.ТекущаяСтрока);


б) методом ДанныеСтроки таблицы формы (элемент)
ТекущиеДанные = Элементы.Зарплата.ДанныеСтроки(Элементы.Зарплата.ТекущаяСтрока);
mirco; Новиков; EVKash; m.biryukov; Aletar; herfis; C0mmander_Alex; fancy; the1; Vortigaunt; adhocprog; independ; SeiOkami; nomad_irk; acanta; +15 Ответить
6. nomad_irk 49 12.05.20 11:23 Сейчас в теме
(5)Мы столкнулись с этим когда пытались понять, почему форма договоров в УХ, на которую навешаны RLS очень сильно тупит при открытии и перемещении курсора по списку договоров. Переделали через

ТекущиеДанные = КроссТаблица.НайтиПоИдентификатору(Элементы.КроссТаблица.ТекущаяСтрока);

и все стало просто летать по сравнению с тем, что было до этого.
C0mmander_Alex; asg.aleks; SeiOkami; acanta; +4 Ответить
11. herfis 363 14.05.20 18:02 Сейчас в теме
Самое для меня полезное в этой статье - это комментарий (5)
16. VZyryanov 22.05.20 09:08 Сейчас в теме
(5) Разработчики 1С не в курсе, что ТекущиеДанные плохо использовать на клиенте.
В 1С:Бухгалтерия 3.0 Элементы.Список.ТекущиеДанные на клиенте вызывается в куче мест, например, ОбщаяФорма.НалогиИОтчеты.Форма.Модуль
&НаКлиенте
Процедура ВопросПередСменойОрганизации
17. -vito- 452 22.05.20 10:40 Сейчас в теме
(16) Владимир, разработчики 1С - такие же люди, как и мы с Вами. Разработчики Платформы - тоже. Мир не идеален.
Никто из нас с этим "сакральным знанием" не родился. Когда у меня падали клиентские процессы, разобраться в причине помог отдел ЦКТП 1С. В большинстве случаев этот код работает нормально. Но при каких-то условиях "что-то идет не так".
18. SeiOkami 1461 22.05.20 10:41 Сейчас в теме
(17) а не помните, как можно воспроизвести ситуацию?
Хочу провести эксперименты
19. -vito- 452 22.05.20 12:44 Сейчас в теме
(18)
а не помните, как можно воспроизвести ситуацию?

Виталий, не было выявлено каких-то явных особенностей, которые позволили бы воспроизвести проблему.
Код был в Процедуре ПриАктивацииСтроки()
стрПлатежнаяЗаявка = Элементы.Список.ТекущиеДанные;'

У нескольких пользователей (из общего числа около 1000), аварийно завершались клиентские процессы десятки раз в день. Воспроизвести ситуацию не удавалось. Отправлял дампы упавших процессов в ЦКТП 1С.
20. Дмитрий74Чел 188 22.05.20 12:51 Сейчас в теме
(17), (18) у меня не получается воспроизвести. Создал внешнюю обработку с дин.списком. В ПриАктивизацииСтроки() указал лДанные = Элементы.Список.ТекущиеДанные;
И никаких серверных вызовов в замере производительности или счетчике вызовов.
8.3.15.1830
21. SeiOkami 1461 22.05.20 13:15 Сейчас в теме
(20) да, в нормальной ситуации нет вызовов. И в СП про это ни слова.
Но, догадываюсь, что это какой-то определенный волшебный случай. Хочется найти способ имитировать проблему...
28. -vito- 452 27.05.20 17:37 Сейчас в теме
(21) Кто-то у меня пытался спросить откуда информация о неявном серверном вызове, но удалил комментарий.
Всё же отвечу:
Информация из переписки с сотрудниками ЦКТП 1С при расследовании инцидента.
Цитата из письма:
К падению приводит работа вот этого кода:
вызываемого из подписки на событие ПриАктивизацииСтроки()
стрПлатежнаяЗаявка = Элементы.Список.ТекущиеДанные;'
Код небезопасен тк делает неявные серверные вызовы в Элементы.Список.ТекущиеДанные.

В отладке с включенным замером производительности у меня отображались эти серверные вызовы. Но, что интересно, не всегда. Предположу, что это связано с состоянием закешированных данных формы и/или другими факторами.
Еще одна цитата из той же переписки, в ответ на вопрос "что влияет":
Тут много факторов имеет влияние. Например объем отображаемых данных.
Могу предположить что пользователи у которых "падало" занимались активной работой в данной форме.

Платформа, на которой проявлялась проблема - 8.3.10.2561. На других не проверял.
22. VZyryanov 22.05.20 13:50 Сейчас в теме
(17) Типовая БП 3.0.70.52, глобальный поиск по модулям. Найдено:
.ТекущиеДанные - 14575
Элементы.Список.ТекущиеДанные - 380
.НайтиПоИдентификатору( - 834
.ДанныеСтроки( - 103

1С использует все 3 способа получения данных строки. ТекущиеДанные используется, похоже, чаще других способов.
Возможно, есть ошибка платформы. Поэтому я буду стараться обходиться без использования ТекущиеДанные.
9. dhurricane 13.05.20 19:58 Сейчас в теме
Спасибо за исследовательскую работу. Порой для юных специалистов аргумент "в СП указан явный запрет" как таковым аргументом не является. "У меня же работает." Благодаря Вам теперь у меня есть и способы воспроизведения возможных проблем.
12. unichkin 1248 17.05.20 23:26 Сейчас в теме
Если ПриАктивизации.. необходим вызов сервера, надо ставить условие на наличие данных, защиту от повторного вызова, и подключать обработчик ожидания. Имхо, это можно уже назвать классическим решением)
25. olegarch 6 23.05.20 18:52 Сейчас в теме
Есть демонический список Реквизит1. Есть обработчик активизации строки.
Вроде как разрешенная штука:

&НаСервереБезКонтекста
Процедура Реквизит1ПриАктивизацииСтрокиНаСервере()
	// Вставить содержимое обработчика.
КонецПроцедуры

&НаКлиенте
Процедура Реквизит1ПриАктивизацииСтроки(Элемент)
	Реквизит1ПриАктивизацииСтрокиНаСервере();
КонецПроцедуры
Показать


Тем не менее, как минимум на 8.3.12..8.3.14 вызов Реквизит1ПриАктивизацииСтрокиНаСервере() поломает множественный выбор строк.
Точнее, выделить-то можно будет, а вот отменить выбор одной строки...
27. Albert_2008 26.05.20 12:57 Сейчас в теме
Спасибо за исследование. "3. Запоминаем обработанную строку" - запомню, когда нибудь попробую.
Оставьте свое сообщение

См. также

3 онлайн-курса по 1С-программированию: обмен данными, расчетные задачи и бухгалтерские задачи с 12 мая по 8 июля 2020 г. Промо

Практика программирования v8 Бесплатно (free)

Пакет из 3-х курсов по 1С-программированию. Основная цель - сформировать у слушателей практические навыки, связанные с реализацией задач обмена для прикладных решений, работающих на платформе “1С:Предприятие”, а также с разработкой прикладных решений, предназначенных для автоматизации расчета заработной платы и задач бухгалтерского учета.

22.04.2020    3161    23    infostart    2    

Программная работа с настройками СКД

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

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

27.01.2020    14909    0    ids79    26    

[СКД] Программное создание схемы компоновки данных

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

Сделаем отчет на СКД полностью программно, без использования макета "схема компоновки данных".

15.01.2020    15532    0    John_d    22    

Последовательности событий. Шпаргалка

Практика программирования v8 Россия Бесплатно (free)

Собрал информацию о событиях/подписках/расширениях в одном месте.

30.12.2019    10675    0    kuzyara    33    

Использование программных перечислений, ч.1: строковые константы Промо

Практика программирования v8 1cv8.cf Бесплатно (free)

Часто ли у вас возникает необходимость в коде выполнять сравнение на строку?

10.12.2016    34146    0    unichkin    45    

30 задач. Странных и не очень

Практика программирования v8 Бесплатно (free)

30 задач на знание языка программирования 1С и некоторого поведения платформы. Маленьких. Странных и не очень.

02.12.2019    12720    0    YPermitin    72    

Таблица значений. Нюансы

Практика программирования v8 Бесплатно (free)

Обзор некоторых аспектов использования общеизвестного инструмента 1С.

01.10.2019    25295    0    Yashazz    44    

Оповещения боту из 1С за 31 минуту

Практика программирования Интеграция v8::УФ 1cv8.cf Бесплатно (free)

Поделюсь опытом, как быстро сделать бота с оповещениями в Телеграмм из 1С без лишних затрат.

18.09.2019    14873    4    feva    35    

Вспомогательные инструкции в коде 1С Промо

Практика программирования v8 1cv8.cf Бесплатно (free)

Помогаем редактору кода 1С помогать нам писать и анализировать код.

15.10.2018    26131    0    tormozit    100    

[Шпаргалка] Программное создание элементов формы

Практика программирования Работа с интерфейсом v8 1cv8.cf Бесплатно (free)

Программное создание практически всех популярных элементов формы.

06.09.2019    34653    0    rpgshnik    59    

Агрегатные функции СКД, о которых мало кто знает

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

Пользуетесь ли Вы всеми возможными агрегатными функциями, которые предоставляет система компоновки данных? Если Вы используете только: СУММА, КОЛИЧЕСТВО, МИНИМУМ, МАКСИМУМ, СРЕДНЕЕ, то эта статья для Вас.

05.09.2019    36822    0    ids79    52    

Регистры бухгалтерии. Общая информация

Практика программирования Математика и алгоритмы v8 v8::БУ БУ Бесплатно (free)

Общая информация о внутреннем устройстве регистров бухгалтерии.

05.09.2019    21541    0    YPermitin    24    

Оформление и рефакторинг сложных логических выражений Промо

Практика программирования v8 Россия Бесплатно (free)

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

20.09.2012    73637    0    tormozit    129    

Три костыля. Сказ про фокусы в коде

Практика программирования v8 Бесплатно (free)

Три интересных (или странных) костыля в коде, которые могут помочь в повседневных и не очень задачах.

03.09.2019    21801    0    YPermitin    80    

Отслеживание выполнения фонового задания

Практика программирования Универсальные функции Разработка v8 1cv8.cf Бесплатно (free)

Запуск фонового задания из модуля внешней обработки. Отслеживание выполнения задания в виде прогресса, расположенного на форме.

17.08.2019    25656    0    ids79    16    

Функции СКД: ВычислитьВыражение, ВычислитьВыражениеСГруппировкойМассив

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

Подробное описание и использование внутренних функций системы компоновки данных: Вычислить, ВычислитьВыражение, ВычислитьВыражениеСГруппировкойМассив, ВычислитьВыражениеСГруппировкойТаблицаЗначений.

08.08.2019    55746    0    ids79    37    

Запись значения в поле ввода/формы со срабатыванием события ПриИзменении Промо

Практика программирования v8 1cv8.cf Россия Бесплатно (free)

Иногда возникает необходимость после записи значения в какое либо поле ввода/формы вызвать для него обработчик события ПриИзменении, а о вызове самого события приходится только мечтать. В этой статье приводится программный способ вызова этого события.

11.07.2007    44725    0    tormozit    38    

Фоновое выполнение кода в 1С - это просто

Практика программирования v8 1cv8.cf Бесплатно (free)

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

02.08.2019    26350    0    avalakh    21    

Разбираемся с параметрами редактирования СКД

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

Связь по типу, Параметры выбора, Связи параметров выбора

31.07.2019    17100    0    json    12    

СКД - наборы данных и связи между ними, создание собственной иерархии, вложенные отчеты

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

Набор данных объект. Использование в схеме компоновки нескольких наборов данных. Различные варианты связи наборов: объединение, соединение. Использование иерархии в отчетах на СКД. Создание собственной иерархии, иерархия детальных записей. Использование вложенных схем в отчетах на СКД.

26.07.2019    42303    0    ids79    11    

Как сделать из &НаКлиентеНаСервереБезКонтекста почти &НаКлиентеНаСервере Промо

Практика программирования v8 1cv8.cf Россия Бесплатно (free)

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

10.09.2017    40484    0    tormozit    72    

СКД - использование расширений языка запросов, секция ХАРАКТЕРИСТИКИ

Инструментарий разработчика Практика программирования v8 v8::СКД Бесплатно (free)

Автоматическое и не автоматическое заполнение полей компоновки данных. Использование расширений языка запросов для СКД «{…}», секция ВЫБРАТЬ, секция ГДЕ, параметры виртуальных таблиц. Автоматизированное использование дополнительных данных в запросе: секция ХАРАКТЕРИСТИКИ.

17.07.2019    28465    0    ids79    27    

Регистры сведений. За кулисами

Практика программирования Разработка v8 1cv8.cf Бесплатно (free)

Небольшие заметки по внутреннему устройству регистров сведений.

09.07.2019    21422    0    YPermitin    13    

"Меньше копипаста!", или как Вася универсальную процедуру писал

Практика программирования Разработка v8 v8::СКД 1cv8.cf Бесплатно (free)

Программист Вася разбирает подход создания универсальных методов на примере программного вывода СКД.

04.07.2019    16455    0    SeiOkami    50    

Выгрузка документа по условию Промо

Практика программирования Разработка v8 Бесплатно (free)

Что делать, если документы нужно выгружать не все подряд, а по какому-то фильтру: статусу, дате, набору условий... А что если он соответствовал этим условиям, а потом перестал? А если потом опять начал? Такие ситуации заставили попотеть не одного программиста.

25.04.2019    14144    0    m-rv    2    

Создание отчетов с помощью СКД - основные понятия и элементы

Практика программирования Математика и алгоритмы v8 v8::СКД Бесплатно (free)

Основные принципы работы СКД. Понятия схемы компоновки и макета компоновки. Описание основных элементов схемы компоновки: наборы данных, поля, вычисляемые поля, ресурсы, параметры.

25.06.2019    42188    0    ids79    17    

Многопоточное ускорение однопользовательских нагрузок в 1С + Microsoft SQL Server 2017

Практика программирования Производительность и оптимизация (HighLoad) v8 v8::Запросы Бесплатно (free)

Взаимодействие с Microsoft SQL Server нередко вызывает трудности у 1С-ников, а потому интересны любые моменты, связанные с его использованием. О своем опыте работы с новым SQL Server 2017 участникам конференции Infostart-2018 рассказал директор ООО «Аналитика софт» Дмитрий Дудин.

11.06.2019    21375    0    dmurk    144    

Регистры накопления. Структура хранения в базе данных

Практика программирования Разработка v8 1cv8.cf Бесплатно (free)

Структура хранения регистров накопления в базе данных для платформы 1С:Предприятие 8.x. Первая часть в серии публикаций.

16.05.2019    35341    0    YPermitin    30    

Как прикрутить ГУИД к регистру сведений Промо

Практика программирования Перенос данных из 1C8 в 1C8 Разработка v8 Бесплатно (free)

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

16.04.2019    17738    0    m-rv    17    

Выполнение внешней обработки в фоновом задании

Практика программирования Разработка v8 1cv8.cf Бесплатно (free)

Подробное описание подхода к созданию длительной операции на основе внешней обработки. Реализация протестирована на 1С 8.3.12.1714 (x64).

11.05.2019    24178    0    Eret1k    23    

О расширениях замолвите слово...

Практика программирования Разработка v8 Бесплатно (free)

О чём стоит задуматься при принятии решения о создании расширения конфигурации…

07.04.2019    29237    0    ellavs    126    

Git-репозитории для 1С-кода (опыт использования при небольших проектах)

Практика программирования Разработка v8 Бесплатно (free)

Инструкции по взаимодействию с Git-репозиторием, которые писались для тех наших программистов, которые вообще никогда не работали с Git (руководства в духе "Как получить код из git-репозитория?", "Как отправить код в git-репозиторий")...

28.03.2019    23016    0    ellavs    86    

Как сделать запрос на изменение данных Промо

Практика программирования v8 v8::Запросы 1cv8.cf Бесплатно (free)

В статье приведены особенности внутренней архитектуры и примеры работы с расширением языка запросов 1С.

01.06.2018    27397    0    m-rv    21    

Трюки с внешними источниками данных

Практика программирования Разработка v8 1cv8.cf Бесплатно (free)

Некоторые трюки для преодоления ограничений внешних источников данных.

14.03.2019    26388    0    YPermitin    53    

Добавление отчетов в типовые конфигурации 1С

Практика программирования Универсальные функции БСП (Библиотека стандартных подсистем) v8::УФ v8::СКД 1cv8.cf Бесплатно (free)

Описание различных способов добавления общих и контекстных отчетов в конфигурации 1С, построенные на базе БСП. Основные моменты и нюансы.

07.03.2019    44916    0    ids79    45    

Разработка и сценарное тестирование с Vanessa-ADD. Отчетность Allure. Автоматизация запуска сценариев

Практика программирования Разработка v8 Россия Бесплатно (free)

Формируем отчетность о результатах выполнения сценариев. Автоматизируем запуск.

26.02.2019    18320    0    Vladimir Litvinenko    27    

Метод формирования движений в типовых регистрах нетиповыми регистраторами Промо

Практика программирования v8 1cv8.cf Бесплатно (free)

Вариант решения задач с проведением по типовым регистрам нетиповыми регистраторами. Зачем - чтобы при сравнении конфигурации не обращать внимание на свойства регистров и исключить вероятность допущения горькой оплошности при обновлении информационных баз, заменив типы регистраторов основной конфигурации типами конфигурации поставщика. Для программных продуктов, имеющих в своем составе метаданных документ "Корректировка регистров"("Корректировка записей регистров").

05.12.2017    25707    0    itriot11    34    

Функциональные опции 1С 8.3 – все возможные варианты использования

Практика программирования Разработка v8::УФ 1cv8.cf Бесплатно (free)

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

22.02.2019    28888    0    ids79    6    

Информирование пользователя. Работа с объектом «СообщениеПользователю»

Практика программирования Разработка v8::УФ 1cv8.cf Бесплатно (free)

Различные варианты и нюансы использования объекта СообщениеПользователю и другие способы информирования пользователя: без привязки к какой-либо форме и с выводом сообщения в отдельном окне.

15.02.2019    38548    0    ids79    47    

Возможности типовых шаблонов ограничения доступа на уровне записей (RLS)

Практика программирования БСП (Библиотека стандартных подсистем) Роли и права v8 v8::Права Бесплатно (free)

Краткий обзор применения типовых шаблонов ограничения доступа на уровне записей в конфигурациях, созданных на базе БСП: #ПоЗначениям, #ПоНаборамЗначений, #ПоЗначениямРасширенный, #ПоЗначениямИНаборамРасширенный

03.02.2019    31309    0    ids79    9    

Использование классов .Net в 1С для новичков Промо

Практика программирования Разработка внешних компонент Универсальные функции v7.7 v8 Бесплатно (free)

Руководство для новичков. Написав статью http://infostart.ru/public/238584/, я понял, что многие не понимают того, что написано. Поэтому в этой статье постараюсь более подробно остановиться на азах и без кода на вражеском языке (C#)

27.01.2016    70993    0    Serginio    108    

EnterpriseData – часть 2. Процесс выгрузки данных

Практика программирования Обмен через XML v8 v8::УФ Россия Бесплатно (free)

Основные этапы выгрузки данных через ED, обработчики событий выгрузки, правила обработки данных, правила конвертации объектов, конвертация свойств первого и второго этапов, процедуры БСП, используемые при выгрузке данных, структура «КомпонентыОбмена».

26.12.2018    22790    0    ids79    31    

Новый подход к обмену данными EnterpriseData

Практика программирования Обмен через XML v8 v8::УФ Россия Бесплатно (free)

Хочу предложить Вашему вниманию цикл статей, посвященных обмену данными через универсальный формат (EnterpriseData или ED).

14.12.2018    35047    0    ids79    72    

Автоматические и управляемые блокировки применительно к типовым конфигурациям 1С Промо

Математика и алгоритмы Практика программирования v8 v8::blocking 1cv8.cf Бесплатно (free)

Основные принципы работы с режимами автоматических и управляемых блокировок в 1С Предприятие 8. Теория и применение в типовых конфигурациях: БП, УТ, ЕРП

10.11.2018    30549    0    ids79    40    

EnterpriseData - пример доработки правил конвертации без использования КД 3.0 в расширении конфигурации

Практика программирования Обмен через XML v8 v8::УФ БП3.0 УТ11 Россия Бесплатно (free)

В статье подробно описан реальный пример доработки обмена данными через EnterpriseData (универсальный формат обмена) между конфигурациями УТ 11.4 и Бухгалтерия 3.0

16.11.2018    31674    0    ids79    32    

Программное заполнение пользовательских параметров и отборов СКД

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

Публикация представляет из себя краткие примеры того, как можно заполнять параметры СКД программно так, чтобы все параметры и отборы были доступны в быстрых настройках и в обычных (типовых) настройках параметров и отборов СКД.

13.11.2018    37314    0    Unk92    20    

Произвольный код в фоновом режиме

Практика программирования v8 1cv8.cf Бесплатно (free)

Задача: реализовать выполнение произвольного кода в фоновом режиме без изменения конфигурации, т.е. во внешней обработке.

03.09.2018    23885    0    nikita0832    42    

Тестер: частые вопросы Промо

Практика программирования v8 Бесплатно (free)

Ошибкам бой - тесты норма жизни!

25.07.2018    26219    0    grumagargler    26    

Основные понятия и механизмы оптимизации клиент-серверного взаимодействия в 1C

Математика и алгоритмы Практика программирования v8 Россия Бесплатно (free)

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

23.08.2018    34790    0    Rain88    46    

Работаем с дополнительными реквизитами на форме

Практика программирования v8 Бесплатно (free)

Пара полезных процедур для работы с дополнительными реквизитами на форме. Далее в статье: 1. Как называются дополнительные реквизиты на форме и в какой момент они появляются на форме? 2. Как проверить до записи корректность заполнения пользователем дополнительного реквизита? 3. Как заполнить значение дополнительного реквизита по другому событию и обновить данные на форме? 4. Как расположить дополнительный реквизит в указанном месте на форме?

15.07.2018    29294    0    papche    37    

Повышаем эффективность разработки правил обмена

Практика программирования Перенос данных из 1C8 в 1C8 v8 КД Бесплатно (free)

Как повысить скорость и качество разработки правил обмена? Как вести групповую разработку правил обмена? Как облегчить сопровождение правил обмена после передачи в эксплуатацию? Об этом и многом другом вы можете узнать из этой статьи.

25.06.2018    26105    0    olegtymko    47    

Введение в механизм представлений в ЗУП ред. 3

Практика программирования v8 v8::СПР ЗУП3.x Бесплатно (free)

В нашей организации на первом же телефонном собеседовании на должность разработчика по ЗУП ред. 3 вас обязательно спросят о том, что такое "Представления".

04.06.2018    34056    0    xrrg    82