Использование переменных в программных модулях
Область применения: управляемое приложение, мобильное приложение, обычное приложение.
1. В большинстве случаев, вместо переменных программных модулей следует использовать более подходящие средства разработки платформы 1С:Предприятие . Поскольку область видимости (использования) таких переменных сложно контролировать, то они зачастую становятся источником трудновоспроизводимых ошибок.
Примеры некорректного использования и исключений из этого правила приведены далее. Рекомендации по оформлению переменных в коде программных модулей см. в статье Структура модуля.
2. Неоправданные примеры использования переменных в модулях объектов (справочников, документов, наборов записей, обработок, отчетов и пр.).
2.1. Для передачи параметров между обработчиками подписок на события и в обработчики событий модуля объекта из внешнего кода рекомендуется использовать свойство объекта ДополнительныеСвойства . Например, неправильно:
Перем КонвертацияФайлов Экспорт;
Если КонвертацияФайлов Тогда
.
// вызывающий код
ФайлОбъект.КонвертацияФайлов = Истина;
ФайлОбъект.Записать();
Если ДополнительныеСвойства.Свойство(«КонвертацияФайлов») Тогда
.
// вызывающий код
ФайлОбъект.ДополнительныеСвойства.Вставить(«КонвертацияФайлов», Истина);
ФайлОбъект.Записать();
В то же время, для передачи внутренних параметров между обработчиками событий модуля объекта целесообразно использовать неэкспортные переменные модуля объекта, которые недоступны из внешнего кода.
Например:
Перем ПредыдущееЗначениеОрганизации; // значение реквизита «Организация» до записи объекта в базу
Процедура ПередЗаписью(Отказ)
ПредыдущееЗначениеОрганизации = . ; // с помощью запроса выясняем значение до записи объекта в базу
КонецПроцедуры
Процедура ПриЗаписи(Отказ)
Если ПредыдущееЗначениеРеквизита <> Организация Тогда
// отрабатываем изменение значения реквизита при записи
.
КонецЕсли;
2.2. Для обработки кодов возврата (ошибок) в логике программного модуля рекомендуется использовать строковые константы.
Например, неправильно:
Перем НетОшибок,
Ошибка_ОбработкиПроверкиЗаполнения, // возникает, если обработка проверки заполнения вернула отказ
Ошибка_ЗаписиОбъекта, // возникает, если во время записи объекта возникло исключение
Ошибка_БлокировкиОбъекта, // возникает, при попытке блокировки объекта
Процедура ВыполнитьПерерасчет()
.
Результат = ОбработатьДокументы(. );
Если Результат = Ошибка_ЗаписиОбъекта Тогда
.
ИначеЕсли Результат = Ошибка_БлокировкиОбъекта Тогда
.
ИначеЕсли .
НетОшибок = 1;
Ошибка_ОбработкиПроверкиЗаполнения = 2;
Ошибка_ЗаписиОбъекта = 3;
Ошибка_БлокировкиОбъекта = 4;
Процедура ВыполнитьПерерасчет()
.
Результат = ОбработатьДокументы(. );
Если Результат = «ОшибкаЗаписиОбъекта» Тогда
.
ИначеЕсли Результат = «ОшибкаБлокировкиОбъекта» Тогда
.
ИначеЕсли .
2.3. Для кеширования долго-вычисляемых и часто-используемых значений в процедурах и функциях рекомендуется применять модули с повторным использованием возвращаемых значений на время вызова сервера.
Исключение из этого правила составляют случаи, когда по соображениям безопасности возвращать результат вычисления в экспортной функции недопустимо. В этом случае они размещаются в локальной переменной модуля.
3. Неоправданные примеры использования переменных в модулях форм.
3.1. Для кеширования долго-вычисляемых и часто-используемых значений в процедурах и функциях рекомендуется применять модули с повторным использованием возвращаемых значений.
При этом не следует кешировать статическую и легко вычисляемую информацию. В частности, не следует кешировать в клиентских переменных модуля формы значения предопределенных элементов и перечислений. Для их получения на клиенте предназначен метод ПредопределенноеЗначение .
3.2. Для хранения и передачи промежуточных результатов вычислений между разными процедурами и функциями формы следует использовать
- Параметры процедур и функций – для передачи результатов по цепочке вызовов дочерних процедур и функций в контексте одного вызова.
- Реквизиты формы – если требуется сохранять промежуточные результаты между разными вызовами с клиента. (Следует иметь в виду, что значения серверных переменных модуля формы не сохраняются между вызовами с клиента.)
Исключение из этого правила составляют случаи использования клиентских переменных формы для хранения промежуточных результатов в обработчиках ожидания формы, в обработчиках внешних событий и в клиентских обработчиках событий элементов формы.
Например:
4. Переменные управляемого и обычного приложения следует использовать для хранения «клиентских параметров сеанса». Подробнее см. статью Использование параметров сеанса.
Как в 1С объявить глобальную переменную в модуле формы?
Подскажите люди добрые! Мне необходима глобальная переменная булевского типа, доступная в модуле формы на время существования самой формы. в модуле формы объявляю:
перем БесплатнаяДоставка; &НаКлиенте Процедура ПриОткрытии(Отказ) БесплатнаяДоставка = Ложь; КонецПроцедуры &НаКлиенте Процедура СуммаПриИзменении(Отказ) Если (Объект.Сумма > 1000) И (БесплатнаяДоставка = Ложь) Тогда . КонецЕсли; КонецПроцедуры
Ругается на переменную БесплатнаяДоставка , пишет «переменная не определена».
Отслеживать
задан 7 июл 2012 в 19:43
Sergey041691 Sergey041691
306 1 1 золотой знак 12 12 серебряных знаков 28 28 бронзовых знаков
2 ответа 2
Сортировка: Сброс на вариант по умолчанию
Перед описанием переменной обязательно должна быть указана директива компиляции (&НаКлиенте или &НаСервере).
Если используется директива компиляции &НаКлиенте, то такая переменная будет существовать с момента создания формы до момента ее закрытия. Причем только в клиентской части формы. Из серверных процедур формы она доступна не будет.
(с) Максим Радченко, 1С. Ветка форума.
Отслеживать
ответ дан 7 июл 2012 в 20:24
Yura Ivanov Yura Ivanov
26.4k 2 2 золотых знака 30 30 серебряных знаков 57 57 бронзовых знаков
Попробуйте объявить переменную в модуле формы с экспорт, и потом получая форму по уникальному идентификатору к ней обращатся. Если не секрет, вам оно зачем?
Отслеживать
ответ дан 11 сен 2014 в 13:55
deliversun deliversun
1 1 1 бронзовый знак
-
Важное на Мете
Похожие
Подписаться на ленту
Лента вопроса
Для подписки на ленту скопируйте и вставьте эту ссылку в вашу программу для чтения RSS.
Дизайн сайта / логотип © 2024 Stack Exchange Inc; пользовательские материалы лицензированы в соответствии с CC BY-SA . rev 2024.1.3.2953
Нажимая «Принять все файлы cookie» вы соглашаетесь, что Stack Exchange может хранить файлы cookie на вашем устройстве и раскрывать информацию в соответствии с нашей Политикой в отношении файлов cookie.
Переменные в 1С 8.2 и 8.3
Во встроенном языке программирования 1С используются переменные. Имена переменных должны начинаться с английского или русского символа, или подчеркивания. Нельзя чтобы наименование переменной начиналось с цифры. Не рекомендуется именовать переменные зарезервированными синтаксическими конструкциями. Имена переменных должны носить осмысленный характер. Это улучшает читабельность программного кода. Что в последующем увеличивает скорость разработки или доработки приложения. При объявлении переменных не требуется указывать тип значения, как это делается во многих других языках программирования. Тип значения определяется автоматически системой.
Локальные переменные
Локальные переменные определяются внутри процедур или функций. Перед ними необязательно писать ключевое слово «Перем». Область доступности таких переменных ограничена границами своей процедуры или функции. То есть, к такой переменной нельзя обратиться в другой процедуре или функции или из глобального контекста.
Функция РассчитатьСумму()
Сумма = 1;
Возврат Сумма;
КонецФункции;
Глобальные переменные
Во многих языках программирования предусмотрено создание глобальных переменных. Во встроенном языке 1С, так же есть возможность создавать глобальные переменные. Такие переменные доступны во всех процедурах и функциях модуля в котором они определены. В языке программирования 1С глобальные переменные могут быть определены в любых модулях (объектов, форм, и т.д) кроме общих модулей. Глобальные переменные задаются в самом верху модуля, перед определением всех процедур и функций. Перед именем переменной пишется ключевое слово «Перем». Значение указывать нельзя. Значение глобальной переменной можно задать в процедурах, функциях модуля или в конце модуля после всех процедур и функций.
Перем гСумма;
Функция РассчитатьСумму()
гСумма = 1;
КонецФункции;
//При данном варианте, значение переменной устанавливается при создании объекта
гСумма = 2;
Экспортные переменные
Глобальную переменную можно сделать экспортной, указав ключевое слово «Экспорт». Например, если экспортная переменная создаётся в модуле объекта справочника, то к ней можно обратиться через объект этого справочника, СправочникОбъект.ИмяПеременной.
Перем гСумма Экспорт;
Как обратиться к глобальной переменной 1с
Всем доброго времени суток.
Имеется 1С:Предприятие 8.3 (8.3.9.2170)
И собственная конфигурация с БСП.
Сейчас происходит переход на Управляемые Формы.
Если на обычных формах было все понятно объявляешь глобальную переменную в модуле обычного приложения и она доступна везде.
То на управляемых формах все на много сложнее. Эти глобальные переменные не доступны в модулях объектах и на сервере. Конечно можно каждый раз с клиента передавать на сервер эти переменные, но будет расти трафик между клиентом и сервером и к тому же если большая вложенность процедур становится слишком много параметров, что не есть хорошо.
Можно конечно использовать Параметры сеанса они доступны везде, но почему то 1с не рекомендует этого делать, так и не понял почему?
Так собственно вопрос чем лучше заменить глобальные переменные в управляемых формах?
Всем заранее спасибо за ответы.
Если боль в том, что «глобальные переменные не доступны в модулях объектах и на сервере», то кэшируй в элементе справочника (в реквизите «Значение», например) и используй серверный модуль с повторным возвращением значений.
Но зависит также от того, когда эти твои переменные инициализируются. Реквизит формы тоже должен прокатить, и даже параметр с флагом «Ключевой».
>> то кэшируй в элементе справочника (в реквизите «Значение», например) и используй серверный модуль с повторным возвращением значений.
Не очень понял это как в каждом справочнике создать реквизит «Значение» мне нужно во всей конфигурации к ним обращаться? и если создавать реквизит формы то в не интерактивном режиме работать не будет