СеткаДанных.ТекущаяЯчейка (DataGrid.CurrentCell) Свойство

Использование

Чтение и запись.

Значение

Тип: ЯчейкаСеткиДанных (DataGridCell).

Возвращает или задает, ячейку имеющую фокус.

Примечание

Свойство недоступно во время разработки.

Пример

ТекущаяЯчейка1 = СеткаДанных1.ТекущаяЯчейка;
Полный пример кода

Копировать     Выделить всё

Перем Ф, СеткаДанных1; Функция РазобратьСтроку(Строка, Разделитель) Стр = СтрЗаменить(Строка,Разделитель,символы.ПС); М = Новый Массив; Если ПустаяСтрока(Стр) Тогда Возврат М; КонецЕсли; Для Ч = 1 По СтрЧислоСтрок(Стр) Цикл М.Добавить(СтрПолучитьСтроку(Стр,Ч)); КонецЦикла; Возврат М; КонецФункции Процедура Кнопка1_Нажатие() Экспорт ТекущаяЯчейка1 = СеткаДанных1.ТекущаяЯчейка; Стр = "Текущая ячейка: строка " + ТекущаяЯчейка1.НомерСтроки + ", колонка " + ТекущаяЯчейка1.НомерКолонки + "." + Символы.ПС; Попытка Прямоугольник1 = СеткаДанных1.ГраницыТекущейЯчейки(); Стр = Стр + "ГраницыТекущейЯчейки: |Икс: " + Прямоугольник1.Икс + " |Игрек: " + Прямоугольник1.Игрек + " |Ширина: " + Прямоугольник1.Ширина + " |Высота: " + Прямоугольник1.Высота; Исключение КонецПопытки; Ф.ОкноСообщений().Показать(Стр, "Текущая ячейка"); СеткаДанных1.Фокус(); КонецПроцедуры ПодключитьВнешнююКомпоненту("C:\444\111\OneScriptForms\OneScriptForms\bin\Debug\OneScriptForms.dll"); Ф = Новый ФормыДляОдноСкрипта(); Форма1 = Ф.Форма(); Форма1.Ширина = 700; Форма1.Высота = 400; Форма1.Отображать = Истина; Форма1.Показать(); Форма1.Активизировать(); СеткаДанных1 = Ф.СеткаДанных(); СеткаДанных1.Родитель = Форма1; СеткаДанных1.ТекстЗаголовка = "Сетка данных"; СеткаДанных1.Ширина = Форма1.Ширина - 100; СеткаДанных1.Высота = Форма1.КлиентВысота - 10; ТаблицаДанных1 = Ф.ТаблицаДанных("ТД1"); КолонкиТаб = ТаблицаДанных1.Колонки; Колонка0 = КолонкиТаб.Добавить(Ф.КолонкаДанных("№ н/п", Ф.ТипДанных.Число)); Колонка1 = КолонкиТаб.Добавить(Ф.КолонкаДанных("ФИО", Ф.ТипДанных.Строка)); Колонка2 = КолонкиТаб.Добавить(Ф.КолонкаДанных("ДатаРождения", Ф.ТипДанных.Дата)); Колонка3 = КолонкиТаб.Добавить(Ф.КолонкаДанных("Высшее образование", Ф.ТипДанных.Булево)); Колонка4 = КолонкиТаб.Добавить(Ф.КолонкаДанных("PostCount", Ф.ТипДанных.Число)); Колонка5 = КолонкиТаб.Добавить(Ф.КолонкаДанных("Инкремент", Ф.ТипДанных.Число)); Колонка5.АвтоПриращение = Истина; Колонка5.НачальноеЧисло = 25; Колонка5.ШагПриращения = 5; Стр13 = "Трифонов Юрий Никифорович,19990607,Истина,61.80 |Шигаев Агап Денисович,19991001,Ложь,48.99 |Сочеванова Анфиса Георгиевна,19970909,Истина,31.08 |Врунгель Христофор Бонифатьевич,19901010,Истина,53.22 |Шикалов Игнатий Маркович,19901010,Истина,53.22 |Сергеевич Аристарх Изяславович,19950621,Ложь,25.97 |Бондарчук Александр Ермолаевич,19930713,Истина,89.53 |Ефремова Ева Степановна,19990105,Ложь,12.11 |Моисеева Зинаида Никитевна,19930616,Истина,33.66 |Кузьмова Лиана Игнатиевна,19930621,Ложь,40.70 |Ковшутина Алина Игоревна,19911122,Истина,77.50 |Чемериса Дина Глебовна,19901206,Истина,35.00 |Сухоруков Давид Александрович,19930811,Истина,71.31 |Шагидзянова Наталия Николаевна,19950330,Истина,17.46 |Игошина Влада Емельяновна,19970731,Ложь,57.09 |Бортник Борис Федосиевич,19911101,Истина,41.48 |Заболотный Евсей Фролович,19931013,Истина,74.24 |Сонин Викентий Мечиславович,19970310,Истина,91.52 |Коваленко Злата Фомевна,19921215,Истина,11.38 |Шатохина Людмила Александровна,19920604,Ложь,83.06 |Пряхин Владислав Владимирович,19910304,Истина,28.36"; Для А = 1 По СтрЧислоСтрок(Стр13) Цикл ТаблицаДанных1.Строки.Добавить(ТаблицаДанных1.НоваяСтрока()); КонецЦикла; М_Счетчик = Ф.МассивСписок(); М_ФИО = Ф.МассивСписок(); М_ДатаРождения = Ф.МассивСписок(); М_ВысшееОбразование = Ф.МассивСписок(); М_КоличествоБонусов = Ф.МассивСписок(); Для А = 1 По СтрЧислоСтрок(Стр13) Цикл Стр14 = СтрПолучитьСтроку(Стр13, А); М9 = РазобратьСтроку(Стр14, ","); М_Счетчик.Добавить(А); М_ФИО.Добавить(М9[0]); М_ДатаРождения.Добавить(Дата("" + М9[1])); М_ВысшееОбразование.Добавить(?(М9[2] = "Истина", Истина, Ложь)); М_КоличествоБонусов.Добавить(Число(М9[3])); КонецЦикла; ТаблицаДанных1.ЗагрузитьКолонку(М_Счетчик, 0); ТаблицаДанных1.ЗагрузитьКолонку(М_ФИО, 1); ТаблицаДанных1.ЗагрузитьКолонку(М_ДатаРождения, "ДатаРождения"); ТаблицаДанных1.ЗагрузитьКолонку(М_ВысшееОбразование, Колонка3); ТаблицаДанных1.ЗагрузитьКолонку(М_КоличествоБонусов, Колонка4); СтильТаблицыСеткиДанных1 = Ф.СтильТаблицыСеткиДанных(); СтильТаблицыСеткиДанных1.ИмяОтображаемого = "ТД1"; СтилиТаблицы1 = СеткаДанных1.СтилиТаблицы; ИндексСтильТаблицыСеткиДанных1 = СтилиТаблицы1.Добавить(СтильТаблицыСеткиДанных1); СтильКолонки1 = Ф.СтильКолонкиПолеВвода(); СтильКолонки1.ИмяОтображаемого = "№ н/п"; СтильКолонки1.ТекстЗаголовка = "№ н/п"; СтильКолонки1.Ширина = 50; СтильКолонки1.Выравнивание = Ф.ГоризонтальноеВыравнивание.Центр; СтильТаблицыСеткиДанных1.СтилиКолонкиСеткиДанных.Добавить(СтильКолонки1); СтильКолонки2 = Ф.СтильКолонкиПолеВвода(); СтильКолонки2.ИмяОтображаемого = "ФИО"; СтильКолонки2.ТекстЗаголовка = "ФИО"; СтильКолонки2.Ширина = 250; СтильТаблицыСеткиДанных1.СтилиКолонкиСеткиДанных.Добавить(СтильКолонки2); СтильКолонки3 = Ф.СтильКолонкиПолеВвода(); СтильКолонки3.ИмяОтображаемого = "ДатаРождения"; СтильКолонки3.ТекстЗаголовка = "Дата рождения"; СтильКолонки3.Ширина = 120; СтильКолонки3.Выравнивание = Ф.ГоризонтальноеВыравнивание.Центр; СтильТаблицыСеткиДанных1.СтилиКолонкиСеткиДанных.Добавить(СтильКолонки3); СтильКолонки4 = Ф.СтильКолонкиБулево(); СтильКолонки4.ИмяОтображаемого = "Высшее образование"; СтильКолонки4.ТекстЗаголовка = "Высшее образование"; СтильКолонки4.Ширина = 160; СтильТаблицыСеткиДанных1.СтилиКолонкиСеткиДанных.Добавить(СтильКолонки4); СтильКолонки5 = Ф.СтильКолонкиПолеВвода(); СтильКолонки5.ИмяОтображаемого = "PostCount"; СтильКолонки5.ТекстЗаголовка = "Счетчик"; СтильКолонки5.Ширина = 80; СтильКолонки5.Выравнивание = Ф.ГоризонтальноеВыравнивание.Центр; СтильТаблицыСеткиДанных1.СтилиКолонкиСеткиДанных.Добавить(СтильКолонки5); СтильКолонки6 = Ф.СтильКолонкиПолеВвода(); СтильКолонки6.ИмяОтображаемого = "Инкремент"; СтильКолонки6.ТекстЗаголовка = "Инкремент"; СтильКолонки6.Ширина = 90; СтильКолонки6.Выравнивание = Ф.ГоризонтальноеВыравнивание.Центр; СтильТаблицыСеткиДанных1.СтилиКолонкиСеткиДанных.Добавить(СтильКолонки6); СеткаДанных1.ИсточникДанных = ТаблицаДанных1; Кнопка1 = Форма1.ЭлементыУправления.Добавить(Ф.Кнопка()); Кнопка1.Правее(СеткаДанных1, 10); Кнопка1.Верх = 10; Кнопка1.Нажатие = Ф.Действие(ЭтотОбъект, "Кнопка1_Нажатие"); Кнопка1.Текст = "Текущая ячейка"; Кнопка1.Высота = Кнопка1.Высота * 2; Ф.ЗапуститьОбработкуСобытий();

