Правила создания общих модулей
🟡 Общие модули создавайте для процедур и функций, объединенных по одному признаку.
🟡 При разработке общих модулей выбирайте один из четырех контекстов выполнения.
🟡 Серверные общие модули используйте для внутренней серверной бизнес-логики.
🟡 Именуйте по общим правилам именования.
#std469
https://v8std.ru/std/469/
#std469
https://v8std.ru/std/469/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Правила создания общих модулей #std469
Общие модули создавайте для процедур и функций, объединенных по одному признаку. Обычно в один модуль попадает код:
1🔥13👌10❤2🤔1
Имена объектов метаданных в конфигурациях
🟡 Именуйте объекты метаданных по общим правилам именования, без лишних технических слов в названиях.
🟡 Для ролей разделяйте схему именования: прикладные роли называйте по должности, технические — по разрешаемому действию.
🟡 Подписки на события называйте от сути действия и образуйте имя от неопределенной формы глагола.
🟡 Функциональные опции и их параметры именуйте по включаемой функциональности и смыслу параметра, а не по внутренней реализации.
#std550
https://v8std.ru/std/550/
#std550
https://v8std.ru/std/550/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Имена объектов метаданных в конфигурациях #std550
Стандарт дополняет общие правила именования: #std474: Имя, синоним, комментарий.
1👍8🔥3👌3❤1🤯1
Использование функциональных опций
🟡 Управляйте необязательной функциональностью через функциональные опции, а их значения храните в данных информационной базы.
🟡 Для контекстной доступности функциональности используйте параметризованные функциональные опции и устанавливайте параметры опций формы.
🟡 После изменения значений функциональных опций вызывайте
🟡 Не перегружайте систему параметрами опций: исключайте дубли и не параметризуйте по данным с очень большим числом значений.
#std470
https://v8std.ru/std/470/
ОбновитьИнтерфейс, чтобы командам и элементам формы применились новые ограничения.#std470
https://v8std.ru/std/470/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Использование функциональных опций #std470
Если часть функциональности конфигурации может быть необязательной, управляйте ее доступностью через функциональные опции.
1👍10👌4🔥3❤1❤🔥1🥰1🙏1
Использование параметров сеанса
🟡 Используйте параметры сеанса для значений, которые нужны в рамках текущего сеанса, запросов и ограничений доступа к данным.
🟡 Не храните в параметрах сеанса значения, нужные только клиентской логике: для этого применяйте глобальные переменные приложения.
🟡 Не используйте параметры сеанса как кеш вычислений серверной бизнес-логики; выносите такие вычисления в серверные функции с повторным использованием.
🟡 Инициализируйте параметры сеанса по требованию в обработчике
#std413
https://v8std.ru/std/413/
УстановкаПараметровСеанса, а не массово при старте программы.#std413
https://v8std.ru/std/413/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Использование параметров сеанса #std413
Параметры сеанса используйте для хранения значений определенных типов в рамках клиентского сеанса.
1👍12👌4❤2🔥2
Использование подсистем
🟡 Используйте подсистемы для двух задач: построения разделов командного интерфейса и функциональной группировки объектов метаданных.
🟡 Если интерфейсная и функциональная структуры не совпадают, создавайте отдельную иерархию функциональных подсистем без включения в командный интерфейс.
🟡 Объекты без визуального представления в интерфейсе включайте только в функциональные подсистемы.
🟡 Команды администрирования выносите в раздел «Настройка и администрирование», сохраняя логическую группировку объектов по функциональному назначению.
#std543
https://v8std.ru/std/543/
#std543
https://v8std.ru/std/543/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Использование подсистем #std543
Подсистемы решают две задачи:
1👍9👌5🔥3
Ограничения на использование Выполнить и Вычислить на сервере
🟡 Не выполняйте на сервере строки кода, собранные из внешних параметров, без строгого контроля источника и содержимого.
🟡 Перед вызовом
🟡 По возможности используйте безопасные обертки БСП вместо прямого вызова
🟡 Код, который нельзя запускать в безопасном режиме, выполняйте только после аудита и только из контролируемого администратором хранилища.
#std770
https://v8std.ru/std/770/
Выполнить и Вычислить на сервере включайте безопасный режим, а в сервисной модели дополнительно включайте безопасный режим разделения данных.Выполнить и Вычислить.#std770
https://v8std.ru/std/770/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Ограничения на использование Выполнить и Вычислить на сервере #std770
Опасность представляет не только прямое выполнение кода пользователя, но и выполнение строк, собранных из параметров и переданных в серверные процедуры/функции.
1👍12🔥5👌3
Транзакции: правила использования
🟡 Начинайте и завершайте транзакцию в одном методе: пары
🟡 Размещайте
🟡 В блоке
🟡 Избегайте лишних, вложенных и длинных транзакций: открывайте их только для действительно неделимых операций.
#std783
https://v8std.ru/std/783/
НачатьТранзакцию и ЗафиксироватьТранзакцию`/`ОтменитьТранзакцию не разносите по разным функциям.ЗафиксироватьТранзакцию последней операцией в блоке Попытка, чтобы после фиксации не возникали новые исключения.Исключение сначала вызывайте ОтменитьТранзакцию, затем выполняйте логирование и завершайте обработку оператором ВызватьИсключение.#std783
https://v8std.ru/std/783/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Транзакции: правила использования #std783
Транзакция - это действие, которое может быть выполнено только целиком. Если часть действия не выполнена - все действие отменяется.
1👍16🔥9👌4❤3💯3🤨1
4🔥55❤🔥16👍12🏆4
Работа с пользовательскими настройками
🟡 Для каждой настройки в хранилище общих настроек используйте уникальный строковый ключ.
🟡 В конфигурации должно быть общее место для редактирования всех пользовательских настроек.
🟡 Если позже будет создан пользователь с прежним именем, он получит ранее сохраненные настройки.
🟡 При необходимости перенос настроек между узлами реализуйте отдельно средствами встроенного языка.
#std557
https://v8std.ru/std/557/
#std557
https://v8std.ru/std/557/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Работа с пользовательскими настройками #std557
Для хранения персональных настроек пользователя используйте ХранилищеОбщихНастроек.
1🔥14👌1
Версия платформы 1С:Предприятие для разработки
🟡 Для решений государственных учреждений при этом новый релиз платформы должен быть сертифицирован в короткие сроки.
🟡 В качестве рекомендуемой версии указывается последний опубликованный релиз 8.3.15, если в нем улучшены функции, важные для пользователей.
🟡 В этом случае пользователи могут продолжать работу на текущем сертифицированном релизе и одновременно получают рекомендацию по обновлению.
🟡 В прикладных решениях для государственных учреждений, оборонных предприятий и корпоративных клиентов рекомендуемая версия может быть выше версии, на которой основан последний сертифицированный релиз.
#std785
https://v8std.ru/std/785/
#std785
https://v8std.ru/std/785/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Версия платформы 1С:Предприятие для разработки #std785
Минимальная версия платформы, на которой обеспечивается работа прикладного решения, устанавливается:
1🤔16❤6
Начальные действия при работе конфигурации
🟡 Для подробного протокола выполненных операций и ошибок используйте журнал регистрации.
🟡 Если в конфигурации используется Библиотека стандартных подсистем, применяйте подсистему Обновление версии ИБ.
🟡 Ситуации, когда обработка выполнена не полностью, должны контролироваться конфигурацией.
🟡 Проверяйте соблюдение стандарта при доработках и перед выпуском релиза.
#std556
https://v8std.ru/std/556/
#std556
https://v8std.ru/std/556/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Начальные действия при работе конфигурации #std556
В конфигурации должен быть механизм, который автоматически:
2🔥9⚡1👌1
Поддержка толстого клиента, управляемое приложение, клиент-сервер
🟡 Не устанавливайте признак Вызов сервера всем модулям с признаком Сервер.
🟡 Для расстановки фрагментов кода с инструкциями препроцессора можно использовать обработку с ИТС.
🟡 Обработчики ОбработкаПолученияДанныхВыбора и ОбработкаПолученияФормы вызываются только на сервере, и это ограничение на них не распространяется.
🟡 В этих модулях часто есть обращения к общим модулям, доступным только на сервере.
#std680
https://v8std.ru/std/680/
#std680
https://v8std.ru/std/680/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Поддержка толстого клиента, управляемое приложение, клиент-сервер #std680
В управляемом режиме иногда требуется поддержка запуска толстого клиента (режим управляемого приложения). Причина — часть возможностей, которые есть в обычном приложении, но...
1🔥11👌1
Технология разветвленной разработки конфигураций
🟡 При сборке исправительной версии рекомендуется устанавливать метку с номером сборки на закладке той версии хранилища, которая идет в сборку.
🟡 При сборке плановой версии рекомендуется устанавливать метку с номером сборки на закладке той версии хранилища, конфигурация которой идет в сборку.
🟡 В исправительной версии не должно быть объемных доработок конфигурации.
🟡 Все изменения по техническому проекту переносите в основное хранилище за одну закладку.
#std709
https://v8std.ru/std/709/
#std709
https://v8std.ru/std/709/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Технология разветвленной разработки конфигураций #std709
Цели внедрения технологии:
1🔥8👍2👌1
Особенности разработки конфигураций для ОС Linux и macOS
🟡 Используйте кроссплатформенные средства платформы для работы с файловой системой.
🟡 Для ключевых функций прикладного решения используйте кроссплатформенные механизмы платформы.
🟡 Если применяется БСП, используйте функции модулей ОбщегоНазначения и ОбщегоНазначенияКлиент.
🟡 В большинстве случаев платформа сама обеспечивает кроссплатформенную работу клиентского и серверного кода.
#std723
https://v8std.ru/std/723/
#std723
https://v8std.ru/std/723/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Особенности разработки конфигураций для ОС Linux и macOS #std723
В большинстве случаев платформа сама обеспечивает кроссплатформенную работу клиентского и серверного кода.
1👍11👌1
Использование значений, влияющих на поведение клиентского приложения
🟡 Если от значения зависит поведение команд или большого числа форм, используйте подход с общим модулем и кешированием на сеанс.
🟡 Если данные влияют только на одну форму или небольшой набор форм, храните их в реквизитах формы и получайте в ПриСозданииНаСервере.
🟡 Такой подход применяйте, когда изменение этих значений в течение сеанса некритично, и в рамках сеанса можно использовать один раз полученное значение.
🟡 Ограничивайте применение клиентских модулей с повторным использованием возвращаемых значений.
#std459
https://v8std.ru/std/459/
#std459
https://v8std.ru/std/459/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Использование значений, влияющих на поведение клиентского приложения #std459
Если поведение многих форм или команд зависит от одних и тех же значений, для минимизации клиент-серверного взаимодействия используйте #std724: общие модули с повторным...
1🔥8❤1
Несоответствие индексов и условий запроса
🟡 Проверяйте, что для всех условий запроса есть подходящие индексы.
🟡 Если между используемыми полями есть пропуски, индекс применяется только частично.
🟡 Реквизиты справочников и документов рекомендуется индексировать с дополнительным упорядочиванием.
#std652
https://v8std.ru/std/652/
#std652
https://v8std.ru/std/652/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Несоответствие индексов и условий запроса #std652
Проверяйте, что для всех условий запроса есть подходящие индексы.
1🤔5❤2👍2🔥2👌1
Режим разделения итогов для регистров накопления
🟡 При проектировании регистра накопления учитывайте, что остатки по одному набору измерений хранятся в одном ресурсе.
🟡 Если включить разделение итогов, обе записи смогут выполняться параллельно даже при совпадении строк по измерениям.
🟡 Но при включенном контроле остатков разделение итогов не даст ожидаемого прироста, и контроль остатков нужно переносить к концу транзакции.
#std664
https://v8std.ru/std/664/
#std664
https://v8std.ru/std/664/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Режим разделения итогов для регистров накопления #std664
При проектировании регистра накопления учитывайте, что остатки по одному набору измерений хранятся в одном ресурсе.
1👌3
Разработка ролей в библиотеках
🟡 В большинстве случаев библиотека должна поставлять готовый набор ролей для работы со своими данными (справочники, регистры и т.п.).
🟡 В ролях допустимо задавать не только права к объектам, но и ограничения доступа на уровне записей (RLS).
🟡 Если для библиотечных ролей используются правила поставки, для всех ролей задавайте правило Изменения разрешены.
#std668
https://v8std.ru/std/668/
#std668
https://v8std.ru/std/668/
Please open Telegram to view this post
VIEW IN TELEGRAM
Стандарты разработки 1С
Разработка ролей в библиотеках #std668
При проектировании ролей в библиотеках придерживайтесь общего подхода к границам функциональности библиотеки:
1👍13👌2