工作记录

-------------------------------------------------------------------------------------------------------

MarkupExtension:XAML标记扩展

实现了什么作用:通过扩展标记将一种输入转化为另一种类型的输出

思路:

不直接设置控件的Visibility属性,利用一个标记扩展,传入一个权限值,然后拿这个权限值跟当前程序的用户权限对比,如果控件的权限值高于当前用户权限(比如控件的权限值是管理员,但是当前用户是普通用户),则返回Visibility.Collapsed,反之返回Visibility.Visible。

代码:

[MarkupExtensionReturnType(typeof(Visibility))]
public class PermissionVisibleExtension : MarkupExtension, IPermissionListener
{private FrameworkElement targetObject;private DependencyProperty targetProperty;[ConstructorArgument("authority")]public Authority Authority { get; set; }public PermissionVisibleExtension(){}public PermissionVisibleExtension(Authority authority){Authority = authority;}public override object ProvideValue(IServiceProvider serviceProvider){try{var providerValuetarget = (IProvideValueTarget)serviceProvider.GetService(typeof(IProvideValueTarget));//控件对象targetObject = (FrameworkElement)providerValuetarget.TargetObject;//元素布局事件targetObject.Loaded += TargetObject_Loaded;//元素删除事件targetObject.Unloaded += TargetObject_Unloaded;//标记的控件属性targetProperty = (DependencyProperty)providerValuetarget.TargetProperty;PermissionService.AddListener(this);return PermissionService.Authority >= Authority ? Visibility.Visible : Visibility.Collapsed;}catch (Exception){return Visibility.Collapsed;}}private void TargetObject_Loaded(object sender, RoutedEventArgs e){PermissionService.AddListener(this);PermissionChanged(PermissionService.Authority);}private void TargetObject_Unloaded(object sender, RoutedEventArgs e){PermissionService.RemoveListener(this);}public void PermissionChanged(Authority authority){targetObject.SetCurrentValue(targetProperty, PermissionService.Authority >= Authority ? Visibility.Visible : Visibility.Collapsed);}
}

其中IPermissionListener是提供了权限变更处理方法的接口:

public interface IPermissionListener
{void PermissionChanged(Authority authority);
}

PermissionService是程序的权限管理类,保存着相关控件的扩展标记,提供了挂载方法:

private static readonly List<IPermissionListener> listeners = new List<IPermissionListener>();
public static void AddListener(IPermissionListener listener)
{if (!listeners.Contains(listener)){listeners.Add(listener);}
}public static void RemoveListener(IPermissionListener listener)
{if (listeners.Contains(listener)){listeners.Remove(listener);}
}

当PermissionService类中的用户权限改变时,会遍历listeners 中的扩展,触发PermissionChanged方法:

 private static void OnPermissionChanged(){foreach (var it in listeners){//authority是当前类中的属性,表示用户权限it.PermissionChanged(authority);}}

每个扩展中的PermissionChanged方法:

public void PermissionChanged(Authority authority)
{targetObject.SetCurrentValue(targetProperty, PermissionService.Authority >= Authority ? Visibility.Visible : Visibility.Collapsed);
}

通过控件直接设置属性值实现改变控件可见状态;

前端写法:

 Visibility="{view:PermissionVisible Authority=Expert}">

引用:笔记:WPF中MarkupExtension使用的IServiceProvider参数都有哪些_wpf iserviceprovider-CSDN博客

WPF基础之Binding解析_calcbinding-CSDN博客

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

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

相关文章

SpringMVC相关梳理

SpringMVC 返回值类型&#xff08;一&#xff09;核心返回值类型分类视图渲染类&#xff1a;用于跳转并渲染页面&#xff0c;如String&#xff08;指定视图名&#xff09;、ModelAndView&#xff08;视图 数据&#xff09;。数据返回类&#xff1a;用于返回数据&#xff08;而…

Docker化性能监控平台搭建:JMeter+InfluxDB+Grafana全攻略

你作为一名DevOps工程师或测试专家&#xff0c;正在监控一个高并发微服务系统&#xff1a;突发流量峰值导致响应延迟&#xff0c;服务器CPU飙升&#xff0c;但你只能手动查看日志&#xff0c;优化起来像大海捞针。这时&#xff0c;DockerJMeterInfluxDBGrafana的“梦幻四重奏”…

Adobe Acrobat 中通过 JavaScript 调用 Web 服务

强大的JavaScript支持&#xff0c;允许用户通过脚本自动化处理PDF文档。本文将详细介绍如何在Adobe Acrobat环境中使用JavaScript调用Web服务&#xff0c;包括基础概念、实现方法、代码示例以及常见问题解决方案。 第一部分&#xff1a;基础概念与技术背景 1.1 Acrobat JavaScr…

SpringCloud OpenFeign 远程调用(RPC)(三)

目录 1 概念导入 2 添加依赖 3 在启动类上添加注解 4 编写对应的接口 5 注入并调用 6 日志 7 超时控制 8 超时重试 9 拦截器 10 Fallback兜底 1 概念导入 Spring Cloud OpenFeign Features :: Spring Cloud Openfeign 2 添加依赖 <!-- 远程调用 --><depen…

【Flask】测试平台开发,登陆重构

概述我们在开篇的时候实现了简单的登陆功能&#xff0c;也实现了一个前后端联调的登陆功能&#xff0c;但是你有没有发现&#xff0c;那个登陆只是一个简单的登陆&#xff0c;且密码在接口返回的过程中是铭文密码&#xff0c;在生产环境中使用肯定是不行的&#xff0c;一般密码…

【Bluedroid】A2DP Source设备音频数据读取机制分析(btif_a2dp_source_read_callback)

本文聚焦Android 蓝牙 A2DP Source设备的音频数据读取核心逻辑,深入解析关键回调函数btif_a2dp_source_read_callback的功能实现,包括从 HAL(硬件抽象层,支持 HIDL/AIDL 两种传输方式)或 UIPC(用户空间进程间通信)获取音频数据的路径选择机制,以及数据下溢(Underflow)…

多方调研赋能AI+智慧消防 豪越科技人工智能创新获认可

8月26日&#xff0c;中国职业安全健康协会城市及社区安全发展专业委员会秘书长汪卫国以及常务副秘书长黄强亮等诸位领导到访委员单位豪越科技&#xff0c;展开了实地的调研活动并给予相关指导。此次调研着重于了解豪越科技自主研发的“AI消防救援一体化安全管控平台”&#xff…

算法---字符串

一、算法说明 字符串是一种类型&#xff0c;他不是一种算法&#xff0c;所以我们在处理这方面的问题的时候&#xff0c;需要结合其他的算法 二、题目 最长公共前缀 1、题目 最长公共前缀 2、解题思路 解法一&#xff1a;我们可以先让两个相互比较&#xff0c;然后在将比较…

鸿蒙Next导航与路由指南:组件导航与页面路由的完美协作

一次搞懂HarmonyOS NEXT中的两种导航方式&#xff0c;打造流畅的应用内跳转体验在鸿蒙应用开发中&#xff0c;流畅的页面导航和路由是提升用户体验的关键。HarmonyOS NEXT提供了组件导航&#xff08;Navigation&#xff09; 和页面路由&#xff08;ohos.router&#xff09; 两种…

JavaScript原型详解——面试重点

一、原型的含义&#xff1a;JavaScript 中的“原型”既指 函数身上的 prototype 对象&#xff0c;也指 对象身上的 [[Prototype]] 隐藏链接&#xff1b;它俩共同构成了“原型链”&#xff0c;决定了“找不到属性时去哪里继续找”的规则。&#xff08;1&#xff09;原型对象(pro…

Vue3 全面介绍

Vue3&#xff08;正式名称为 Vue.js 3&#xff09;是 Vue.js 前端框架的第三个主要版本&#xff0c;于 2020 年 9 月正式发布。作为对 Vue2 的重大升级&#xff0c;Vue3 在核心架构、性能优化、开发体验等方面进行了全面重构&#xff0c;同时保持了 Vue 一贯的“渐进式框架”理…

HTTP 范围请求:为什么你的下载可以“断点续传”?

在现代网络应用中&#xff0c;我们习以为常的功能&#xff0c;如断点续传、多线程下载和在线视频快进快退&#xff0c;都依赖于 HTTP 协议中的一个强大特性&#xff1a;范围请求&#xff08;Range Requests&#xff09;。这项技术让客户端能够聪明地只请求文件的一部分&#xf…

万博智云联合华为云共建高度自动化的云容灾基线解决方案

一、摘要 近日&#xff0c;万博智云与华为云的深入合作再添新章——万博智云HyperBDR云容灾解决方案&#xff0c;顺利通过华为云专家团队评审和认证&#xff0c;正式被选为华为云基线解决方案&#xff08;Baseline Solution&#xff09;&#xff0c;并在华为云国际站上线。 Hy…

机器视觉opencv教程(二):二值化、自适应二值化

文章目录机器视觉opencv教程&#xff08;二&#xff09;&#xff1a;二值化、自适应二值化一、二值化图基础概念二、传统二值化方法&#xff08;基于全局固定阈值&#xff09;1. 阈值法&#xff08;THRESH_BINARY&#xff09;2. 反阈值法&#xff08;THRESH_BINARY_INV&#xf…

leetcode 461 汉明距离

一、问题描述二、解题思路采用位运算的思想来解决这个问题&#xff0c;首先&#xff0c;将x和y进行异或&#xff0c;x和y对应二进制位不同就会得到1&#xff0c;然后统计所有1的个数&#xff0c;即为汉明距离。三、代码实现时间复杂度&#xff1a;T(n)O(n)空间复杂度&#xff1…

ClickHouse 客户端

ClickHouse 客户端 ClickHouse提供两种客户端接口&#xff0c;分别基于 HTTP 和 TCP 协议 基于 HTTP 协议 主要用来支持轻量级的简单操作&#xff0c;方便跨平台和编程语言。 测试clickhouse联通性&#xff1a; $ curl http://localhost:8123/ Ok.在运行状况检查脚本中使用…

DBeaver 连接 PostgreSQL 教程

&#x1f6e0;️ DBeaver 连接 PostgreSQL 教程1️⃣ 安装 DBeaver打开官网&#xff1a;https://dbeaver.io/download/下载 Community Edition&#xff08;免费版&#xff09;&#xff0c;选择对应系统&#xff08;Windows / macOS / Linux&#xff09;。安装完成后&#xff0c…

Komo Searc-AI驱动的搜索引擎

本文转载自&#xff1a;Komo Searc-AI驱动的搜索引擎 - Hello123工具导航 ** 一、&#x1f50d; Komo Search 是什么&#xff1f; Komo Search 是一款基于人工智能技术的新一代交互式搜索引擎&#xff0c;它彻底改变了我们获取信息的方式 —— 从被动检索变成主动对话。不同于…

HTML 和 JavaScript 关联的基础教程

HTML 和 JavaScript 是构建现代网页的核心技术。HTML 负责页面结构&#xff0c;JavaScript 负责动态交互。以下是两者的基本关联方式。内联方式&#xff1a;直接在 HTML 中嵌入 JavaScript在 HTML 文件中&#xff0c;可以通过 <script> 标签直接编写 JavaScript 代码。这…

淘宝四个月造了一个超越美团的“美团”

本周三&#xff0c;美团发布最新一季财报&#xff0c;利润承压导致股价爆跌。只隔一天&#xff0c;阿里也发布了最新季报&#xff0c;最大的亮点是“淘宝闪购”即时零售业务&#xff0c;日均订单量站稳8000万单&#xff0c;峰值订单更是达到了1.2亿单。8000万单这个数字令市场眼…