Об обновлениях

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

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

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

Основа быстрого и безошибочного обновления закладывается на этапе разработки или при рефакторинге кода.

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

Перем ТаблицаСтоимостейБезДопРасходов;//гги
//гги ТабДокумент = ПечатьАктаОбОказанииУслуг();

//гги
Если Не Проведен Тогда
	Предупреждение("Запрещено печатать непроведенные документы");
	возврат;
КонецЕсли;
//гги

//гги
Процедура ДополнительныеДействияПриОткрытииФормы()
...
КонецПроцедуры

Здесь «//гг» - общая метка, «и» - мой буквенный идентификатор. Такие метки быстро наносить и легко искать в модулях конфигурации.

Рядом с меткой полезно указать, с какой целью сделано это изменение. Это может быть реализация некоего технического задания, исправление ошибки и так далее. Я использую метки «//тз001», «//метка002». Детальное описание, что означает техническое задание №001 или с чем было связано внесение изменений под меткой №002, я веду в отдельном файле (также можно использовать какой-нибудь модуль самой конфигурации). Если некая процедура использована в нескольких ТЗ, я отмечаю ее несколькими метками:

//гги//тз008//тз013
Функция НазначениеСпецификации_ЛКМ_Новые() Экспорт
    возврат лкпОбщегоНазначенияПолныеПрава.ПолучитьЭлементСправочника(
        "ЛКМ Новые", "НазначенияИспользованияСпецификаций", "Спецификации");
КонецФункции

Заглянув в описание, можно узнать, для чего были внесены изменения. Глобальным поиском по «//тз008» можно найти все изменения, вызванные ТЗ №008 - чтобы, например, удалить их, если данное задание уже не используется, и есть желание почистить конфигурацию от «мертвого» кода.

Отмечайте изменения в интерфейсах конфигураций на обычных формах. Я делаю это в модуле приложения:

//гги Интерфейс УправлениеПроизводством добавлено меню "Дополнительно"

При изменениях в визуальных элементах формы делайте комментарии в модуле формы:

//гги добавлены вкладки ДатаОтгрузки, ОтветственноеХранение
//на вкладке Дополнительно кнопка Логистам

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

Обычные формы:

Индекс = ЭлементыФормы.Товары.Колонки.Индекс(ЭлементыФормы.Товары.Колонки.Артикул);
Колонка = ЭлементыФормы.Товары.Колонки.Вставить(Индекс, "Транспортная упаковка");
Колонка.Имя = "ТранспортнаяУпаковка";
Колонка.УстановитьЭлементУправления(Тип("ПолеВвода"));
Колонка.Данные = "ТранспортнаяУпаковка";
Колонка.ТолькоПросмотр = Ложь;
Колонка.Ширина = 15;
Колонка.Видимость = Истина;

Колонка.ЭлементУправления.УстановитьДействие("ПриИзменении", Новый Действие("ТоварыТранспортнаяУпаковкаПриИзменении"));

Управляемые формы:

ЭлементРодитель = Элементы.Продукция;
ЭлементПередКоторымВставить = Элементы.ПродукцияНазначение;

НовыйЭлемент = Элементы.Вставить("НаименованиеПереработчика",
     Тип("ПолеФормы"),
     ЭлементРодитель,
          ЭлементПередКоторымВставить);

НовыйЭлемент.ПутьКДанным = "Объект.Продукция.НаименованиеПереработчика";
НовыйЭлемент.Вид = ВидПоляФормы.ПолеВвода;

Но без фанатизма – на обычных формах проще выделить мышкой и скопировать-вставить десяток элементов на добавленной странице, чем создавать их все программным способом, задавая расположение и привязки - пусть даже в перспективе это придется делать 10 или 100 раз. Однажды я перенес все многочисленные изменения форм УПП в код, а завод через полгода обанкротился.

На управляемых формах вносить изменения в форму через программный код полезно почти всегда – особенно в случае использования при обновлении внешней программы типа kDiff3 (см. ниже).

Описание изменений прав можно делать в модуле объекта или в модуле приложения, отмечая их дополнительным тегом "//правагг":

В модуле менеджера объекта:

//гги//правагг ЭкономистЦеха все; МенеджерПоЗаказам, МенеджерПоПродажам чтение

В модуле приложения:

