MVC 및 GUI: MVC 패턴에 따라 ActionListener는 어디에 속합니까?
배경:
당신이 언급한 것처럼 이 질문은 ActionListener의 배치와 관련이 있습니다. Java에서 GUI를 생성하는 데 사용되는 MVC(Model-View-Controller) 아키텍처 패턴은 MVC를 엄격하게 따르지 않습니다.
ActionListener 배치:
1. 뷰 책임:
기술적으로는 뷰 그런 다음 뷰는 UI 컨트롤에 연결된 ActionListener를 컨트롤러에 알려야 합니다. 이렇게 하면 컨트롤러가 UI 구성 요소에서 격리되어 구현된 모든 뷰와 함께 작동할 수 있습니다.
2 . 전용 뷰 리스너:
ActionListener를 UI 컨트롤에 직접 연결하는 대신 전용 뷰를 생성할 수도 있습니다. 경청자. 이 리스너는 뷰가 생성할 수 있는 작업을 설명합니다. 예를 들어:
public interface MainViewListener { void didPerformClose(MainView mainView); }
컨트롤러는 이 리스너를 통해 뷰를 구독하고 뷰는 닫기 버튼을 누를 때 didPerformClose를 호출합니다.
계층 간 통신 관리:
이상적으로는 MVC 아키텍처의 계층입니다. 인터페이스를 통해 통신해야 합니다. 이렇게 하면 레이어를 독립적으로 교체할 수 있으므로 각 레이어가 다른 레이어에 대한 인식을 최소화하려고 합니다.
업데이트된 예:
느슨한 결합을 사용한 로그인 보기 예:
로그인 예를 고려해보세요. CredentialsView 및 LoginView에는 특정 책임이 있습니다.
CredentialsView:
LoginView:
통신용 인터페이스를 사용하면 시스템을 손상시키지 않고 뷰와 컨트롤러를 쉽게 교체하거나 업데이트할 수 있습니다.
ActionListener 배치:
업데이트된 예에서 인증 및 취소 버튼에 대한 ActionListener는 여전히 LoginView에 있습니다. 그러나 LoginView는 작동합니다. CredentialsView의 컨트롤러와 LoginViewController의 뷰로 사용됩니다. 이 접근 방식은 명확한 책임 분리를 유지하면서 논리를 단순화합니다.
결론:
위 내용은 MVC 아키텍처에서 ActionListener는 어디에 있어야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!