Blazor Webassembly多标签页实现非iframe的实现


前面用iframe实现了多标签页,这次是不用iframe实现的多标签页.参考了一下Ant Design Blazor.
基本功能已经都实现了不论是标签滚动、激活、左移、右移、关闭其他,还是在内容页跳转、新增、关闭标签都有实现。
已经可以用来做实际项目
源码地址: https://github.com/liningit/BlazorWebassemblyMultiPagesTabNoIframe
实现原理是新建一个类继承RouteView,在此类里面的Render方法中可以通过RouteData获取当前路由对应的对象.然后生成RenderFragment.
然后将其保存到List中,然后循环显示出来.对于未激活的通过display:none隐藏就可以了,这样哪怕切换标签状态也是保存的并不会刷新

    public class ReuseTabsRouteView : RouteView
    {
        [Inject]
        public TabSetTool TabSetTool { get; set; }

        [Inject]
        public NavigationManager Navmgr { get; set; }
         
        protected override void Render(RenderTreeBuilder builder)
        {
            var layoutType = RouteData.PageType.GetCustomAttribute<LayoutAttribute>()?.LayoutType ?? DefaultLayout;

            var body = CreateBody(RouteData, Navmgr.Uri);

            builder.OpenComponent<CascadingValue<ReuseTabsRouteView>>(0);
            builder.AddAttribute(1, "Name", "RouteView");
            builder.AddAttribute(2, "Value", this);

            builder.AddAttribute(3, "ChildContent", (RenderFragment)(b =>
            {
                b.OpenComponent(20, layoutType);
                b.AddAttribute(21, "Body", body);
                b.CloseComponent();
            }));

            builder.CloseComponent();
            var url = "/" + Navmgr.ToBaseRelativePath(Navmgr.Uri);
            if (url != "/#")
            {
                var selTab = TabSetTool.Pages.FirstOrDefault(m => m.Url == url && (m.Title == TabSetTool.Title || string.IsNullOrEmpty(m.Title)));
                if (selTab == null)
                {
                    TabSetTool.Pages.Add(new Tab
                    {
                        Body = body,
                        Url = url,
                        Title = TabSetTool.Title,
                        IsActive = true,
                    });
                }
                else
                {
                    selTab.Title = TabSetTool.Title;
                    selTab.Body = body;
                    selTab.IsActive = true;
                }
            }
        }

        private RenderFragment CreateBody(RouteData routeData, string url)
        {
            return builder =>
            {
                builder.OpenComponent(0, routeData.PageType);
                foreach (var routeValue in routeData.RouteValues)
                {
                    builder.AddAttribute(1, routeValue.Key, routeValue.Value);
                }
                builder.CloseComponent();
            };
        }


    }

App.razor中将RouteView改成ReuseTabsRouteView.

另外要注意TabSet中一定要有

[CascadingParameter(Name = "RouteView")]
public ReuseTabsRouteView RouteView { get; set; }

这两句,要不然页面会不更新

引用来源:https://www.cnblogs.com/liningit/p/15716595.html

版权声明:本文为YES开发框架网发布内容,转载请附上原文出处连接
管理员
上一篇:C# 时间戳与 标准时间互转
下一篇:.NET6中一些常用组件的配置及使用记录,持续更新中。。。
评论列表

发表评论

评论内容
昵称:
关联文章

Blazor Webassembly标签实现iframe实现
Blazor是春天还是寒风里挣扎
Blazor是春天还是寒风里挣扎
初识MASA Blazor
Devexpress GridControl明细标签控制,隐藏detail标签
使用.NET 6开发TodoList应用(13)——实现查询分
ManualResetEvent实现线程暂停与恢复
WPF 双向绑定到公开 set 方法属性在 NET 45 和 NET Core 行为不同
TinyMCE插件开发之《设置Code标签
在Winform框架文档界面中实现双击子窗口单独弹出或拖出及拽回处理
SourceGenerator应用: .Net进程开发库 - Juxtapose
详解ElasticAPM实现微服务链路追踪(NET)
[WPF] 实现 WPF Inner Shadow
vue vue-clie环境配置
C# 线程入门系列(三)
Devexpress XtraTabbedMdiManager添加右键关闭菜单 (关闭当前、关闭其它、所有关闭)
ios video标签部分mp4文件无法播放问题
同时个请求_axios并发请求
协议处理类实现
百亿级数据 分库分表 后怎么分查询?

联系我们
联系电话:15090125178(微信同号)
电子邮箱:garson_zhang@163.com
站长微信二维码
微信二维码