//гги//правагг убрал доступ у роли Пользователь к
     //всё Спр.ЗначенияПоказателейАнализовНоменклатуры,
     //всё Спр.НормативныеДокументыСертификацииНоменклатуры,
     //всё РС.НормативныеДокументыСертификацииНоменклатуры
     //редактирование Спр.СерииНоменклатуры
     //всё Док.СертификацияНоменклатуры

Перенос изменений в стандартных ролях – наиболее трудоемкий и неавтоматизируемый процесс. Поэтому старайтесь не изменять стандартные роли – вместо этого создавайте свои. Если вы хотите добавить права к своему справочнику менеджерам по продажам, сделайте новую роль префикс_МенеджерПоПродажам, назначьте ей права к своему справочнику, и добавьте эту роль пользователям. Другой возможный подход - добавление своих атомарных ролей, например префикс_РедактированиеСправочника_ТипыПродукции

Новые объекты и реквизиты объектов отмечайте префиксом из 2-3 символов, после которых идет символ подчеркивания. Так будет проще отличить объекты, добавленные программистом от объектов, которые удалены из конфигурации поставщика, но по той или иной причине остались в конфигурации базы данных, и вообще добавит порядка в вашу конфигурацию.

мт_ОбщегоНазначения (общий модуль)

мт_ЗначимыеПоставщики (регистр сведений)

мт_ЦенаЗакупки (реквизит документа)

Добавленные объекты располагайте внизу ветки дерева конфигурации:

После обновления они будут «уползать» вверх (например, если до обновления в конфигурации поставщика было 100 справочников, а стало 102, то после обновления справочники будут располагаться в таком порядке: с 1 по 100 строку - справочники конфигурации поставщика, потом ваши справочники, потом остальные справочники конфигурации поставщика). Не ленитесь восстановить порядок – переместите ваши объекты вниз. Недопустимо, чтобы ваши объекты были раскиданы по всему дереву конфигурации, вперемешку с объектами поставщика. Кроме очевидного беспорядка, это может привести к затруднениям при переносе изменений при обновлении. Старайтесь располагать ваши объекты в алфавитном порядке.

Не добавляйте свои отчеты и обработки в дерево конфигурации. Их место - в дополнительных отчетах и обработках или в расширении.

 

Итак, если в конфигурации у вас теперь порядок, то перенос изменений при обновлении происходит так: открываются две базы данных – с обновленной и необновленной конфигурациями. Глобальным поиском по меткам //гг (со снятым флажком «Искать слово целиком») выводятся метки в старой и новой конфигурации. Просматривайте вхождения по порядку, находите недостающие строки в новой конфигурации, переносите эти куски кода из старой. Ранее, при отображении дерева измененных объектов, запишите, какие роли и интерфейсы у вас дважды изменены (просмотр дважды измененных объектов – стандартный этап при использовании внешней программы, о чем ниже). Перенесите изменения в дважды измененных ролях, используя поиск по «//правагг». Перенесите изменения в дважды измененных интерфейсах, используя пометки в общем модуле.

Крайне полезно использовать внешнюю программу для анализа изменений в модулях при обновлении. Я использую kDiff3. Здесь я не буду описывать работу с ней; описание можно найти на сайте 1С или на других сайтах. Использование внешней программы ускоряет обновление в десятки раз, обязательно освойте ее.

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

Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. BigB 182 12.02.20 23:11 Сейчас в теме
А не лучше ли доработки делать в виде расширений? Тогда и в конфигурации не надо включать возможность изменения и обновляться такая конфигурация будет без проблем.
costy_admin; ipoloskov; Alfn; +3 2 Ответить
2. ipoloskov 139 13.02.20 05:15 Сейчас в теме
(1) это тоже. Но у меня на поддержке еще находятся множество УПП, у других наверняка тоже.
Статью я написал по следам обновления "чужой" УПП, которую провожу в данный момент, и бардака, обнаруженного в этой конфигурации.

По поводу расширений. Я недавно вернул одну Бухгалтерию 3.0 на поддержку, перенеся все доработки в расширение. Но там я это сделал скорее для того, чтобы ускорить процесс обновления (конфигурация "на замке" обновляется в 2-3 раза быстрее, чем со снятым замком). Еще для одного клиента Бух30 я сделал новую подсистему полностью на расширении.

