- Hands-On Full:Stack Web Development with ASP.NET Core
- Tamir Dresher Amir Zuker Shay Friedman
- 287字
- 2021-06-10 19:37:27
Routing in SPAs
In SPAs, the complexity needed from ASP.NET Core MVC routing is low, because routing will mostly be taken care of by the frontend code. On the ASP.NET Core MVC end, we will use routing to support client-side routing capabilities.
For this, we will take advantage of conventional routing and set up two catch-all routes, as follows:
app.UseMvc(routes =>
{
routes.MapRoute(
name: "default",
template: "{controller=Home}/{action=Index}/{id?}");
routes.MapSpaFallbackRoute(
name: "spa-fallback",
defaults: new { controller = "Home", action = "Index" });
});
The first default route was discussed earlier in this section. This will enable all incoming requests to be directed to the Index method of the HomeController.
The second route uses the MapSpaFallbackRoute method, instead of the common MapRoute method. The difference between these methods is a small but important one: the MapSpaFallbackRoute method registers a route just like MapRoute does, but whenever a route matches its template and has a file extension at the end, the URL will be treated as a static file request and will return the file as is, without executing an action method. For example, a call to http://example.com/users will execute the Index method within the UsersController class. A call to http://example.com/images/user.png will return a file named user.png from a folder named images.
This capability is extremely important for SPAs that request many static files from the server, such as images, videos, HTML pages, JavaScript files, CSS files, and more.
These two routes enable everything that is needed for the frontend of the SPA to operate correctly. The first route enables using different MVC controllers, which is sometimes needed in large SPAs, and the second route enables the use of routing on the client-side and the serving of static files when requested.
- 連接未來:從古登堡到谷歌的網(wǎng)絡革命
- Building E-commerce Sites with VirtueMart Cookbook
- Hands-On Chatbot Development with Alexa Skills and Amazon Lex
- 網(wǎng)絡故障現(xiàn)場處理實踐(第4版)
- HCNA網(wǎng)絡技術
- 信息通信網(wǎng)絡建設安全管理概要2
- 區(qū)塊鏈輕松上手:原理、源碼、搭建與應用
- 網(wǎng)管工具使用與技巧大全
- Learning Windows 8 Game Development
- 工業(yè)互聯(lián)網(wǎng)創(chuàng)新實踐
- 網(wǎng)絡空間全球治理觀察
- 互聯(lián)網(wǎng)安全的40個智慧洞見(2016)
- Qt5 Python GUI Programming Cookbook
- 網(wǎng)絡安全之道
- 想象的互動:網(wǎng)絡人際傳播中的印象形成