首页 > 其他分享 >「DevExpress中文教程」如何将DevExtreme JS HTML编辑器集成到WinForms应用

「DevExpress中文教程」如何将DevExtreme JS HTML编辑器集成到WinForms应用

时间:2024-03-28 09:44:55浏览次数:17  
标签:HTML DevExpress await 应用程序 JS 编辑器 WinForms Undo

在本文中我们将演示一个混合实现:如何将web UI工具集成到WinForms桌面应用程序中。具体来说,我们将把DevExtreme JavaScript WYSIWYG HTML编辑器(作为DevExtreme UI组件套件的一部分发布的组件)集成到Windows Forms应用程序中。

DevExpress中文教程图集

获取DevExtreme v23.2正式版下载

DevExpress技术交流群9:909157416      欢迎一起进群讨论

在开始之前,首先为大家列出一些可能会遇到的问题:

  • DevExtreme HTML编辑器不支持所有与HTML相关的功能和标签(阅读限制)。
  • 为了无缝地将Web HTML编辑器集成到桌面UI中,您可能需要隐藏其工具栏和对话框(而不是在WinForms应用程序中实现它们)。
  • 您需要管理皮肤/主题的变化,以确保在WinForms和Web UI控件之间有一个一致的外观和感觉,减少应用程序本身视觉不一致的风险。

注意:在WinForms桌面应用程序中使用DevExpress JavaScript HTML编辑器需要一个有效的DevExtreme授权

入门指南

官方已经创建了一个示例WinForms应用程序,它集成了基于web的HTML编辑器组件。

要开始,您必须:

1. 从GitHub下载我们的示例WinForms应用程序

2. 在Visual Studio IDE中打开解决方案。

3. 使用 Project Converter (项目转换器)工具更新基于您当前版本的DevExpress引用。

4. 构建解决方案并运行应用程序。

实现细节

我们将客户端HTML编辑器封装到Microsoft Edge WebView2控件(dxhtmlleditorwebview)中,WebView2是一个可嵌入的浏览器控件,它允许您在为WinForms和WPF构建桌面应用程序时使用web技术,如HTML、CSS和JavaScript。

HTML编辑器功能
  • 导出到HTML和Markdown
  • 内联格式和块格式
  • 复制/粘贴富文本格式
  • 插入媒体和上传图像
  • 表格
  • 邮件合并
  • 用户界面定制
  • Light/Dark主题

我们的示例还实现了以下内容:

  • 自动同步WinForms应用程序皮肤与HTML编辑器的主题。
    当从深色调色板切换到浅色调色板(反之亦然)时,相应的主题(深色或浅色)将应用于HTML Editor。
DevExpress中文教程图集
  • 撤消/重做功能区命令。
    用户可以在HTML编辑器中撤销/重做操作。
DevExpress中文教程图集
公共API和事件

我们在DXHtmlEditorWebView类中实现了以下公共方法和事件:

  • GetHtmlText() – 以HTML格式导出HTML编辑器的内容。
  • SetHtmlText(string htmlString) – 设置HTML编辑器的内容,传递给SetHtmlText方法的HTML字符串应该是格式良好的HTML标记,此方法将HTML编辑器中的任何现有内容替换为新的HTML内容。
  • SetTheme(string themeName) – 将指定的主题应用于HTML编辑器。
  • Undo() –恢复在HTML编辑器中执行的最新操作或一系列操作。
  • Redo() – 重新应用以前未完成的操作。
  • HtmlChanged
  • HtmlLoaded
在WinForms应用程序中使用HTML编辑器

1. 将DXHtmlEditor复制到您的项目中。

2. 安装Microsoft.Web.WebView2 NuGet包。

3. 打开DXHtmlEditorClient.cs文件然后在OnWebResourceRequested方法中指定默认命名空间:

void OnWebResourceRequested(object sender, CoreWebView2WebResourceRequestedEventArgs e) {
var environment = webView?.Environment;
if(environment == null)
return;
string asset = $@"{nameof(MyDefaultNamespace)}.{nameof(DXHtmlEditor)}.Assets.{e.Request.Uri.Substring(rootURIFilter.Length - 1)}";
// ...
}

4. 对Assets文件夹中的所有文件设置Build Action为“Embedded Resource”。

5. 构建解决方案。

6. 将DXHtmlEditorWebView组件从工具箱中拖放到表单中。

扩展嵌入式HTML编辑器的功能

要将HTML编辑器与“本地”用户界面集成,您应该隐藏它的工具栏/对话框(在../Assets/index.js中),并在WinForms UI中实现相应的UI元素。在我们的例子中,隐藏了HTML编辑器的撤销/重做工具栏命令,并在Ribbon UI中添加了相应的命令。

实现包括以下内容:

1. 在index.js中,我们添加了undo 和 redo函数:

function undo() {
htmlEditor.undo();
}
function redo() {
htmlEditor.redo();
}

2. 在DXHtmlEditorClient.cs中,我们添加了Undo 和 Redo方法:

public async Task Undo() {
await CallDxHtmlEditClient("undo()");
}
public async Task Redo() {
await CallDxHtmlEditClient("redo()");
}

3. 在DXHtmlWebView.cs中,我们添加了Undo 和 Redo方法:

public async Task Undo() {
await EnsureIsLoaded();
await client.Undo();
}
public async Task Redo() {
await EnsureIsLoaded();
await client.Redo();
}

4. 我们添加了Undo 和 Redo项目到Ribbon中,并处理了它们的ItemClick事件:

async void OnUndo(object sender, DevExpress.XtraBars.ItemClickEventArgs e) {
await dxHtmlEditorWebView.Undo();
}
async void OnRedo(object sender, DevExpress.XtraBars.ItemClickEventArgs e) {
await dxHtmlEditorWebView.Redo();
}
总结

这种混合方法的主要好处是能够在.NET桌面应用程序中利用web技术的优势,独家和成熟的web组件(如DevExtreme HTML编辑器)经过了广泛的测试和改进。这些UI组件通常包含广泛的特性集,可以处理各种使用场景。

 

标签:HTML,DevExpress,await,应用程序,JS,编辑器,WinForms,Undo
From: https://www.cnblogs.com/AABBbaby/p/18100807

相关文章

  • js的事件
    JS的事件介绍JS(JavaScript)是基于对象(Object-based)、事件驱动的脚本语言。JS事件,就是用户或浏览器本身的某种行为,一般是用户对页面的一些动作引起的,例如,单击某个链接或按钮、在文本框中输入文本、按下键盘上的某个按键、移动鼠标等等。当事件发生时,您可以使用JavaScript中的......
  • python 调用 js
    安装pyexecjspipinstallPyExecJS2使用importosimportexecjsimportexecjs.runtime_namescurrent_dir=os.path.dirname(__file__)js_abs_path=os.path.join(current_dir,"js\\index.js")'''js内容functionadd(a,b){returna+......
  • devexpress schedulerControl Gantt View 使用
    usingSystem;usingSystem.Collections.Generic;usingSystem.ComponentModel;usingSystem.Data;usingSystem.Drawing;usingSystem.Text;usingSystem.Linq;usingSystem.Windows.Forms;usingDevExpress.XtraEditors;usingF.Studio.DevExpressUI;usingDevExp......
  • 【漏洞复现】万户 ezOFFICE wf_printnum.jsp SQL注入漏洞
    0x01产品简介万户OAezoffice是万户网络协同办公产品多年来一直将主要精力致力于中高端市场的一款OA协同办公软件产品,统一的基础管理平台,实现用户数据统一管理、权限统一分配、身份统一认证。统一规划门户网站群和协同办公平台,将外网信息维护、客户服务、互动交流和日常工作......
  • JackJson对象转化
    当接受jsonKey首字母为大写的时候需要用JSONProperty配合JsonIngore处理packagecom.example.demoboot.dto;importcom.example.demoboot.entity.Person;importjava.util.List;/***封装response返回的data对象对象太多可以用宽对象,把所有需要的都写一起**......
  • JSP
    Jsp语法:1.      注释 静态注释:就是对静态代码的注释语法 它是由浏览器处理的也可以对XML配置文件进行注释,由服务器进行处理动态注释:就是对动态代码的注释语法<%--  --%>它是由tomcat处理的      ,也可以采用原生Java注释。2.变量  全局变量:<%!......
  • 一个基于Nodejs环境的小工具,使用Puppeter对网页进行全屏截图
    screenshotsAsmalltoolbasedonNodejsenvironment,usingPuppetertotakefullscreenscreenshotsofanywebpage1.简介 一个基于Nodejs环境的小工具,使用Puppeter对任何网页进行全屏截图 2.特点 如果页面有滚动条会自动滚屏截取全部可见内容如果页面使用......
  • Node.JS安装教程 (2024)
    Node.js安装教程(2024)1.下载Node.js目前官网已经更新到20.12版本了官网下载地址https://nodejs.org/en/download,点击下载即可。2.打开刚刚下载的安装包,点击next3.勾选同意许可,接着点击next4.选择安装路径,这里默认是安装到C盘,点击next如果需要改变安装路径,点击change......
  • 人工智能时代,前端全栈成就独立开发工程师 next.js 开发实战
    由于next.js是基础于react所以在正式学习next.js之前我们了解一下react一模块,就是一个文件,向外提供一些功能的文件,之所要要折分模块就是因为功能越来越复杂,为了方便管化或管理。第一部份,我们用最原始的,没有用脚手架,所以要手工加载三个文件,一个dom 一个react 一个babel......
  • 浅析JS原型链
    目录实例对象原型对象对象原型短暂总结一下constructor原型链何为原型链呢?就是实例对象和原型对象之间的链接,每一个对象都有原型,原型本身又是对象,原型又有原型,以此类推形成一个链式结构.称为原型链。这里又扯到了另外两个概念了。实例对象>>>先往下看实例对象原型对象>>......