Какие я вижу минусы в полном перенесении правок в расширение:
Часто приходится вносить правки в модули конфигурации, причем делать правки где-нибудь в середине процедуры. Выносить процедуру в расширение чревато тем, что при обновлении она будет изменена - а видно этого не будет. На устоявшихся конфигурациях типа Бухгалтерии это, наверное, не страшно, но на развивающихся типа ERP при каждом обновлении добавится работа - искать в расширении процедуры с заголовком &Вместо, копировать новый код процедуры из основной конфигурации и заново расставлять в нем свои правки. Сравните с тремя щелчками мышью, необходимыми для обработки дважды измененного модуля с помощью kDiff3, и вы поймете, почему я не люблю директиву &Вместо в расширении.
Сейчас появилась возможность добавлять процедуры в расширение с контролем, но я этот механизм еще не пробовал.
3. MVK80 13.02.20 08:10 Сейчас в теме
(2), используйте в расширениях ИзменениеИКонтроль (это вместо &Вместо) и не надо править код основной конфигурации. Доступно с платформы 8.3.15....(последние цифры не помню). Но аккуратно, так как много багов пока в ИзменениеИКонтроль.
Xershi; BigB; +2 Ответить
6. Monte Carlo 13.02.20 10:53 Сейчас в теме
(3) ERP в режиме совместимости с версией 8.3.12 до сих пор. В ней не работает ИзменениеИКонтроль.
7. MVK80 13.02.20 11:42 Сейчас в теме
(6), работает. Это платформенная фишка не привязанная к режиму совместимости. Попробуйте! Мы как раз и работаем с ERP и с ИзменениемИКонтролем.
9. Monte Carlo 13.02.20 13:35 Сейчас в теме
(7) Странно, пробовали не работает. Да это и логично. Если конфигурация работает в режиме совместимости с более старой версией платформы, то в ней не поддерживаются новые фишки.
17. MVK80 16.02.20 19:35 Сейчас в теме
(9), то есть вам проще поверить что я вру, когда явно пишу, что мы уже работаем с ИзменениемИКонтролем в ERP, нежели в то, что у вас могло не получится по тысячам причин (и вы сразу опустили руки) и теперь вы пытаетесь оправдать это какой-то логикой? Создайте пустую конфигурацию с режимом совместимости 8.3.12 на платформе выше 8.3.15. Создайте процедуру в общем модуле например с Сообщить("Основная конфигурация)" расширьте её с помощью ИзменениеИКонтроль и там замените на Сообщить("Расширение") и с помощью кнопки в обработке вызовите её.
19. Monte Carlo 18.02.20 11:00 Сейчас в теме
(17) Да, прошу прощения. Не работают клиентские методы, а серверная процедура отработала.
21. MVK80 18.02.20 11:21 Сейчас в теме
(19), да там достаточно нюансов, но какие-то пока обходим, регистрируем ошибки. Но в целом всё норм, можно работать!
По поводу клиентских методов вот ошибка: https://bugboard.v8.1c.ru/error/000062705
20. Ndochp 103 18.02.20 11:20 Сейчас в теме
(9) Вы изменение и контроль не по статье с зазеркалья делаете? а то в релизе "КонецВставить" таки переименовали в "КонецВставки" и у меня ерпа работает.
22. Monte Carlo 18.02.20 12:47 Сейчас в теме
(20) Нет, использую #КонецВставки. В клиентском методе падает с ошибкой в модуле ****.cpp. Внутренняя платформенная ошибка, после которой приложение прекращает работу.
23. Ndochp 103 18.02.20 14:47 Сейчас в теме
(22) Забавно. У меня на 8.3.15.1656 полет нормальный. Совместимость 8.3.12, как в поставке.
Но выпадение в cpp это явно не признак штатной работы механизма совместимости.
25. ipoloskov 139 19.02.20 12:57 Сейчас в теме
(3) попробовал (ERP на 8.3.16.1063)
Сразу же после запуска выскочило сообщение, что исходный код модуля изменен (или что-то в этом духе)
26. igee12 19.02.20 16:53 Сейчас в теме
(25) Проверьте, чтобы не было лишних пустых строк за пределами #Вставка .. #КонецВставки, иначе "исходный" код метода 1С считает измененным.
ipoloskov; +1 Ответить
16. costy_admin 49 15.02.20 09:59 Сейчас в теме
(1) Поддерживаю по моему сейчас проще все переводить на расширение.
4. stepan_s 13.02.20 08:27 Сейчас в теме
понятно что при помощи расширений будет красиво. Понятно что так лучше делать на будущее с типовыми....
Но автор наверное поделился опытом как было единственно возможно до недавнего времени....
Учитывая что функционал новый - не стоит слепо и не оглядываясь сразу использовать новые возможности, особенно поделки 1С :).

