참고URL

http://msdn.microsoft.com/query/dev10.query?appId=Dev10IDEF1&l=KO-KR&k=k(SYSTEM.WINDOWS.EVENTSETTER);k(VS.XAMLEDITOR);k(SOLUTIONITEMSPROJECT);k(TargetFrameworkMoniker-%22.NETFRAMEWORK%2cVERSION%3dV4.0%22)&rd=true

 

EventSetter (한번쯤 읽어보고 넘어가자~)

이벤트 setter는 라우트된 이벤트에 대한 응답으로 지정된 이벤트 처리기를 호출하며, 이러한 처리기는 Style을 참조하는 모든 요소에 적용되므로 각각의 개별 요소에 대해 인스턴스 처리기를 연결하지 않아도 됩니다.Style.Setters만이 EventSetter 개체를 지원합니다.

라우트된 이벤트에 대해서만 이벤트 setter를 선언할 수 있습니다.직접 라우팅 전략, bubbling 이벤트 또는 tunneling 이벤트를 사용하여 라우트된 이벤트에 대해 이벤트 setter를 선언할 수 있습니다.

EventSetter 클래스의 인스턴스는 대개 XAML(Extensible Application Markup Language)를 통해, 즉 XAML를 통해 정의되는 스타일 내의 개체 요소로 만들어집니다.EventSetter도 코드에서 인스턴스화할 수 있습니다.

이벤트 setter는 테마 리소스 사전에 포함된 스타일에는 사용할 수 없습니다.이는 테마 리소스 사전이 대개 런타임에 느슨한 BAML(이진 XAML) 파일인데다 처리기를 정의하는 관련 코드 숨김이 있을 수 있는 범위가 정의되어 있지 않기 때문입니다.

이벤트 setter를 통해 연결하는 처리기는 이벤트에 대한 클래스 처리기 및 인스턴스 처리기 이후에 호출됩니다.그러므로 클래스 처리기 또는 인스턴스 처리기가 해당 인수에서 이벤트를 처리한 것으로 표시하면 이벤트 setter가 구체적으로 HandledEventsToo true를 설정하지 않는 한 이벤트 setter가 선언하는 처리기는 호출되지 않습니다.

이벤트 setter는 BasedOn 스타일에서 생성될 수도 있습니다.스타일에서 생성되며 BasedOn으로 지정되는 이벤트 setter 처리기는 직접 적용되는 스타일에 대한 처리기 이후에 호출됩니다.

Style.Setters만이 EventSetter 개체를 지원합니다.트리거(TriggerBase 및 파생 클래스)는 EventSetter를 지원하지 않습니다.

 

UI

image 

.xaml

image

 

비하인드 코드

        void FileHyperlinkClick(object sender, RoutedEventArgs e)
        {
            //Hyperlink b = e.Source as Hyperlink;
            Hyperlink hy = sender as Hyperlink;
            //Contract.Data.PersonnelPerformanceReviewDetail 데이터 개체
            Contract.Data.PersonnelPerformanceReviewDetail ppd = this.datagrdPersonnelPerformanceReviewDetail.SelectedItem
                                                                                    as Contract.Data.PersonnelPerformanceReviewDetail;

            if (ppd != null)
            {
                // 특정파일 열기
            }

        }

+ Recent posts