日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > HTML >内容正文

HTML

Blazor带我重玩前端(四)

發布時間:2023/12/4 HTML 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Blazor带我重玩前端(四) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

布局

Blazor中的布局和MVC中的布局是類似的。

創建布局

新建一個Razor頁面,所有新增的布局都要繼承LayoutComponentBase,同時標識自定義內容的輸出位置,即標識Body的位置。如圖所示:

應用布局

我們修改一下index.razor頁面中的代碼,增加@layout MyLayout。運行后,按F12查看網頁源代碼如下:布局的內容被<app></app>標簽包著,這也意味著,我們的layout并不是頁面的全部內容,而僅僅只是blazor相關的內容。
順便說一下,布局是可以“繼承”的,也就是說,我們可以聲明一個新的布局繼承自MainLayout.razor ,只需要指定如下代碼即可:

@inherits?LayoutComponentBase @layout?MainLayout

路由

路由定義

路由模板

定義在App.razor中:

<Router?AppAssembly="@typeof(Program).Assembly"><Found?Context="routeData"><RouteView?RouteData="@routeData"?DefaultLayout="@typeof(MainLayout)"?/></Found><NotFound><LayoutView?Layout="@typeof(MainLayout)"><p>Sorry,?there's?nothing?at?this?address.</p></LayoutView></NotFound> </Router>

里面有三個重要組件:

  • Found:路由機制渲染存在的頁面

  • RouteView:接收路由數據和默認的布局

  • NotFound:路由機制渲染不存在的頁面,當然我們可以自己定義404內容

定義路由

路由定義很簡單,只需要前綴@page,然后定義你的路由名稱即可,如@page “index”。當然一個頁面可以定義多個路由。如下:

  • @page “/index”

  • @page “/”

  • @page “/home/index”

定義與約束路由參數

這個其實和ASP.NET Core API的路由方式沒有太大區別,包括路由約束部分。

@page?"/Index/{Theme}"

接收參數的方式也很簡單,需要聲明一個get;set的屬性,并且必須是public的,同時需要用Parameter特性去標識。

@{[Parameter]public?string?Theme{get;set;} }

以下是路由約束,相比于MVC,這些約束也沒什么變化。

我們先看一個例子

<div?class="@NavMenuCssClass"?@onclick="@ToggleNavMenu"><ul?class="nav?flex-column"><li?class="nav-item?px-3"><NavLink?class="nav-link"?href=""?Match="NavLinkMatch.All"><span class="oi?oi-home"?aria-hidden="true"></span>?Home</NavLink></li><li?class="nav-item?px-3"><NavLink?class="nav-link"?href="MyComponent"?Match="NavLinkMatch.Prefix"><span class="oi?oi-plus"?aria-hidden="true"></span>?My?Component</NavLink></li></ul> </div>?

NavLinkMatch有兩個枚舉:

  • NavLinkMatch.All:當匹配整個URL時,可以路由到頁面

  • NavLinkMatch.Prefix:這是默認使用的,當匹配到當前URL的前綴時,可以路由到頁面。如https://localhost:5001/MyComponent和 https://localhost:5001/MyComponent/AnotherSegment 接下來我們看一下如果通過代碼方式進行頁面跳轉,那就是可以使用NavigationManager進行頁面跳轉,其實例是通過注入獲取的。

@inject?NavigationManager?NavigationManager

成員描述
Uri獲取當前的絕對URL
BaseUri獲取根URI(末尾帶斜杠),然后以此追加相對路徑進而組合成絕對URI
NavigateTo導航到指定的 URI(前提是設置forceLoad 為true),使用此方式,會繞過客戶端路由,使得瀏覽器會強制刷新頁面,如:UriHelper.NavigateTo("/DataList/" + Index, forceLoad);
LocationChanged當導航位置更改時觸發的事件
ToAbsoluteUri將相對 URI 轉換為絕對 URI
ToBaseRelativePath給定一個根 URI(例如,以前由BaseUri返回的 URI),將絕對 URI 轉換為帶有根URI 前綴的相對 URI

其他

Blazor雖然提供了十分豐富而又靈活的路由功能,但目前還沒有一個明確的功能讓我們使用可選參數,但是我們可以變通一下,就是設置接收的數據類型為可空類型。代碼如下:

@page?“DataList/{Index:int}” [Parameter] public?int??Index?{?get;?set;?} protected?override?void?OnInitialized() {base.OnInitialized();Index?=?Index???1; }
  • Blazor帶我重玩前端(一)

  • Blazor帶我重玩前端(二)

  • Blazor帶我重玩前端(三)

總結

以上是生活随笔為你收集整理的Blazor带我重玩前端(四)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 人人妻人人爽人人澡人人精品 | 欧美乱大交xxxxx | 婷婷色激情 | 毛片99 | 丝袜诱惑一区二区 | 九色porny自拍 | 国产一级二级在线 | 99re8在线精品视频免费播放 | 激情六月 | 色哟哟无码精品一区二区三区 | 日韩专区一区二区三区 | 免费大片av | 天天操天天射天天 | 欧美人妻精品一区二区免费看 | 中文字幕无码毛片免费看 | 正在播放亚洲 | 操操操操网 | 久久影院一区二区 | 激情婷婷六月 | 99久久婷婷国产精品综合 | 亚洲大片精品 | 性欧美一区 | 超碰免费在线 | 久草网在线视频 | 久久精品伦理 | 色爱av综合 | 密桃成熟时在线观看 | 国产不卡毛片 | 丁香婷婷九月 | 久久久久久久性 | 欧美成人免费网站 | 13日本xxxxxⅹxxx20 | 日韩欧美一级片 | 夜夜爽夜夜 | 亚洲国产永久 | 西西444www大胆无视频 | 国产精品视频一区二区在线观看 | 国产精品毛片一区视频播 | 一区二区三区四区免费观看 | 老头糟蹋新婚少妇系列小说 | 国产精品久久久久久免费免熟 | 一区二区在线视频 | 香蕉久热| 国产精品亚洲欧美 | www.av欧美| 国产高清在线不卡 | 亚洲视频在线免费播放 | 国产精品视频一区二区在线观看 | 日韩精品少妇 | 欧美亚洲国产成人 | 青青草一区二区三区 | 反差在线观看免费版全集完整版 | 欧美日韩五月天 | 中文av网| 深夜福利免费在线观看 | 老司机久久精品视频 | 国产在线视频卡一卡二 | 在线观看你懂的网址 | 无码人妻精品丰满熟人区 | 亚洲一区色 | 久久久这里有精品 | 国产夫妻在线 | 精品在线一区二区三区 | 超碰人人爱| 午夜做爰xxxⅹ性高湖视频美国 | 性一交一乱一色一免费无遮挡 | 免费看的一级片 | 国产精品无码久久久久成人app | 妓院一钑片免看黄大片 | 国产精品111| 蜜桃av导航 | 1024福利| 久热伊人 | 欧美乱子伦 | 亚洲成人一区二区 | 欧美一区一区 | 中文 欧美 日韩 | 中文字幕视频网站 | 色爱av综合网 | 久久久老熟女一区二区三区91 | 天天摸天天操天天干 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 日日夜夜精品视频免费 | 刘亦菲毛片| 精品人妻无码专区在线 | 免费看裸体网站视频 | 欧美人妻一区二区三区 | 99福利视频 | www日本视频| 91碰碰| 亚洲白浆 | 精品国产18久久久久久 | av不卡在线观看 | 久久久久久久久久久久久久国产 | 一区二区三区视频观看 | 中国黄色在线视频 | 日韩国产在线一区 | 992tv成人免费视频 | 欧美黄色网络 |