Тестовый код

Копировать     Выделить всё

Перем Ф, СеткаДанных1; Функция РазобратьСтроку(Строка, Разделитель) Стр = СтрЗаменить(Строка,Разделитель,символы.ПС); М = Новый Массив; Если ПустаяСтрока(Стр) Тогда Возврат М; КонецЕсли; Для Ч = 1 По СтрЧислоСтрок(Стр) Цикл М.Добавить(СтрПолучитьСтроку(Стр,Ч)); КонецЦикла; Возврат М; КонецФункции Процедура Кнопка1_Нажатие() Экспорт ТекущаяЯчейка1 = СеткаДанных1.ТекущаяЯчейка; Стр = "Текущая ячейка: строка " + ТекущаяЯчейка1.НомерСтроки + ", колонка " + ТекущаяЯчейка1.НомерКолонки + "." + Символы.ПС; Попытка Прямоугольник1 = СеткаДанных1.ГраницыТекущейЯчейки(); Стр = Стр + "ГраницыТекущейЯчейки: |Икс: " + Прямоугольник1.Икс + " |Игрек: " + Прямоугольник1.Игрек + " |Ширина: " + Прямоугольник1.Ширина + " |Высота: " + Прямоугольник1.Высота; Исключение КонецПопытки; Ф.ОкноСообщений().Показать(Стр, "Текущая ячейка"); СеткаДанных1.Фокус(); КонецПроцедуры ПодключитьВнешнююКомпоненту("C:\444\111\OneScriptForms\OneScriptForms\bin\Debug\OneScriptForms.dll"); Ф = Новый ФормыДляОдноСкрипта(); Форма1 = Ф.Форма(); Форма1.Ширина = 700; Форма1.Высота = 400; Форма1.Отображать = Истина; Форма1.Показать(); Форма1.Активизировать(); СеткаДанных1 = Ф.СеткаДанных(); СеткаДанных1.Родитель = Форма1; СеткаДанных1.ТекстЗаголовка = "Сетка данных"; СеткаДанных1.Ширина = Форма1.Ширина - 100; СеткаДанных1.Высота = Форма1.КлиентВысота - 10; ТаблицаДанных1 = Ф.ТаблицаДанных("ТД1"); КолонкиТаб = ТаблицаДанных1.Колонки; Колонка0 = КолонкиТаб.Добавить(Ф.КолонкаДанных("№ н/п", Ф.ТипДанных.Число)); Колонка1 = КолонкиТаб.Добавить(Ф.КолонкаДанных("ФИО", Ф.ТипДанных.Строка)); Колонка2 = КолонкиТаб.Добавить(Ф.КолонкаДанных("ДатаРождения", Ф.ТипДанных.Дата)); Колонка3 = КолонкиТаб.Добавить(Ф.КолонкаДанных("Высшее образование", Ф.ТипДанных.Булево)); Колонка4 = КолонкиТаб.Добавить(Ф.КолонкаДанных("PostCount", Ф.ТипДанных.Число)); Колонка5 = КолонкиТаб.Добавить(Ф.КолонкаДанных("Инкремент", Ф.ТипДанных.Число)); Колонка5.АвтоПриращение = Истина; Колонка5.НачальноеЧисло = 25; Колонка5.ШагПриращения = 5; Стр13 = "Трифонов Юрий Никифорович,19990607,Истина,61.80 |Шигаев Агап Денисович,19991001,Ложь,48.99 |Сочеванова Анфиса Георгиевна,19970909,Истина,31.08 |Врунгель Христофор Бонифатьевич,19901010,Истина,53.22 |Шикалов Игнатий Маркович,19901010,Истина,53.22 |Сергеевич Аристарх Изяславович,19950621,Ложь,25.97 |Бондарчук Александр Ермолаевич,19930713,Истина,89.53 |Ефремова Ева Степановна,19990105,Ложь,12.11 |Моисеева Зинаида Никитевна,19930616,Истина,33.66 |Кузьмова Лиана Игнатиевна,19930621,Ложь,40.70 |Ковшутина Алина Игоревна,19911122,Истина,77.50 |Чемериса Дина Глебовна,19901206,Истина,35.00 |Сухоруков Давид Александрович,19930811,Истина,71.31 |Шагидзянова Наталия Николаевна,19950330,Истина,17.46 |Игошина Влада Емельяновна,19970731,Ложь,57.09 |Бортник Борис Федосиевич,19911101,Истина,41.48 |Заболотный Евсей Фролович,19931013,Истина,74.24 |Сонин Викентий Мечиславович,19970310,Истина,91.52 |Коваленко Злата Фомевна,19921215,Истина,11.38 |Шатохина Людмила Александровна,19920604,Ложь,83.06 |Пряхин Владислав Владимирович,19910304,Истина,28.36"; Для А = 1 По СтрЧислоСтрок(Стр13) Цикл ТаблицаДанных1.Строки.Добавить(ТаблицаДанных1.НоваяСтрока()); КонецЦикла; М_Счетчик = Ф.МассивСписок(); М_ФИО = Ф.МассивСписок(); М_ДатаРождения = Ф.МассивСписок(); М_ВысшееОбразование = Ф.МассивСписок(); М_КоличествоБонусов = Ф.МассивСписок(); Для А = 1 По СтрЧислоСтрок(Стр13) Цикл Стр14 = СтрПолучитьСтроку(Стр13, А); М9 = РазобратьСтроку(Стр14, ","); М_Счетчик.Добавить(А); М_ФИО.Добавить(М9[0]); М_ДатаРождения.Добавить(Дата("" + М9[1])); М_ВысшееОбразование.Добавить(?(М9[2] = "Истина", Истина, Ложь)); М_КоличествоБонусов.Добавить(Число(М9[3])); КонецЦикла; ТаблицаДанных1.ЗагрузитьКолонку(М_Счетчик, 0); ТаблицаДанных1.ЗагрузитьКолонку(М_ФИО, 1); ТаблицаДанных1.ЗагрузитьКолонку(М_ДатаРождения, "ДатаРождения"); ТаблицаДанных1.ЗагрузитьКолонку(М_ВысшееОбразование, Колонка3); ТаблицаДанных1.ЗагрузитьКолонку(М_КоличествоБонусов, Колонка4); СтильТаблицыСеткиДанных1 = Ф.СтильТаблицыСеткиДанных(); СтильТаблицыСеткиДанных1.ИмяОтображаемого = "ТД1"; СтилиТаблицы1 = СеткаДанных1.СтилиТаблицы; ИндексСтильТаблицыСеткиДанных1 = СтилиТаблицы1.Добавить(СтильТаблицыСеткиДанных1); СтильКолонки1 = Ф.СтильКолонкиПолеВвода(); СтильКолонки1.ИмяОтображаемого = "№ н/п"; СтильКолонки1.ТекстЗаголовка = "№ н/п"; СтильКолонки1.Ширина = 50; СтильКолонки1.Выравнивание = Ф.ГоризонтальноеВыравнивание.Центр; СтильТаблицыСеткиДанных1.СтилиКолонкиСеткиДанных.Добавить(СтильКолонки1); СтильКолонки2 = Ф.СтильКолонкиПолеВвода(); СтильКолонки2.ИмяОтображаемого = "ФИО"; СтильКолонки2.ТекстЗаголовка = "ФИО"; СтильКолонки2.Ширина = 250; СтильТаблицыСеткиДанных1.СтилиКолонкиСеткиДанных.Добавить(СтильКолонки2); СтильКолонки3 = Ф.СтильКолонкиПолеВвода(); СтильКолонки3.ИмяОтображаемого = "ДатаРождения"; СтильКолонки3.ТекстЗаголовка = "Дата рождения"; СтильКолонки3.Ширина = 120; СтильКолонки3.Выравнивание = Ф.ГоризонтальноеВыравнивание.Центр; СтильТаблицыСеткиДанных1.СтилиКолонкиСеткиДанных.Добавить(СтильКолонки3); СтильКолонки4 = Ф.СтильКолонкиБулево(); СтильКолонки4.ИмяОтображаемого = "Высшее образование"; СтильКолонки4.ТекстЗаголовка = "Высшее образование"; СтильКолонки4.Ширина = 160; СтильТаблицыСеткиДанных1.СтилиКолонкиСеткиДанных.Добавить(СтильКолонки4); СтильКолонки5 = Ф.СтильКолонкиПолеВвода(); СтильКолонки5.ИмяОтображаемого = "PostCount"; СтильКолонки5.ТекстЗаголовка = "Счетчик"; СтильКолонки5.Ширина = 80; СтильКолонки5.Выравнивание = Ф.ГоризонтальноеВыравнивание.Центр; СтильТаблицыСеткиДанных1.СтилиКолонкиСеткиДанных.Добавить(СтильКолонки5); СтильКолонки6 = Ф.СтильКолонкиПолеВвода(); СтильКолонки6.ИмяОтображаемого = "Инкремент"; СтильКолонки6.ТекстЗаголовка = "Инкремент"; СтильКолонки6.Ширина = 90; СтильКолонки6.Выравнивание = Ф.ГоризонтальноеВыравнивание.Центр; СтильТаблицыСеткиДанных1.СтилиКолонкиСеткиДанных.Добавить(СтильКолонки6); СеткаДанных1.ИсточникДанных = ТаблицаДанных1; Кнопка1 = Форма1.ЭлементыУправления.Добавить(Ф.Кнопка()); Кнопка1.Правее(СеткаДанных1, 10); Кнопка1.Верх = 10; Кнопка1.Нажатие = Ф.Действие(ЭтотОбъект, "Кнопка1_Нажатие"); Кнопка1.Текст = "Текущая ячейка"; Кнопка1.Высота = Кнопка1.Высота * 2; Сообщить(?( "" + СеткаДанных1.ТекущаяЯчейка = "КлЯчейкаСеткиДанных" , "", "!!! ") + "СеткаДанных.ТекущаяЯчейка (DataGrid.CurrentCell) Свойство" + " " + ТекущаяДата());

Смотрите также

СеткаДанных (DataGrid) Класс | Библиотека OneScriptForms