Но более меня смутило такое большое количество текста, интерпретирующее рекомендации 1С по обновлениям измененных конф, но только вскольз отмечен механизм сравнения при помощи сторонних инструментов (kDiff3) при этом с ремаркой "не расскажу".
Зачем упоминать если не рассказывать? Или как в голливудских фильмах - затравка на интерес к новой части?
8. ipoloskov 139 13.02.20 13:02 Сейчас в теме
(4) хммм, наверное потому, что я узнал про kDiff3 на этом сайте. Сейчас, к сожалению, не могу найти ту статью. Но про kDiff3 написано много где еще - зачем дублировать?
Рекомендации 1С не видел. Но, судя по попадающим ко мне конфигурациям, ранее поддерживавшихся другими компаниями, их вообще мало кто видел. Комментариев изменений форм не делают. Комментариев измерений ролей не делают. Я делюсь личным опытом, который позволяет мне обновлять десяток УПП, где я уже провел рефакторинг в соответствии с вышеуказанными рекомендациями, практически в фоновом режиме - минимально отвлекаясь от разработки.
27. wau8824ru 21 29.02.20 08:39 Сейчас в теме
(8)
Комментариев изменений форм не делают

Изменения форм можно смотреть вот так, ролей тоже можно смотреть так же
Прикрепленные файлы:
ipoloskov; +1 Ответить
5. vano-ekt 848 13.02.20 08:54 Сейчас в теме
О обновлениях

о правописании предлогов 🤦‍♂️
ben19791010; SpartakM; YanTsys; Monte Carlo; +4 Ответить
10. YanTsys 12 13.02.20 14:10 Сейчас в теме
Не добавляйте свои отчеты и обработки в дерево конфигурации. Их место - в дополнительных отчетах и обработках или в расширении.

Почему?
11. ipoloskov 139 13.02.20 14:34 Сейчас в теме
(10)
1) Это то, что просят подправить чаще всего. Чтобы лишний раз не изменять конфигурацию.
2) Отчетов накапливается много. Их перемещение вниз дерева конфигурации становится трудоемким (третий абзац снизу).
3) Можно настроить доступ конкретным пользователям, не заводя отдельные роли (если располагать в доп. отчетах).

Для обычных форм, минусы расположения в дополнительных отчетах - их нет в меню интерфейса, что неудобно пользователю. Я обходил это так: добавлял в интерфейс пункт меню с вызовом процедуры общего модуля:
Процедура ПлановыйТабельРабочегоВремени() Экспорт //эту процедуру я вызываю из меню
	
	ОткрытьВнешнийОтчет("Плановый табель рабочего времени");
	
КонецПроцедуры

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

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

&НаСервере
Функция ОбработкаСсылка(Наименование)
	
	возврат Справочники.ДополнительныеОтчетыИОбработки.НайтиПоНаименованию(Наименование);
	
КонецФункции
Показать

а эту команду уже добавить в подсистему-интерфейс. После этого можно будет менять отчет, не меняя расширение, и отчет располагается удобно для пользователя - в панели интерфейса.
12. YanTsys 12 13.02.20 14:53 Сейчас в теме
(11)
Отчетов накапливается много. Их перемещение вниз дерева конфигурации становится трудоемким (третий абзац снизу).


Почему вниз? Мы свои объекты располагаем в начале списка, тогда их потом не приходится искать...

Чтобы лишний раз не изменять конфигурацию.


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

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

Аргумент. Но будут и обратные ситуации когда мы хотим просто назначить роль человеку и не вспоминать какой комплекс отчетов и обработок ему еще нужно настроить.

Я обходил это так: добавлял в интерфейс пункт меню с вызовом процедуры общего модуля:

Я для внешних обработок просто добавляю общую команду и потом даю к ней доступ в нужной подсистеме.
13. ipoloskov 139 13.02.20 15:07 Сейчас в теме
(12)
Мы свои объекты располагаем в начале списка, тогда их потом не приходится искать...

