PropertyDescriptor.SetValue(Object, Object) Метод
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
При переопределении в производном классе устанавливает другое значение для компонента.
public:
abstract void SetValue(System::Object ^ component, System::Object ^ value);
public abstract void SetValue (object component, object value);
public abstract void SetValue (object? component, object? value);
abstract member SetValue : obj * obj -> unit
Public MustOverride Sub SetValue (component As Object, value As Object)
Параметры
- component
- Object
Компонент со значением свойства, которое нужно установить.
- value
- Object
Новое значение.
Комментарии
Как правило, этот метод реализуется с помощью отражения.
Этот метод создает DesignerTransaction автоматически в следующем порядке:
Метод вызывает IDesignerHost.CreateTransaction метод для создания нового DesignerTransaction для представления изменений.
Метод вызывает IComponentChangeService.OnComponentChanging метод, чтобы указать, что транзакция началась, и изменения происходят.
Метод сбрасывает свойство в значение, определенное порядком проверки этого метода.
Метод вызывает IComponentChangeService.OnComponentChanged метод, чтобы указать, что произошли изменения.
Вызовы DesignerTransaction.Commit метода, указывающие, что транзакция завершена.
Цель транзакции заключается в поддержке Undo
и Redo
функциональности.
Примечания для тех, кто реализует этот метод
При переопределении этого метода необходимо задать значение свойства, вызвав соответствующий метод SetMyProperty, который необходимо реализовать. Если указанное значение недопустимо, компонент должен вызвать исключение, которое передается. Необходимо разработать свойство таким образом, чтобы метод GetMyProperty (реализованный) после метода SetMyProperty возвращал значение, переданное, когда метод SetMyProperty не создает исключение.