這個示範,我們先不管太多觀念,主要先把第一個MVC頁面給建立起來
感受一下MVC專案開發的感覺
建立新的專案
data:image/s3,"s3://crabby-images/e0017/e0017663ee6a0a676a491ae7bc32c66c51615cbe" alt=""
選擇ASP.NET Core Web應用程式(Model-View-Controller)
data:image/s3,"s3://crabby-images/b19e3/b19e38cbe55e6399373190ae5e3278247b9265aa" alt=""
專案名稱打上HelloWorld
data:image/s3,"s3://crabby-images/680dd/680dd6b3c6d10e0a4b903f8865ec8d4e47fd8570" alt=""
預設不變,建立專案
data:image/s3,"s3://crabby-images/5eb90/5eb9026440568f8a2f9a7b0bb5fedad1c6070d7b" alt=""
先執行啟動不偵錯,看看預設專案範本長什麼樣子
data:image/s3,"s3://crabby-images/f7cca/f7cca3e569b059c1e24ff318caf8a1ff9f0a3113" alt=""
可以看到專案有建好了Home、Privacy兩個頁面,那我們試著增加HelloWorld頁面
data:image/s3,"s3://crabby-images/81256/812561f6c146ec58e3736a6e6ec8185a600a4e66" alt=""
data:image/s3,"s3://crabby-images/26442/26442ecf4c73e1c882156874509009b97e0cb755" alt=""
其實Home連結有另一個網址是/Home/Index
data:image/s3,"s3://crabby-images/2c18b/2c18b615d70e12534b4f795b81c3e706e8d5daa6" alt=""
那我們現在要來建立一個/Home/HelloWorld頁面,首先要去HomeController.cs,增加一個HelloWorld的方法,很簡單的我們就依照Index跟Privacy建一個一模一樣的方法
namespace HelloWorld.Controllers
{
public class HomeController : Controller
{
private readonly ILogger<HomeController> _logger;
public HomeController(ILogger<HomeController> logger)
{
_logger = logger;
}
public IActionResult Index()
{
return View();
}
public IActionResult Privacy()
{
return View();
}
//這邊
public IActionResult HelloWorld()
{
return View();
}
[ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
public IActionResult Error()
{
return View(new ErrorViewModel { RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier });
}
}
}
存檔之後,我們打上/Home/HelloWorld就可以了嗎,當然還不行,會出現以下畫面
data:image/s3,"s3://crabby-images/cc68a/cc68ac666959441dacee30172198559e766eb322" alt=""
其實開發ASP.NET很友善,錯誤訊息通常也很容易看得懂,這裡明確說到,就是我們少了HelloWorld.cshtml,在指示中的兩個資料夾下
那我們可邊可以快速建立一個對應的View,對著程式碼中的View案右鍵,新增檢視
data:image/s3,"s3://crabby-images/4be83/4be8341e8eca8aebb56f7832d3018aeb4b4affb0" alt=""
選擇Razor - 空白,名稱我們就打上HelloWorld.cshtml
data:image/s3,"s3://crabby-images/c6e9d/c6e9d57b18d953d6e06ae76bdcf460ee39d0bf8c" alt=""
這邊我們複製Privacy.cshtml的內容,在HelloWorld.cshtml,改成我們要的內容
@{
ViewData["Title"] = "HelloWorld";
}
<h1>@ViewData["Title"]</h1>
<p>HelloWorld.</p>
之後再回到瀏覽器,我們HelloWorld的頁面就出現啦
data:image/s3,"s3://crabby-images/74377/74377e68bb4a2de5235d8bd77b330511cf7ec669" alt=""
那可以看到上面有連結,我們要到哪裡新增呢?這時就要到View/Shared/_Layout.cshtml,如下圖的html頁面打上連結
data:image/s3,"s3://crabby-images/f7440/f7440974664daf955a769013a3cd649e81dc10b2" alt=""
我們複製現有的然後改成HelloWorld,至於這是什麼語法,我們之後會再談到,今天我們就先直接照著改就好
<li class="nav-item">
<a class="nav-link text-dark" asp-area="" asp-controller="Home" asp-action="HelloWorld">HelloWorld</a>
</li>
存檔之後,我們的連結就出現了
data:image/s3,"s3://crabby-images/f6117/f61173d9380fb111cd8eabf5b665ebf26f39d741" alt=""
那以上就是一個建立MVC頁面的一個流程
至於原理觀念,或者我想要建立一個新的Controllers怎麼做,就等到之後的章節在一步步講解了
今天就先抓一個感覺,想聽更多的廢話可以看影片
新手分享學習成果,若有錯誤,煩請告知修正,感謝🙏