Удаление записи из табличной части в режиме без использования модальности

01.03.20

Разработка - Механизмы платформы 1С

Всем привет! Появилась необходимость в написании кода удаления записи из табличной части с обратной связью в режиме без использования модальности. Но как правильно сделать нигде не нашел. Предлагаю свой вариант на растерзание.

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
Удаление записи из табличной части в режиме без использования модальности
.dt 34,02Kb
1 2 500 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

В интернете есть много примеров, где используется глобальная переменная и метод удаление вызывается два раза, первый раз для вопроса пользователю, а второй непосредственно для удаления. Этот вариант мне показался сильно замудренный.

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

 

 

 

 

 

 

Создадим документ с именем Документ1. В объекте Документ1 добавим табличную часть с именем ТабличнаяЧасть1. В этой табличной части для демонстрации добавляем реквизит Реквизит1 с типом Строка длинной 10 символов.

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

Создаем форму документа, для табличной части ТабличнаяЧасть1 создаем событие ПередУдалением(Элемент, Отказ).

В данное событие прописываем код, где в первую очередь отказываемся от стандартной процедуры удаления: Отказ = Истина;

Далее создаем оповещение на процедуру УдалениеСтроки с передачей одного параметра, который содержит текущий элемент коллекции ДанныеФормыКоллекция (Элементы.ТабличнаяЧасть1.ТекущиеДанные). Код оповещения получился таким:

Оповещение = Новый ОписаниеОповещения("УдалениеСтроки", 
		ЭтотОбъект,
 		Элементы.ТабличнаяЧасть1.ТекущиеДанные);

Далее показываем вопрос пользователю:

ПоказатьВопрос(Оповещение, 
		"Удалить?", 
		РежимДиалогаВопрос.ДаНет);

 

 

 

 

 

 

 

 

 

 

В результате получили процедуру кодом:

&НаКлиенте
Процедура ТабличнаяЧасть1ПередУдалением(Элемент, Отказ)
	
	Отказ = Истина;	                                          
	Оповещение = Новый ОписаниеОповещения("УдалениеСтроки", 
		ЭтотОбъект,
 		Элементы.ТабличнаяЧасть1.ТекущиеДанные);
 	ПоказатьВопрос(Оповещение, 
		"Удалить?", 
		РежимДиалогаВопрос.ДаНет);
 
КонецПроцедуры

На стороне клиента создаем экспортную процедуру УдалениеСтроки(Результат, ДополнительныеПараметры).

Сначала проверяем, что нажал пользователь Да или Нет. Если пользователь нажал кнопку Да, то строчкой кода Объект.ТабличнаяЧасть1.Удалить(ДополнительныеПараметры); удаляем из коллекции ДанныеФормыКоллекция текущий элемент переданный в параметр ДополнительныеПараметры.

После строки удаления прописываем код установки факта Модифицированности: Модифицированность = Истина; 

В результате получили процедуру с кодом:

&НаКлиенте
Процедура УдалениеСтроки(Результат, ДополнительныеПараметры) Экспорт 

	Если Результат = КодВозвратаДиалога.Да Тогда
 		Объект.ТабличнаяЧасть1.Удалить(ДополнительныеПараметры);
		Модифицированность = Истина;
 	КонецЕсли;	

КонецПроцедуры

Результат полного кода представлен на рисунке ниже.

Пример проверен на платформе 1С:Предприятие 8.3 (8.3.14.1565).

Вступайте в нашу телеграмм-группу Инфостарт

ОписаниеОповещения БезМодальности ПоказатьВопрос РежимДиалогаВопрос

См. также

Механизмы платформы 1С Программист Бесплатно (free)

Разберем 15 мифов о работе платформы «1С:Предприятие 8» – как распространенных, так и малоизвестных. Начнем с классики: «Код, написанный в одну строку, работает быстрее, чем многострочный». Так ли это на самом деле?

16.07.2025    30227    TitanLuchs    106    

149

Механизмы платформы 1С Работа с интерфейсом Программист Стажер 1С:Предприятие 8 Бесплатно (free)

Про ООП в 1С и о том, как сделать свой код более кратким и выразительным при помощи использования текучего интерфейса (fluent interface).

03.02.2025    16499    bayselonarrend    127    

68

Механизмы платформы 1С Программист 1С:Предприятие 8 Бесплатно (free)

В этой статье подробно рассматривается работа с JSON в XDTO в 1С:Предприятие. Вы узнаете, как сериализовать и десериализовать объекты XDTO в JSON, интегрировать 1С с веб-сервисами и API, а также корректно обрабатывать данные при обмене. Разбираются особенности работы с коллекциями, использование функций восстановления и частые ошибки при работе с JSON и XDTO.

30.01.2025    19716    user2122906    9    

66

Механизмы платформы 1С Файловый обмен (TXT, XML, DBF), FTP Программист 1С:Предприятие 8 Бесплатно (free)

Этот материал познакомит вас с механизмом XDTO (XML Data Transfer Objects) в 1С и научит эффективно использовать его возможности. Мы разберёмся, как работать с XML-схемами, создавать модели данных, манипулировать объектами XDTO, а также сериализовать и десериализовать их в XML. Вы узнаете, как использовать XDTO для интеграции с внешними системами, избегать типичных ошибок и оптимизировать код. К концу вы будете уверенно применять XDTO для решения сложных задач обмена данными и автоматизации процессов.

17.01.2025    34038    user2122906    12    

61

Механизмы платформы 1С WEB-интеграция Программист 1С:Предприятие 8 Бесплатно (free)

В платформе 8.3.27 появилась возможность использовать WebSocket-клиент. Давайте посмотрим, как это все устроено и чем оно нам полезно.

14.01.2025    30723    dsdred    100    

147

Механизмы платформы 1С Программист Стажер 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

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

23.06.2024    27246    bayselonarrend    22    

176

Механизмы платформы 1С Программист Стажер 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Пример использования «Сервисов интеграции» без подключения к Шине и без обменов.

13.03.2024    14804    dsdred    22    

85
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. AntonDr 21.05.21 18:49 Сейчас в теме
Наверное, имеет смысл упомянуть и о необходимости вызова обработчика события ПослеУдаления. На случай если таковой имеется
2. user1848064 21.09.22 11:07 Сейчас в теме
Для отправки сообщения требуется регистрация/авторизация