没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:龚雪|2022-11-30 11:06:32.290|阅读 185 次
概述:本文将为大家介绍如何使用DevExpress WinForm组件实现基于HTML&CSS的桌面UI,欢迎下载最新版体验~
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
相关链接:
DevExpress WinForm拥有180+组件和UI库,能为Windows Forms平台创建具有影响力的业务解决方案。DevExpress WinForm能完美构建流畅、美观且易于使用的应用程序,无论是Office风格的界面,还是分析处理大批量的业务数据,它都能轻松胜任!
注意:目前基于HTML & CSS的控件正在积极研发中,可以作为技术预览提供,如果需要使用请下载最新版组件体验哦~
一组控件和组件允许开发人员构建HTML格式的UI,并使用CSS样式自定义UI元素的外观设置、大小、填充和布局选项,不再需要处理自定义绘制事件或更改大量属性来修改控件以匹配UI规范,可以使用HTML和CSS标记的知识为桌面应用程序构建布局。
在上文中(点击这里回顾>>),我们为大家介绍了HTML-CSS标记的一些基础概念,本文将继续为大家介绍如何动态指定HTML-CSS模板、动态自定义项目等,欢迎持续关注这个系列的文章哦~
许多控件使用HTML-CSS模板来呈现它们的项,例如ItemsView从ItemsView.HtmlTemplate 属性指定的默认模板中生成它的所有项(记录)。
这些控件具有将模板分配给项的事件,从而动态覆盖默认模板:
示例
下面的ItemsView.QueryItemTemplate事件处理程序根据项的类型(IsOwnMessage设置)为不同的项分配不同的模板。
C#
void OnQueryItemTemplate(object sender, QueryItemTemplateEventArgs e) { var message = e.Row as DevAV.Chat.Model.Message; if(message == null) return; if(message.IsOwnMessage) Styles.MyMessage.Apply(e.Template); else Styles.Message.Apply(e.Template); //... }
VB.NET
Private Sub OnQueryItemTemplate(ByVal sender As Object, ByVal e As QueryItemTemplateEventArgs) Dim message = TryCast(e.Row, DevAV.Chat.Model.Message) If message Is Nothing Then Return If message.IsOwnMessage Then Styles.MyMessage.Apply(e.Template) Else Styles.Message.Apply(e.Template) End If '... End Sub
从模板生成项的控件也有事件来动态自定义每个项:
在控件中的每个项显示在屏幕上之前触发这些事件,它们允许开发人员访问将要呈现的单个HTML元素,并自定义它们的可见性和样式设置。
示例
下面的示例根据自定义逻辑更改HTML元素的可见性。
开发人员可以在下面的演示中找到这个示例的完整代码:Chat Client。
C#
//CustomizeItem event handler: void OnCustomizeItem(object sender, CustomizeItemArgs e) { //... if(message.IsLiked) { var btnLike = e.Element.FindElementById("btnLike"); var btnMore = e.Element.FindElementById("btnMore"); if(btnLike != null && btnMore != null) { btnLike.Hidden = false; btnMore.Hidden = true; } } if(message.IsFirstMessageOfBlock) return; if(!message.IsOwnMessage) { var avatar = e.Element.FindElementById("avatar"); if(avatar != null) //Display an empty region instead of the 'avatar' element. avatar.Style.SetVisibility(Utils.Html.Internal.CssVisibility.Hidden); } //... }
VB.NET
Private Sub OnCustomizeItem(ByVal sender As Object, ByVal e As CustomizeItemArgs) Dim message = TryCast(e.Row, DevAV.Chat.Model.Message) If message Is Nothing Then Return If message.IsLiked Then Dim btnLike = e.Element.FindElementById("btnLike") Dim btnMore = e.Element.FindElementById("btnMore") If btnLike IsNot Nothing AndAlso btnMore IsNot Nothing Then btnLike.Hidden = False btnMore.Hidden = True End If End If If message.IsFirstMessageOfBlock Then Return If Not message.IsOwnMessage Then Dim avatar = e.Element.FindElementById("avatar") 'Display an empty region instead of the 'avatar' element. If avatar IsNot Nothing Then avatar.Style.SetVisibility(Utils.Html.Internal.CssVisibility.Hidden) End If '... End Sub
如果控件绑定到数据源,可以在HTML标记中使用以下语法来显示数据源字段的值:
${FieldName}
' $ '字符指定后面的文本是控件需要求值的表达式,表达式可以包含静态文本和绑定到多个字段的数据:
例如,下面的HTML代码显示了来自控件数据源的“UserName”字段的值:
HTML
<div class='contactName'>${UserName}</div>
下面的示例在用户名之前添加' Welcome '字符串:
HTML
<h1>$Welcome {UserName}!</h1>
DevExpress技术交流群6:600715373 欢迎一起进群讨论
更多DevExpress线上公开课、中文教程资讯请上中文网获取
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com
文章转载自:慧都网PDF 的页面大小决定了其内容的显示、打印或处理方式。在准备打印、转换格式或标准化布局时,我们通常需要更改PDF文档的纸张大小。在本教程中,您将学习如何使用 Java 编辑任何 PDF 文件的页面大小。我们将通过完整的代码示例,逐步指导您完成操作。
本文主要介绍如何使用DevExpress WPF Grid控件中的节点(Nodes)概述,欢迎下载最新版组件体验!
本教程提供DevExpress WinFormsWinExplorer视图的基本信息,欢迎下载最新版组件体验!
无论是用于 Web 开发、图形设计还是数据可视化,调整SVG图像大小的能力都至关重要。Aspose.Imaging for Java库允许开发人员构建 SVG 图像调整器并轻松执行其他图像处理,为各行各业提供了灵活、易于集成的图像处理解决方案。
优秀的界面控件开发包,帮助企业构建卓越应用!
DevExpress DXperience Subscription高性价比的企业级.NET用户界面套包,助力企业创建卓越应用!
DevExpress WinForms Subscription为Windows Forms平台创建具有影响力的业务解决方案,高性价比WinForms界面控件套包。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@evget.com
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
慧都科技 版权所有 Copyright 2003-
2025 渝ICP备12000582号-13 渝公网安备
50010702500608号