1. Построение приложений с привязанными данными в Windows Forms

Программное добавление столбцов

прежде всего нужно определить столбцы

Существуют различные способы программного добавления к сетке столбцов и строк. Прежде всего нужно определить столбцы, из которых будет составлена сетка. Для определения столбца вы должны специфицировать шаблон ячейки, по которому будет строиться столбец. Шаблон ячейки будет по умолчанию использоваться для ячеек в данном столбце, когда к сетке добавляется строка. Шаблоны ячеек являются экземплярами производных от DataGridViewCell Классов. Для представления столбцов из текстовых полей, кнопок, комбинированных полей, гиперссылок и изображений вы можете воспользоваться встроенными типами ячеек. NET. Еще один встроенный тип ячейки представляет заголовки столбцов в сетке. Для каждого из типов ячеек имеется соответствующий тип столбца, предназначенный для хранения ячеек такого типа. Вы можете конструировать экземпляры DataGridViewColumn, В которых тип ячейки представлен как шаблон, но, как правило, вы создаете экземпляр столбца производного типа, предназначенного для конкретного типа ячеек, с которым вы хотите работать. Кроме того, вы можете определять свои собственные специальные типы ячеек и столбцов.

Пока давайте ограничимся самым распространенным и простым типом ячейки, ячейкой текстового поля DataGridViewTextBoxCell. Это, кстати, тип ячейки по умолчанию. Добавить программно столбец текстовых полей можно одним из трех способов. Воспользуйтесь перегруженной версией метода Add Коллекции Columns Сетки: добавляете столбцы подобным образом, значения их имен и заголовков по умолчанию нулевые. Чтобы установить эти или другие свойства экземпляра столбца, вы можете обращаться к ним как до, так и после добавления столбца к коллекции Columns. Вы можете также воспользоваться индексацией коллекции Columns И получить ссылку на столбец, после чего использовать эту ссылку для доступа к любым свойствам столбца.

Привязка ведущий-детализация

вы уже видели простой пример

Привязка к данным «ведущий-детализация» сильно отличается от того, как это делается в WindowsForms. Вы уже видели простой пример в листинге А.8. Для каждого привязанного элемента управления, который будет участвовать в представлении ведущий-детализация, вы устанавливаете отдельный управляющий элемент источника данных. Первый источник данных обычным образом привязывается к родительской коллекции данных. Если дочерним источником является SqlDataSource, В его свойстве SelectCommand Устанавливается соответствующий запрос для получения дочерней коллекции данных. Затем вы по выбору можете либо предусмотреть параметризованное предложение Where, Либо установить в свойстве FilterExpression Элемента управления источника допустимый критерий фильтрации, снабдив его любыми необходимыми параметрами в FilterPa — Rameters. Пример такого подхода показан в листинге А.9. В этом примере сетка заказчиков привязана к SqlDataSource Тем же способом, что был показан в предыдущих примерах. Сетка заказов привязана к своему собственному источнику данных, запрос которого выбирает из таблицы Orders все записи заказов. Затем в свойстве FilterExpression Источника устанавливается строка с заместителем. Заместитель заполняется из параметра фильтра, который предоставляется объектом ControlParameter. Этот объект извлекает значение, которое будет использоваться для фильтрации, из некоторого другого элемента управления на странице, в данном случае из сетки заказчиков, по указанному имени свойства этого элемента управления . В результате на Web-страницу поступают все записи заказов, но в действительности на отображаемые данные наложен фильтр, отбирающий записи, которые будут переданы через источник данных.

Верификация в Windows Forms

примеры верификации включают в себя

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

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

Замораживание столбцов и строк

часто при прокрутке можно потерять

Когда вы имеете дело с массой столбцов или строк, прокрутка неизбежна. Часто при прокрутке можно потерять контекст строк или столбцов, на которые вы смотрите, особенно если этот контекст указывается значениями в каких-то других строках ил столбцах. Скажем, вы прокручиваете сетку с информацией о продуктах. Если в ней много столбцов, ассоциированных с каждым из продуктов, то при прокрутке вправо, когда вы хотите просмотреть не видимые в данный момент столбцы, вы потеряете контекст наименования продукта, которое при прокрутке уходит с экрана влево. На самом деле в такой ситуации вам нужно заморозить столбец с наименованиями продуктов, чтобы он все время оставался на экране, а прокручивались только остальные столбцы. Подобным же образом бывают случаи, когда вам нужно отображать одну или несколько строк в верхней части сетки, которые должны оставаться на месте при прокрутке сетки вниз к другим ее строкам. В элементе управления DataGridView Это достигается просто: нужно лишь установить в True Свойство Frozen Соответствующего столбца или строки. В частности, если вы замораживаете столбец, то этот столбец и все столбцы слева от него не будут сдвигаться, когда вы производите прокрутку к правому краю сетки. Точно так же при замораживании строки эта строка и те, что расположены выше, не будут смещаться, когда вы станете прокручивать сетку вниз. Если вы собираетесь заморозить столбец или строку, то скорее всего захотите как-то визуально обозначить для пользователя логическую границу между замороженным элементом и незамороженными, которые находятся рядом. Проще всего это можно сделать, установив для свойства Dividerwidth Столбца или DividerHeight Строки значение, отличное от значения по умолчанию. Эти свойства являются целыми значениями, указывающими, сколько пикселов используется для рисования разделителя между ячейками данного столбца или строки и соседними ячейками. Вот простой пример кода, замораживающего одновременно столбец и строку с заданием ширины разделителя: