使用ViewModel來實現多個Model傳送至視圖

在開發ASP.NET MVC時,咱們會趕上這樣的情形,須要一次性傳送多個Model從控制器Controller至視圖View。數據庫

 實現很簡單,只是建立一個集合類便可。

Ok,下面先在數據庫準備一些數據,如:


ide

CREATE TABLE [dbo].[TableA]
(
    [A] NVARCHAR(30) NULL,
    [B] NVARCHAR(30) NULL,
    [C] NVARCHAR(30) NULL
)
GO

INSERT INTO [dbo].[TableA] ([A],[B],[C])
VALUES ('a1','b1','c1'),('a2','b2','c2'),
       ('a3','b3','c3'),('a4','b4','c4'),
       ('a5','b5','c5')
GO

CREATE PROCEDURE [dbo].[usp_TableA_GetAll]
AS
SELECT [A],[B],[C] FROM [dbo].[TableA]
GO
Source Code

 

另外一份數據:
spa

 

CREATE TABLE [dbo].[TableB]
(
    [X] DECIMAL(18,8) NULL,
    [Y] DECIMAL(18,8) NULL,
    [Z] DECIMAL(18,8) NULL
)
GO

INSERT INTO [dbo].[TableB] ([X],[Y],[Z]) 
VALUES (0.2,0.3,0.4),(1.2,2.3,3.4),(4.2,5.3,6.4)
GO

CREATE PROCEDURE [dbo].[usp_TableB_GetAll]
AS
SELECT [X],[Y],[Z] FROM [dbo].[TableB]
GO
Source Code

 

此時回至ASP.NET MVC項目中,建立兩個model:
TableA model:
3d

 

TableB model:
code

 

如今你需還要建立兩個實體,去獲取數據庫的數據:
TableAEntity:
blog

 

TableBEntity:
開發

 

一切就緒,轉入正題,實現ViewModel類:
get

 

在控制器中:
it

 

下面是視圖實現:
event

 

上圖#2代碼以下:

 

程序運行結果:

 

本篇關鍵部分,是建立另一個ViewModel類,在類中添加相關model有屬性。下面是重溫一下:

這種方法,就等於寫死了,若是有另外的model添加或是刪除,得來去修改這個ViewModel類。

相關文章
相關標籤/搜索