設計模式 - MVC模式



MVC 模式代表模型-檢視-控制器模式。此模式用於分離應用程式的關注點。

  • 模型 - 模型表示一個物件或攜帶資料的 JAVA POJO。如果其資料發生變化,它還可以具有更新控制器的邏輯。

  • 檢視 - 視圖表示模型包含的資料的視覺化。

  • 控制器 - 控制器作用於模型和檢視。它控制資料流進入模型物件,並在資料更改時更新檢視。它使檢視和模型分離。

實施

我們將建立一個充當模型的學生物件。StudentView將是一個可以將學生詳細資訊列印到控制檯的檢視類,而StudentController是負責將資料儲存在學生物件中並在相應地更新檢視StudentView的控制器類。

MVCPatternDemo,我們的演示類,將使用StudentController來演示 MVC 模式的用法。

MVC Pattern UML Diagram

步驟 1

建立模型。

Student.java

public class Student {
   private String rollNo;
   private String name;
   
   public String getRollNo() {
      return rollNo;
   }
   
   public void setRollNo(String rollNo) {
      this.rollNo = rollNo;
   }
   
   public String getName() {
      return name;
   }
   
   public void setName(String name) {
      this.name = name;
   }
}

步驟 2

建立檢視。

StudentView.java

public class StudentView {
   public void printStudentDetails(String studentName, String studentRollNo){
      System.out.println("Student: ");
      System.out.println("Name: " + studentName);
      System.out.println("Roll No: " + studentRollNo);
   }
}

步驟 3

建立控制器。

StudentController.java

public class StudentController {
   private Student model;
   private StudentView view;

   public StudentController(Student model, StudentView view){
      this.model = model;
      this.view = view;
   }

   public void setStudentName(String name){
      model.setName(name);		
   }

   public String getStudentName(){
      return model.getName();		
   }

   public void setStudentRollNo(String rollNo){
      model.setRollNo(rollNo);		
   }

   public String getStudentRollNo(){
      return model.getRollNo();		
   }

   public void updateView(){				
      view.printStudentDetails(model.getName(), model.getRollNo());
   }	
}

步驟 4

使用StudentController方法來演示 MVC 設計模式的用法。

MVCPatternDemo.java

public class MVCPatternDemo {
   public static void main(String[] args) {

      //fetch student record based on his roll no from the database
      Student model  = retriveStudentFromDatabase();

      //Create a view : to write student details on console
      StudentView view = new StudentView();

      StudentController controller = new StudentController(model, view);

      controller.updateView();

      //update model data
      controller.setStudentName("John");

      controller.updateView();
   }

   private static Student retriveStudentFromDatabase(){
      Student student = new Student();
      student.setName("Robert");
      student.setRollNo("10");
      return student;
   }
}

步驟 5

驗證輸出。

Student: 
Name: Robert
Roll No: 10
Student: 
Name: John
Roll No: 10
廣告