开源博客项目Blog .NET Core源码学习(26:App.Hosting项目结构分析-14)

  后台管理页面的系统管理下主要包括用户管理、角色管理、按钮管理和菜单管理,其中创建用户时要指定角色,创建角色时需指定菜单权限,按钮管理也是基于各菜单项进行设置,只有菜单管理相对独立,因此本文学习并分析App.Hosting项目中后台管理页面的菜单管理页面,后续再分析其它页面。
  菜单管理页面用于显示、新建、编辑、删除菜单数据,以便设置后台管理页面的一级菜单和二级菜单数据。菜单管理页面附带一新建及编辑页面,以支撑新建和编辑菜单数据。整个页面使用了layui中的树表(treetable,扩展组件,非最新layui中的树表组件)、表单、treeselect组件(扩展组件)等样式或模块,并未使用独立的js文件,而是直接在页面内嵌js代码,并调用SystemManage/ ModuleController的相关函数处理数据。

在这里插入图片描述
  菜单管理页面仅包含单个元素以树表形式显示全部菜单数据。

<table id="menuList" lay-filter="menuList"></table>

  内置的js代码主要用于设置树表样式及处理事件。调用treetable.render函数设置树表样式,主要包括:
  1)用elem属性设置树表容器元素,同时用url设置调用SystemManage/ModuleController的GetMenus函数获取所有菜单;
  2)用treeSpid、treeIdName、treePidName属性设置菜单树形父子关系;
  3)用toolbar属性设置头部工具栏,指定的元素id定义在_AminLayout.cshtml内,且根据不同的页面显示不同的工具栏内容,在本页面中工具栏中有添加按钮(按钮在系统管理->按钮管理中配置);
  4)用cols属性设置显示列,其中第一列采用type:‘number’设置为序号列,其它列对应GetMenus函数返回值的属性,菜单名称列(对应字段FullName)和菜单状态列(对应字段EnableMark)采用templet属性以模版函数方式设置列显示样式,最后一列用templet属性以模版选择器形式指定_AminLayout.cshtml文件中定义的按钮模版(按钮在系统管理->按钮管理中配置)。

