當前位置:
首頁 > 知識 > MVC 的模式

MVC 的模式

MVC 模式代表 Model-View-Controller(模型-視圖-控制器) 模式。這種模式用於應用程序的分層開發。

  • Model(模型) - 模型代表一個存取數據的對象或 JAVA POJO。它也可以帶有邏輯,在數據變化時更新控制器。

  • View(視圖) - 視圖代表模型包含的數據的可視化。

  • Controller(控制器) - 控制器作用於模型和視圖上。它控制數據流向模型對象,並在數據變化時更新視圖。它使視圖與模型分離開。

實現

我們將創建一個作為模型的 Student 對象。StudentView 是一個把學生詳細信息輸出到控制台的視圖類,StudentController 是負責存儲數據到 Student 對象中的控制器類,並相應地更新視圖 StudentView。

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

MVC 的模式

步驟 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) {
//從數據可獲取學生記錄
Student model = retriveStudentFromDatabase();
//創建一個視圖:把學生詳細信息輸出到控制台
StudentView view = new StudentView();
StudentController controller = new StudentController(model, view);
controller.updateView();
//更新模型數據
controller.setStudentName("John");
controller.updateView();
}
private static Student retriveStudentFromDatabase(){
Student student = new Student();
student.setName("Robert");
student.setRollNo("10");
return student;
}}

步驟 5

驗證輸出。

Student: Name: RobertRoll No: 10Student: Name: JohnRoll No: 10

喜歡這篇文章嗎?立刻分享出去讓更多人知道吧!

本站內容充實豐富,博大精深,小編精選每日熱門資訊,隨時更新,點擊「搶先收到最新資訊」瀏覽吧!


請您繼續閱讀更多來自 程序員小新人學習 的精彩文章:

jQuery UI 實例-自動完成(Autocomplete)
jQuery UI 使用

TAG:程序員小新人學習 |