mvc腳本
㈠ 什麼是MVC啊
MVC全名是Model View Controller,是模型(model)-視圖(view)-控制器(controller)的縮寫,一種軟體設計典範,用一種業務邏輯、數據、界面顯示分離的方法組織代碼,將業務邏輯聚集到一個部件裡面,在改進和個性化定製界面及用戶交互的同時,不需要重新編寫業務邏輯。
MVC被獨特的發展起來用於映射傳統的輸入、處理和輸出功能在一個邏輯的圖形化用戶界面的結構中。
MVC開始是存在於桌面程序中的,M是指業務模型,V是指用戶界面,C則是控制器,使用MVC的目的是將M和V的實現代碼分離,從而使同一個程序可以使用不同的表現形式。
比如一批統計數據可以分別用柱狀圖、餅圖來表示。C存在的目的則是確保M和V的同步,一旦M改變,V應該同步更新。
模型-視圖-控制器(MVC)是Xerox PARC在二十世紀八十年代為編程語言Smalltalk-80發明的一種軟體設計模式,已被廣泛使用。
後來被推薦為Oracle旗下Sun公司java EE平台的設計模式,並且受到越來越多的使用ColdFusion和PHP的開發者的歡迎。模型-視圖-控制器模式是一個有用的工具箱,它有很多好處,但也有一些缺點。
(1)mvc腳本擴展閱讀:
MVC 編程模式:
MVC 是一種使用 MVC(Model View Controller 模型-視圖-控制器)設計創建 Web 應用程序的模式:
1、Model(模型)表示應用程序核心(比如資料庫記錄列表)。
2、View(視圖)顯示數據(資料庫記錄)。
3、Controller(控制器)處理輸入(寫入資料庫記錄)
MVC 模式同時提供了對 HTML、CSS 和 JavaScript 的完全控制:
1、Model(模型)是應用程序中用於處理應用程序數據邏輯的部分。
通常模型對象負責在資料庫中存取數據。
2、View(視圖)是應用程序中處理數據顯示的部分。
通常視圖是依據模型數據創建的。
3、Controller(控制器)是應用程序中處理用戶交互的部分。
通常控制器負責從視圖讀取數據,控制用戶輸入,並向模型發送數據。
MVC 分層有助於管理復雜的應用程序,因為您可以在一個時間內專門關注一個方面。例如,您可以在不依賴業務邏輯的情況下專注於視圖設計。同時也讓應用程序的測試更加容易。
MVC 分層同時也簡化了分組開發。不同的開發人員可同時開發視圖、控制器邏輯和業務邏輯。
框架內容:
MVC指MVC模式的某種框架,它強制性的使應用程序的輸入、處理和輸出分開。使用MVC應用程序被分成三個核心部件:模型、視圖、控制器。它們各自處理自己的任務。最典型的MVC就是JSP + servlet + javabean的模式。
1、視圖
視圖是用戶看到並與之交互的界面。對老式的Web應用程序來說,視圖就是由HTML元素組成的界面,在新式的Web應用程序中,HTML依舊在視圖中扮演著重要的角色,但一些新的技術已層出不窮,它們包括Adobe Flash和像XHTML,XML/XSL,WML等一些標識語言和Web services.
MVC好處是它能為應用程序處理很多不同的視圖。在視圖中其實沒有真正的處理發生,不管這些數據是聯機存儲的還是一個雇員列表,作為視圖來講,它只是作為一種輸出數據並允許用戶操縱的方式。
2、模型
模型表示企業數據和業務規則。在MVC的三個部件中,模型擁有最多的處理任務。
例如它可能用像EJBs和ColdFusion Components這樣的構件對象來處理資料庫,被模型返回的數據是中立的,就是說模型與數據格式無關,這樣一個模型能為多個視圖提供數據,由於應用於模型的代碼只需寫一次就可以被多個視圖重用,所以減少了代碼的重復性。
3、控制器
控制器接受用戶的輸入並調用模型和視圖去完成用戶的需求,所以當單擊Web頁面中的超鏈接和發送HTML表單時,控制器本身不輸出任何東西和做任何處理。它只是接收請求並決定調用哪個模型構件去處理請求,然後再確定用哪個視圖來顯示返回的數據。
常見框架Struts:
Struts是Apache軟體基金下Jakarta項目的一部分。Struts框架的主要架構設計和開發者是Craig R.McClanahan。Struts 是Java Web MVC框架中不爭的王者。經過長達九年的發展,Struts已經逐漸成長為一個穩定、成熟的框架,並且佔有了MVC框架中最大的市場份額。
但是Struts某些技術特性上已經落後於新興的MVC框架。面對Spring MVC、Webwork2這些設計更精密,擴展性更強的框架,Struts受到了前所未有的挑戰。但站在產品開發的角度而言,Struts仍然是最穩妥的選擇。
Struts有一組相互協作的類(組件)、Servlet以及jsp tag lib組成。基於struts構架的web應用程序基本上符合JSP Model2的設計標准,可以說是MVC設計模式的一種變化類型。
根據上面對framework的描述,很容易理解為什麼說Struts是一個web framework,而不僅僅是一些標記庫的組合。但 Struts 也包含了豐富的標記庫和獨立於該框架工作的實用程序類。
Struts有其自己的控制器(Controller),同時整合了其他的一些技術去實現模型層(Model)和視圖層(View)。
在模型層,Struts可以很容易的與數據訪問技術相結合,包括EJB,JDBC和Object Relation Bridge。在視圖層,Struts能夠與JSP, Velocity Templates,XSL等等這些表示層組件相結合。
參考資料:
網路-MVC框架
㈡ 如何實現MVC模式
最簡單的方法是使用struts或jsf等mvc的框架,本身就是一個實現。如果自己實現,比較復雜的就是要自己寫一個總控制器,接受所有用戶的請求,進行分發給其他servlet或直接進行頁面跳轉。不建議自己實現,建議使用一個mvc框架,然後搞明白他的生命周期和原理,再去看框架總控制器的源代碼,這樣比較好。
原理:
jsp發展經歷了兩個模型時代,jsp模型一時代是把代碼都寫在jsp頁面上,用戶訪問jsp頁面時,jsp頁面來對資料庫進行操作並返回值到jsp頁面,這樣第一不好維護,第二安全性不高,第三代碼結構不清晰,第四重用性不高。於是就有了jsp模型二時代,人們將所有的頁面請求交給一個servlet控制器來接受,然後進行分發,由該servlet來決定調用其他servlet訪問資料庫還是進行頁面跳轉,這個servelt就是MVC中的C,struts中好像叫ActionServlet,Jsf中叫FacesServelt,web.xml中配置的就是總servlet控制器,為了更好的分層,重用,降低依賴性,就有了MVC,由M層接受和綁定用戶的數據,V層進行展現,C層進行控制。
目前主流的開發模式是四層開發模式:界面層(page)+動作處理層(action)+業務邏輯層(service)+數據訪問層(),page層用於展現頁面,action層用於捕獲用戶事件並調用service層處理業務邏輯,service要處理業務邏輯肯定就要對資料庫進行增刪改查,拼接HQL語句,然後調用層對資料庫進行操作,hibernate完成的就是DAO層。但是這樣一來action層對service層產生了依賴,因為要創建一個service介面的引用,service層對層產生了依賴,就是說實例化一個action層的對象,同時要至少實例化一個service層和至少實例化一個層,於是spring的IOC就可以起作用了,就可以降低各層之間的依賴。將各層做為介面對象實例配置到spring中,降低依賴。
㈢ ASP.NET MVC中實現多個按鈕提交的幾種要領 [圖]
有時刻會遇到這種情況:在一個表單上須要多個按鈕來完成不一樣的功能,比如一個基本的審批功能。假如是用webform那不須要探討,但asp.net mvc中一個表單只好提交到一個Action處理,相比較較麻煩點。要領一:運用客戶端腳本比如咱們在View中這樣寫:以下為引用的內容:<input type="submit" value="審核議決 " onclick='this.form.action="<%=Url.Action("Action1") %>";' />
<input type="submit" value="審核不議決 " onclick='this.form.action="<%=Url.Action("Action2") %>";' />
<input type="submit" value="返回" onclick='this.form.action="<%=Url.Action("Action3") %>";' />在點擊提交按鈕時,先改動 Form的action屬性,使表單提交到按鈕相應的action處理。但有的時刻,可能Action1和2的邏輯特別類似,也許只是將某個欄位的值置為1或者0,那麼分開到二個action中又顯得有點多餘了。要領二:在Action中判斷議決哪個按鈕提交在View中,咱們不用任何客戶端腳本處理,給每個提交按鈕加好name屬性:以下為引用的內容:<input type="submit" value="審核議決 " name="action" />
<input type="submit" value="審核不議決 " name="action"/>
<input type="submit" value="返回" name="action"/>然後在控制器中判斷:以下為引用的內容:[HttpPost]
public ActionResult Index(string action /* 其它參數*/){if (action=="審核議決 "){//}else if (action=="審核不議決 "){//}else{//}}
㈣ mvc視圖中怎麼上傳圖片並顯示
如果只是上傳的話那太容易了,如果還要顯示那就難了,因為要顯示的話就不能只向伺服器提交一次請求,必須非同步提交。下面的例子是我親自寫的,非同步提交上傳圖片並預覽。全部代碼都在。
返回到前台頁面的JSON格式對象是以類的對象。
publicclassReturnImage
{
publicstringbig{get;set;}
publicstringsmall{get;set;}
publicstringisSuccessfull{get;set;}
publicstringmessage{get;set;}
}
對於上傳和生成縮略圖,請自行完成,以下是ASP.NETMVC的例子。
publicclassHomeController:Controller
{
//
//GET:/Home/
publicActionResultIndex()
{
returnView();
}
///<summary>
///上傳圖片
///</summary>
///<returns></returns>
publicActionResultUploadImage()
{
//定義錯誤消息
JsonResultmsg=newJsonResult();
try
{
//接受上傳文件
HttpPostedFileBasepostFile=Request.Files["upImage"];
if(postFile!=null)
{
DateTimetime=DateTime.Now;
//獲取上傳目錄轉換為物理路徑
stringuploadPath=Server.MapPath("~/UploadFiles/"+time.Year+"/"+time.ToString("yyyyMMdd")+"/");
//文件名
stringfileName=time.ToString("yyyyMMddHHmmssfff");
//後綴名稱
stringfiletrype=System.IO.Path.GetExtension(postFile.FileName);
//獲取文件大小
longcontentLength=postFile.ContentLength;
//文件不能大於2M
if(contentLength<=1024*2048)
{
//如果不存在path目錄
if(!Directory.Exists(uploadPath))
{
//那麼就創建它
Directory.CreateDirectory(uploadPath);
}
//保存文件的物理路徑
stringsaveFile=uploadPath+fileName+"_big"+filetrype;
try
{
//保存文件
postFile.SaveAs(saveFile);
//保存縮略圖的物理路徑
stringsmall=uploadPath+fileName+"_small"+filetrype;
MakeThumbnail(saveFile,small,320,240,"W");
ReturnImageimage=newReturnImage();
image.big="/UploadFiles/"+time.Year+"/"+time.ToString("yyyyMMdd")+"/"+fileName+"_big"+filetrype;
image.small="/UploadFiles/"+time.Year+"/"+time.ToString("yyyyMMdd")+"/"+fileName+"_small"+filetrype;
msg=Json(image);
}
catch
{
msg=Json("上傳失敗");
}
}
else
{
msg=Json("文件大小超過限制要求");
}
}
else
{
msg=Json("請選擇文件");
}
}
catch(Exceptione)
{
;
}
msg.ContentType="text/html";
returnmsg;
}
///<summary>
由於回答超過最大限制,///生成縮略圖的代碼請向我索取