Сравнение с конфигурацией поставщика (такое иногда приходится делать) вывалит все объекты конфигурации с пометкой "изменен порядок". Если свои объекты внизу, такого не будет.
wau8824ru; +1 Ответить
14. kosmo0 100 14.02.20 02:32 Сейчас в теме
Личный опыт по обычным формам (УПП).
1. В измененных блоках желательно помечать начало и конец измененного блока. Так как если в модуле изменения в нескольких местах, то невозможно определить что менялось и что не менялось. Можно словами "НачалоБлока" и "КонецБлока", можно скобками "<<" и ">>".

Процедура ааа()
//мои изменения
  действие1
  действие2
  действие3
КонецПроцедуры

Процедура ааа()
//мои изменения
//НачалоБлока
  действие1
  действие2
//КонецБлока
  действие3
КонецПроцедуры
Показать


2. В комментариях обязательно ставил дату изменения. При багах проще находить исходный код и, при наличии, сразу представлять масштаб некорректных данных в БД из-за работы измененного кода.

3. В некоторых случаях полезно оставлять исходный код. Когда он относительно небольшой и расположен в "критическом" месте. Например в общем модуле - всегда есть вероятность один вызов из 10000 не будет отрабатывать как предусмотрено (то есть в этом вызове нужен только исходный код). При этом также обрамление //ИсходныйКод_НачалоБлока и //ИсходныйКод_КонецБлока. Лично я оставлял это примерно на год, потом удалял (становилось ясно что грабли отсутствуют). Просто с таким блоком намного проще отлаживать баги - что было сразу видно и не надо открывать старую конфигурацию.

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

5.
По возможности добавляйте свои элементы форм программно – тогда перенос изменений при обновлении сведется к копированию/вставке кусков кода. Но без фанатизма – на обычных формах проще выделить мышкой и скопировать-вставить десяток элементов на добавленной странице, чем создавать их все программным способом, задавая расположение и привязки - пусть даже в перспективе это придется делать 10 или 100 раз. Однажды я перенес все многочисленные изменения форм УПП в код, а завод через полгода обанкротился.


Лично я бы рекомендовал добавления делать программно. Если копипастить визуальные элементы ОБЫЧНОЙ формы, то при сравнении с типовой эти элементы будут показываться как различающиеся с типовыми. Причем по всем реквизитам полное совпадение, но будет показано как различающееся (по крайней мере в 8.3.8 так было).
И если типовая форма изменилась и на ней есть ваши изменения визуальных элементов, то при объединении получается такая чушь.

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

кстати, рекомендую программно создаваемые элементы формы привязывать к низу формы (панели). И если новые типовые элементы перекроют ваши, то можно будет их увидеть растянув форму вниз (а иначе переделка конфигурации - сколько времени это займет? и что скажет на это бухгалтерия в отчетный период?)
24. ipoloskov 139 19.02.20 12:56 Сейчас в теме
(14) отмечать, где в блоке начало, а где конец, имеет смысл в двух случаях:
1) блок слишком большой, и визуально на экране не видно, где он начинается и заканчивается. В этом случае необходимо выделить его в отдельную процедуру.
2) вставок много, и они идут чередой среди аутентичного кода.
Во всех остальных случаях пометки типа "начало" и "конец" только добавляют мусора на экран.
15. anton13m 14.02.20 14:12 Сейчас в теме
В некоторых случаях адаптация расширений под новую версию может существенно усложнить обновление, т.к. механизм сравнения расширений с конфигурацией поставщика или основной, вроде бы, до сих пор отсутствует, да и бывает, что внесение изменений в конфигурацию будет предпочтительней, чем выносить доработки в расширение.
ipoloskov; Ndochp; +2 Ответить
18. triviumfan 24 17.02.20 20:02 Сейчас в теме
Даже не читал. Раз название темы безграмотное, следовательно и статья тоже.
Оставьте свое сообщение

См. также

Звуковое управление в 1С 8.3 Промо

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

В данной статье описано создание библиотеки для звукового управления (выполнение команд голосом) для платформы 1С 8.3. Задача была поставлена так, чтобы модуль функционировал непосредственно на клиенте 1С, осуществляя управление формами, и взаимодействовал с интерфейсом.

16.03.2021    2623    velemir    28    

Полезные примеры СКД, ч.2

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

Еще несколько примеров решения задач в СКД.

06.04.2021    2564    Neti    7    

Обзор полезных методов БСП 3.1.4

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

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

25.03.2021    10531    rayastar    45    

