C# + .NET5 Web入门实战:私人笔记(3)集成Ant Design UI框架
myzbx 2024-12-15 15:35 15 浏览
上一节我们创建了一个基于Blazor的Web应用,并且通过修改页面上某一处的文字大概了解了各个程序文件的作用。
这一节我们开始往里面增加内容,首先要加的就是分类树控件。上节提到过,分类树控件需要用到Ant Design的UI框架,所以我们得先要做Ant Design环境的集成。
Ant Design环境集成
我的参考资料来自Ant Design官网(注1),鼓励有一定基础和学习能力的自行参考。对于初学者,Ant Design官方则给出了这样建议:
假设你已了解关于 HTML、CSS 和 JavaScript 的初级知识,并且已经完全掌握了 Blazor 的正确开发方式。如果你刚开始学习.NET 或者 Blazor,将 UI 框架作为你的第一步可能不是最好的主意。
我的教程目标就是针对初学者,所以如果你能够认真阅读完本节教程,我相信你可以。
环境要求
强烈建议用VS2019,如果是其他版本的VS,我也不确定是否会有这样那样的问题。
集成步骤
1、切换到程序包管理器控制台
首次使用要稍微等待一下,出现PM> 字样,就可以了。
2、安装程序包
首先键入:cd Diary.Web.Blazor.WASM,然后按回车。即进入当前项目目录。成功后不会有提示,再出一行PM>就是成功了。
然后键入:dotnet add package AntDesign,按回车。你会看到一堆的内容,只要没有暗红色的字体出现,就是正确的。同样再出一行PM>就是成功了。
这样就是安装成功了。
我们到解决方案视图的依赖项,看到包下有AntDesign,再次确认成功。
3、引入样式
在wwwroot/index.html中添加
?<link href="_content/AntDesign/css/ant-design-blazor.css" rel="stylesheet" />
?<script src="_content/AntDesign/js/ant-design-blazor.js"></script>
这两行语句,如下图:
如果按照官网的参考,这样,Anti Design的UI框架就算安装好了。但实际上还差两步,没有以下的步骤是没办法使用的,我继续补充。
4、引入命名空间
在_Imports.razor中增加@using AntDesign;的命名空间引用。
5、添加AntDesign服务
在Program.cs添加builder.Services.AddAntDesign();用来启动AntDesign服务。注意代码行的位置。
以上,就是集成Ant Design的全部操作,按F5如果能正常打开网站显示页面,就说明配置成功了。
接下来我们需要检验一下。
环境检验
在Index.razor下增加一个按钮
然后运行一下,我们看到这样风格的按钮,测试通过了。
以上都是准备工作。下一步我们要开始做私人笔记中的功能:界面的整体布局。
界面的整体布局
所谓的布局,最大的影响因素就是用户的操作习惯,这点Web程序与传统的WinForm程序是不同的。WinForm的用户操作习惯是顶部有菜单栏,所以功能入口都可以在菜单上堆。但是Web网站带顶部菜单的则不多见,一般都是我们看到的都是这种左侧导航,右侧内容的形式。
所以我们也需要遵从一般Web程序的用户使用习惯,把WinForm中的菜单转到左侧导航。鉴于我们这个小项目的功能比较简单,就仍然用它已经有的三个导航菜单,依次为:内容管理、系统设置、关于。当然我这里只是做教程演示,具体项目大家可以扩充。
以上导航文字在NavMenu.razor文件中修改文字即可,如下图:
内容管理页对应的就是Index.razor页面,然后我们再把Index.razor中不相关的内容都删掉。运行效果如下:
现在准备工作我们都做好了,那如何来添加分类树呢?首先我们需要参考Ant Design关于树对应的文档,通过文档可以得知,树用Tree来表示。
然后在Index.razor页面,把Ant Design官网的测试数据复制上去:
运行后的效果:
现在,树控件的内容我们可以展现出来了。只是这个数据是通过Html静态指定的,那要如何通过程序动态来添加呢?我们下一节继续。
注1:头条不允许外链,Ant Design官网的位置我一并更新到了私信回复,请通过下方私信方式获取链接。
------------------------------------
本教程项目源码已作为开源项目加入到Gitee,代码内容会随教程实时更新,大家有兴趣的话可以关注我,以获得最及时的更新。私信:
私人笔记 可以获取相关链接;
大家阅读过程中有哪些看不懂或未尽兴的地方,可以在评论区留言,我会先记下来在后续的教程中找机会再说。
教程有帮助的话请大家帮忙关注、转发、扩散,能不能开专栏还需要你们的支持!
相关推荐
- Django零基础速成指南:快速打造带用户系统的博客平台
-
#python##服务器##API##编程##学习#不是所有教程都值得你花时间!这篇实战指南将用5分钟带你解锁Django核心技能,手把手教你从零搭建一个具备用户注册登录、文章管理功能的完整...
- iOS 17.0 Bootstrap 1.2.9 半越狱来啦!更新两点
-
这款Bootstrap半越狱工具终于更新,离上一次更新已相隔很久,现在推出1.2.9版本,主要为内置两点功能进行更新,也是提升半越狱的稳定性。如果你正在使用这款半越狱工具的,建议你更新。注意!...
- iOS 16.x Bootstrap 1.2.3 发布,支持运行清理工具
-
本文主要讲Bootstrap半越狱工具更新相关内容。如果你是iOS16.0至16.6.1和17.0系统的,想体验半越狱的果粉,请继续往下看。--知识点科普--Bootstrap...
- SpringBoot整合工作流引擎Acticiti系统,适用于ERP、OA系统
-
今日推荐:SpringBoot整合工作流引擎Acticiti的源码推荐理由:1、SpringBoot整合工作流引擎Acticiti系统2、实现了三级权限结构3、持久层使用了mybatis框架4、流程包...
- SpringCloud自定义Bootstrap配置指南
-
在SpringCloud中自定义Bootstrap配置需要以下步骤,以确保在应用启动的早期阶段加载自定义配置:1.添加依赖(针对新版本SpringCloud)从SpringCloud2020...
- Python使用Dash开发网页应用(三)(python网页开发教程)
-
PlotlyDash开发Web应用示例一个好的网页设计通常都需要编写css甚至js来定制前端内容,例如非常流行的bootstrap框架。我们既然想使用Dash来搭建web应用,很大的一个原因是不熟悉...
- Oxygen XML Editor 27.1 中的新功能
-
OxygenXMLEditor27.1版是面向内容作者、开发者、合作者和出版商的行业领先工具包的增量版本。在27.1版本中,AIPositronAssistant得到了增强,包括用于...
- 【LLM-多模态】Mini-Gemini:挖掘多模态视觉语言模型的潜力
-
一、结论写在前面论文提出了Mini-Gemini,一个精简而强大的多模态VLM框架。Mini-Gemini的本质在于通过战略性框架设计、丰富的数据质量和扩展的功能范围,发掘VLM的潜在能力。其核心是补...
- 谐云课堂 | 一文详解分布式改造理论与实战
-
01微服务与分布式什么是分布式?首先,我们对上图提到的部分关键词进行讲解。单体,是指一个进程完成全部的后端处理;水平拆分,是同一个后端多环境部署,他们都处理相同的内容,使用反向代理来均衡负载,这种也叫...
- 基于Abaqus的手动挡换挡机构可靠性仿真
-
手动挡,也称手动变速器,英文全称为Manualtransmission,简称MT,即用手拨动换挡操纵总成才能改变变速器内的齿轮啮合位置,改变传动比,从而达到变速的目的。家用轿车主要采用软轴连接的换挡...
- 【pytorch】目标检测:彻底搞懂YOLOv5详解
-
YOLOv5是GlennJocher等人研发,它是Ultralytics公司的开源项目。YOLOv5根据参数量分为了n、s、m、l、x五种类型,其参数量依次上升,当然了其效果也是越来越好。从2020...
- 超实用!50个非常实用的PS快捷键命令大全分享
-
今天,给大家介绍50个非常实用的快捷键命令大全,大家伙都是设计师,关于软件使用那是越快越好啊。一、常用的热键组合1、图层混合模式快捷键:正常(Shift+Option+N),正片叠底(Shif...
- Pohtoshop中深藏不露的小技巧(科目一考试技巧记忆口诀看完必过)
-
邢帅教育ps教程为大家总结了一些Pohtoshop中深藏不露的小技巧,可以帮助到大家在设计时减少不必要的麻烦,提高工作效率哦~~~1.设置网格线保持像素完美不在1:1分辨率下也能保持像素完美,可以...
- Ganglia监控安装总结(监控安装工作总结)
-
一、ganglia简介:Ganglia是一个跨平台可扩展的,高性能计算系统下的分布式监控系统,如集群和网格。它是基于分层设计,它使用广泛的技术,如XML数据代表,便携数据传输,RRDtool用于数据...
- 谁说Adobe XD做不出好看的设计?那是你没搞懂这些功能
-
AdobeXD的美化栏具有将设计视图美化的功能,它能使界面设计和原型设计更漂亮、更吸引眼球。美化栏的7个功能包括竖线布局设计、横线布局设计、重复网格、图形大小和位置设置、响应式调整大小、文字美化以及...
- 一周热门
- 最近发表
-
- Django零基础速成指南:快速打造带用户系统的博客平台
- iOS 17.0 Bootstrap 1.2.9 半越狱来啦!更新两点
- iOS 16.x Bootstrap 1.2.3 发布,支持运行清理工具
- SpringBoot整合工作流引擎Acticiti系统,适用于ERP、OA系统
- SpringCloud自定义Bootstrap配置指南
- Python使用Dash开发网页应用(三)(python网页开发教程)
- Oxygen XML Editor 27.1 中的新功能
- 【LLM-多模态】Mini-Gemini:挖掘多模态视觉语言模型的潜力
- 谐云课堂 | 一文详解分布式改造理论与实战
- 基于Abaqus的手动挡换挡机构可靠性仿真
- 标签列表
-
- HTML 基础教程 (29)
- HTML 简介 (30)
- HTML 响应式设计 (31)
- HTML URL 编码 (32)
- HTML Web 服务器 (31)
- HTML 表单属性 (32)
- HTML 音频 (31)
- HTML5 支持 (33)
- HTML API (36)
- HTML 总结 (32)
- HTML 全局属性 (32)
- HTML 事件 (31)
- HTML 画布 (32)
- HTTP 方法 (30)
- 键盘快捷键 (30)
- CSS 语法 (35)
- CSS 选择器 (30)
- CSS 轮廓 (30)
- CSS 轮廓宽度 (31)
- CSS 谷歌字体 (33)
- CSS 链接 (31)
- CSS 中级教程 (30)
- CSS 定位 (31)
- CSS 图片库 (32)
- CSS 图像精灵 (31)