在这里插入图片描述
  除上述设置之外,还定义了工具栏、操作按钮的响应函数,同时删除按钮的事件处理函数逻辑为调用SystemManage/ModuleController的Delete函数删除数据,然后重载页面数据。
  调用form.on('switch(enabled)'设置树表中菜单状态列开关事件的事件处理函数,其内部调用tools.submitConfrim函数提示用户是否在启用和禁用间切换,确定的话则调用SystemManage/ ModuleController的Enable函数更新菜单状态,同时更新页面数据,取消的话则还原菜单状态列之前的显示值。

在这里插入图片描述
  新建和编辑菜单数据使用的同一页面,位置为SystemManage\Views\Module\Form.cshtml页面,使用layui的表单组件、treeselect组件设置样式。如果是新建菜单数据,则直接弹出页面,而编辑数据的话,主页面会通过url传递key参数,在编辑页面中调用SystemManage/ModuleController的GetForm函数和GetMenuTree函数获取菜单详情数据初始化编辑页面的对应元素数据。页面Form.cshtml页面内嵌的js中定义initSelect函数调用SystemManage/ModuleController的GetMenuTree函数初始化treeselect组件的下拉值。新建或编辑完成后,主页面的js中设置了回调函数,最终调用SystemManage/ModuleController的Form函数新增或更新数据。

参考文献:
[1]https://gitee.com/miss_you/Blog
[2]https://layui.dev/docs/2/
[3]https://animate.style/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/840913.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

蓝桥杯【第15届省赛】Python B组 32.60 分

F 题列表越界访问了……省一但没什么好名次 测评链接&#xff1a;https://www.dotcpp.com/oj/train/1120/ C 语言网真是 ** 测评&#xff0c;时间限制和考试的不一样&#xff0c;E 题给我整时间超限&#xff1f; A&#xff1a;穿越时空之门 100&#x1f3c6; 【问题描述】 随…

使用梦畅闹钟,结合自定义bat、vbs脚本等实现定时功能

梦畅闹钟-每隔一段时间运行一次程序 休息五分钟bat脚本&#xff08;播放音乐视频&#xff0c;并锁屏&#xff09; chcp 65001 echo 回车开始休息5分钟 pause explorer "https://www.bilibili.com/video/BV1RT411S7Tk/?p47" timeout /t 3 /nobreak rundll32.exe use…

什么是SSL证书?如何选择SSL证书?

在浏览网站的时候&#xff0c;你会不会有这样一些疑问。 为什么有的网站是http://开头&#xff0c;有的却是https://&#xff1f;它们有什么区别吗&#xff1f; 经常访问的网站&#xff0c;浏览器突然提示“安全证书过期”&#xff0c;提醒你不要浏览该网址&#xff1f; 这一切…

什么是跨域?为什么会产生跨域?怎么解决跨域?

跨域&#xff0c;即跨域资源共享&#xff08;CORS&#xff0c;Cross-Origin Resource Sharing&#xff09;&#xff0c;是一个W3C标准&#xff0c;它定义了一种浏览器和服务器交互的方式来确定是否允许跨源请求。简单来说&#xff0c;跨域就是浏览器的同源策略导致来自不同源的…

Debug-010-git stash的用法及使用场景

问题原因&#xff1a; 其实也不是最近&#xff0c;就是之前就碰到过这个问题&#xff0c;那就是我正在新分支开发新功能&#xff0c;开发程度还没有到可以commit的程度&#xff0c;我不想提交(因为有些功能没有完全实现&#xff0c;而且没有自测的话很容易有问题&#xff0c;提…

ICML 2024 时空数据(Spatial-Temporal)论文总结

2024ICML&#xff08;International Conference on Machine Learning&#xff0c;国际机器学习会议&#xff09;在2024年7月21日-27日在奥地利维也纳举行 &#xff08;好像ICLR24现在正在维也纳开&#xff09;。 本文总结了ICML 24有关时空数据(Spatial-temporal) 的相关论文…

博客摘录「 Sql Server 收缩日志文件原理及always on 下的实践」2024年5月22日

四、Always on 环境下实践   先对数据库进行完整备份&#xff1a; EXEC sp_configure show advanced options, 1; RECONFIGURE; EXEC sp_configure xp_cmdshell, 1; RECONFIGURE; DECLARE DbName NVARCHAR(1000); DECLARE myCursor CURSOR LOCAL STATIC FOR S…

Golang并发编程-协程goroutine任务取消(Context)

文章目录 前言一、单个任务的取消二、 所有任务取消三、Context的出现Context的定义Context使用 总结 前言 在实际的业务种&#xff0c;我们可能会有这么一种场景&#xff1a;需要我们主动的通知某一个goroutine结束。比如我们开启一个后台goroutine一直做事情&#xff0c;比如…

【小程序八股文】系列之篇章二 | 小程序的核心机制

【小程序八股文】系列之篇章二 | 小程序的核心机制 前言三、微信小程序原理与运行机制简述一下微信小程序的原理微信小程序的双线程的理解为什么不采用浏览器多线程模式&#xff1f;为什么是双线程&#xff1f;&#xff08;出发点&#xff1a;安全&#xff0c;快速&#xff0c;…

前端面试题日常练-day33 【面试题】

题目 希望这些选择题能够帮助您进行前端面试的准备&#xff0c;答案在文末。 在jQuery中&#xff0c;以下哪个选项用于在元素上绑定一个点击事件&#xff1f; a) click() b) bind() c) on() d) trigger() jQuery中&#xff0c;以下哪个选项用于获取元素的属性值&#xff1f; …

Golang面试手册

Golang面试手册 薪资15~25k 岗位职责&#xff1a; 负责公司自有平台的研发工作包括系统功能模块开发&#xff1b;系统API接口开发等持续优化产品&#xff1b;关注技术细节&#xff0c;并能根据业务需求&#xff0c;提出技术和架构方案&#xff1b;担任重点项目的技术指导并负…

Flutter 中的 ElevatedButton 小部件:全面指南

Flutter 中的 ElevatedButton 小部件&#xff1a;全面指南 Flutter 提供了多种按钮小部件&#xff0c;每种都有其独特的用途和样式。ElevatedButton 是其中一种&#xff0c;它代表了具有凸起效果的按钮&#xff0c;通常用于 Material Design 风格的应用中。本文将为您提供一个…

在Linux环境下使用selenium执行web自动化

一、执行测试的必要组件 对于selenium的执行方式有很多&#xff0c;包括支持不同语言&#xff0c;实际使用时肯定选择自己熟悉的架构&#xff0c;比如我选择使用webdriver驱动的方式。 需要的组件包括&#xff1a;驱动firefox的工具geckodriver&#xff0c;加载到eclipse里的…

Express 的 req 和 res 对象

新建 learn-express文件夹&#xff0c;执行命令行 npm init -y npm install express 新建 index.js const express require(express); const app express();app.get(/, (req, res, next) > {res.json(return get) })app.post(/, (req, res, next) > {res.json(retur…

论文精读-SRFormer Permuted Self-Attention for Single Image Super-Resolution

论文精读-SRFormer: Permuted Self-Attention for Single Image Super-Resolution SRFormer:用于单图像超分辨率的排列自注意 Params&#xff1a;853K&#xff0c;MACs&#xff1a;236G 优点&#xff1a; 1、参考SwinIR的RSTB提出了新的网络块结构PAB&#xff08;排列自注意力…

sky walking日志采集以及注意事项

文章目录 1&#xff0c;sky walking日志采集功能概述2&#xff0c;采集log4j2日志3&#xff0c;采集logback日志4&#xff0c;效果展示5&#xff0c;注意事项 1&#xff0c;sky walking日志采集功能概述 在介绍Sky walking日志采集功能之前&#xff0c;最好在系统学习一遍日志…

【医学AI|顶刊精析|05-25】哈佛医学院·告别切片局限:3D病理如何革新癌症预后

小罗碎碎念 先打个预防针&#xff0c;我写这篇推文用了两个多小时&#xff0c;这就意味着要读懂这篇文章不太容易&#xff0c;我已经做好反复阅读的准备了。不过&#xff0c;风险之下&#xff0c;亦是机会&#xff0c;读懂的人少&#xff0c;这个赛道就越值得押宝。 在正式阅…

【C语言】8.C语言操作符详解(3)

文章目录 10.操作符的属性&#xff1a;优先级、结合性10.1 优先级10.2 结合性 11.表达式求值11.1 整型提升11.2 算术转换11.3 问题表达式解析11.3.1 表达式111.3.2 表达式211.3.3 表达式311.3.4 表达式411.3.5 表达式5: 11.4 总结 10.操作符的属性&#xff1a;优先级、结合性 …

基于Keras的手写数字识别(附源码)

目录 引言 为什么要创建虚拟环境&#xff0c;好处在哪里&#xff1f; 源码 我修改的部分 调用本地数据 修改第二层卷积层 引言 本文是博主为了记录一个好的开源代码而写&#xff0c;下面是代码出处&#xff01;强烈建议收藏&#xff01;【深度学习实战—1】&#xff1a…

Keras深度学习框架基础第二讲:层接口(layers API)第二部分“基本层类”

1、layer 类 典型的layer类如下 keras.layers.Layer(activity_regularizerNone,trainableTrue,dtypeNone,autocastTrue,nameNone,**kwargs )这是一个所有层都继承的基类。 一个层是一个可调用的对象&#xff0c;它接受一个或多个张量作为输入&#xff0c;并输出一个或多个张…