Базовые вещи БСП, которые облегчат жизнь программисту 1С

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

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

30.08.2020    12417    quazare    34    

Serverless (Faas) в 1С. Создание и вызов Yandex Cloud Functions Промо

Универсальные функции Практика программирования v8 Бесплатно (free)

"Я не могу просто взять и скопировать код с гитхаба", "у нас 1С микросервисами окружена", "возможностей мало" - частые фразы 1С разработчиков. которым не хватает возможностей платформы в современном мире. Faas, конечно, история не новая, но нас сдерживало 152ФЗ и задержки по пингам. Для того, чтобы действительно использовать в 1С код, к примеру, на Python, надо было приложить усилия. Теперь всё намного проще - берём и используем.

28.12.2020    5089    comol    26    

Форма выбора (подбор) в управляемых формах

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

Разбор небольших примеров того, как правильно открывать форму выбора (подбора) в управляемых формах, не прибегая к модальным окнам.

08.05.2020    41425    user5300    17    

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

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

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

27.01.2020    42870    ids79    26    

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

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

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

15.01.2020    32391    John_d    22    

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

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

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

10.12.2016    38838    unichkin    74    

Последовательности событий при проведении документа 1С. Шпаргалка + про формы + про расширения

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

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

30.12.2019    24900    kuzyara    38    

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

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

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

02.12.2019    19555    YPermitin    60    

Как передать IP адрес, который вызвал HTTP запрос в 1C (для веб-сервера Apache)

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

Столкнулся с задачей получения IP адреса, который вызывает http сервис 1С. Итак, решение:

22.11.2019    10187    Sibars    19    

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

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

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

15.10.2018    32582    tormozit    105    

Полезные процедуры и функции для программиста

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

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

07.10.2019    34196    HostHost    41    

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

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

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

01.10.2019    42413    Yashazz    50    

О программе Postman для тестирования API и для чего она нужна 1С-нику

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

Для чего нужна программа Postman для тестирования API и какая от него польза для 1С-программиста.

24.09.2019    15385    budidich    28    

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

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

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

20.09.2012    79706    tormozit    131    

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

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

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

18.09.2019    18516    feva    42    

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

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

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

06.09.2019    72317    rpgshnik    70    

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

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

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

05.09.2019    60923    ids79    55    

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

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

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

11.07.2007    50603    tormozit    48    

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

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

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

05.09.2019    34718    YPermitin    25    

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

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

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

03.09.2019    27527    YPermitin    81    

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

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

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

17.08.2019    37759    ids79    16    

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

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

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

10.09.2017    47435    tormozit    74    

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

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

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

08.08.2019    113985    ids79    67    

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

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

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

02.08.2019    46590    avalakh    26    

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

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

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

31.07.2019    31191    json    15    

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

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

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

25.04.2019    16604    m-rv    2    

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

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

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

26.07.2019    80919    ids79    14    

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

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

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

17.07.2019    41175    ids79    27    

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

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

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

09.07.2019    29191    YPermitin    14    

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

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

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

16.04.2019    21202    m-rv    17    

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

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

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

04.07.2019    20624    SeiOkami    50    

Работа с настройками системы компоновки данных

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

Варианты отчетов, работа с настройками вариантов: структура группировок, поля отчета, отборы, сортировка, условное оформление, другие настройки, настройки отображения диаграмм.

02.07.2019    63248    ids79    17    

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

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

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

25.06.2019    62696    ids79    26    

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

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

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

01.06.2018    32920    m-rv    22    

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

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

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

11.06.2019    27712    dmurk    146    

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

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

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

16.05.2019    51693    YPermitin    30    

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

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

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

07.04.2019    38694    ellavs    127    

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

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

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

05.12.2017    28994    itriot11    34    

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

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

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

28.03.2019    28994    ellavs    90    

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

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

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

14.03.2019    35507    YPermitin    53    

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

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

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

07.03.2019    65281    ids79    46    

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

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

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

27.01.2016    79035    Serginio    113    

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

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

В статье собраны наиболее распространенные ошибки при работе с хранилищем конфигурации и способы их обхода и решения.

01.03.2019    51500    Смешной 1С    31    

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

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

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

26.02.2019    24871    Vladimir Litvinenko    28    

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

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

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

22.02.2019    42798    ids79    19    

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

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

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

10.11.2018    38522    ids79    40