- 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)絡(luò)教育學(xué)習(xí)指導(dǎo)
- 解析QUIC/HTTP3:未來互聯(lián)網(wǎng)的基石
- 物聯(lián)網(wǎng)智慧安監(jiān)技術(shù)
- Building E-commerce Sites with VirtueMart Cookbook
- Building Django 2.0 Web Applications
- Hands-On Industrial Internet of Things
- TCP/IP入門經(jīng)典(第5版)
- 圖解手機元器件維修技巧
- 2小時讀懂物聯(lián)網(wǎng)
- 夢工廠之材質(zhì)N次方:Maya材質(zhì)手冊
- 計算機網(wǎng)絡(luò)技術(shù)及應(yīng)用
- Learning Storm
- NB-IoT原理和優(yōu)化
- 智慧城市中的物聯(lián)網(wǎng)技術(shù)
- 黑客與反黑工具使用詳解