百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

Cefsharp 的使用(几行代码写个浏览器)

csdh11 2025-02-10 11:57 15 浏览

一、使用工具

VS2022-Winform(.NET Framework 4.7.2)、CefSharp.WinForms(谷歌浏览器开源组件)、TinyMCE

二、实现步骤

1. 安装依赖组件CefSharp.WinForms

① 打开VS2022--顶部菜单“工具”--“NuGet包管理器”--“管理解决方案的NuGet程序包”。

② 搜索“CefSharp.WinForms”,并安装,步骤如下图。

③ 在Winform设计界面,拖拽ChromiumWebBrowser组件到窗口,步骤如下图。

2. 把下载的Tiny-MCE文件夹放到项目根目录(同.sln同目录)

这里以文件夹“@tinymce”为例,把案例的sample.html改成index.html放到@tinymce里面。

3. 编写实现的C#代码。

目标是:前端能调用C#方法,交互传值;既可以使用C#弹窗,也可以使用JS弹窗。

① 配置CefSharp显示的网页位置,并注册JS调用C#的对象JsObj。

注意:指定html位置的时候,如果在配置管理器修改了参数(比如x64改x86),可能导致调试时无法通过如下方法获取index.html文件的正确路径,可以删除一个“.Parent"再试,也可以用MessageBox.Show(url)打印路径确认文件位置是否正确。

public Form1()
{
	InitBrowser();
	InitializeComponent();
	this.StartPosition = FormStartPosition.CenterScreen; // 设置窗体居中
}
public ChromiumWebBrowser browser;
public void InitBrowser()
{
	CefSettings settings = new CefSettings();
	CefSharp.Cef.Initialize(settings);

	//指定html位置。注意:如果在配置管理器修改了参数(比如x64),可能导致调试时无法通过如下方法获取index.html文件的正确路径,可以删除一个“.Parent"再试,也可以用MessageBox.Show(url)打印路径确认文件位置是否正确。
	string path = Directory.GetParent(Directory.GetCurrentDirectory()).Parent.Parent.FullName + @"\@tinymce\index.html";  // 这里注意parent搭配获取目录的方法,index.html是放在项目sln文件同目录内@tiny_mce文件夹里面的。
	// string path = Path.GetFullPath("D:\\GitHub\\WindowsFormsApp4\\@tinymce\\index.html");
	string url = "file://" + path;
	// MessageBox.Show(url);
	browser = new ChromiumWebBrowser(url.ToString());

	browser.Dock = DockStyle.Fill;  // 铺满
	this.Controls.Add(browser);

	// 注册JsObj对象,实现JS调用C#
	CefSharpSettings.WcfEnabled = true;
	browser.JavascriptObjectRepository.Settings.LegacyBindingEnabled = true;  // 允许调用JS函数调用后端代码
	browser.JavascriptObjectRepository.Register("JsObj", new getWinFormData(browser, this), isAsync: false, options: BindingOptions.DefaultBinder);
}
private void Form1_FormClosing(object sender, FormClosingEventArgs e)
{
	CefSharp.Cef.Shutdown();
}

② 编写C#方法,用以前端JS调用。

// 自定义类(JS调用C#)
public class getWinFormData
{
	private static ChromiumWebBrowser chromiumWebBrowser;
	private static Form1 form1;

	private int myId = 2;
	private String text_str = "首发知乎";
	private String startTime = "2023-05-10";

	// 构造方法
	public getWinFormData(ChromiumWebBrowser OriginachromiumWebBrowser, Form1 Originaform1)
	{
		chromiumWebBrowser = OriginachromiumWebBrowser;
		form1 = Originaform1;
	}
	// 窗口加载完毕时需要出发的全局JS对象
	public void OnFrameLoadEnd(object sender, FrameLoadEndEventArgs e)
	{
		if (e.Frame.IsMain)
		{
			chromiumWebBrowser.ExecuteScriptAsync(@"document.body.onmouseup = function()
			{
				JsObj.onSelected(window.getSelection().toString());
			}");
		}
	}
	public void showMsg(string msg)
	{
		//String Content = msg;  // 后台接收前端提供的值,可以进行其它处理,比如本地存储;
		MessageBox.Show("C#弹窗:" + msg);
	}
	public string readMessage()
	{
		return myId +";"+ text_str + ";" + startTime;
	}
	public int getId()
	{
		return myId;
	}
}

③ 如下是实现:Winform窗体大小变化时,执行JS代码实时更新前端TinyMCE编辑器尺寸。

void Form1_SizeChanged(object sender, EventArgs e)
{
	int formHeight = this.ClientSize.Height;
	string jsCode =
	$"document.querySelector('#idcardmsg').value = {formHeight};"
	+ $"tinymce.activeEditor.editorContainer.style.height = {formHeight - 300} + 'px'"  // 减去200是为了让底部的“提交”按钮在合适位置;公式可以按需调整。
	;
	browser.ExecuteScriptAsync(jsCode);
}

这里注意,需要给Winform设计界面的窗口属性绑定事件。

4. 编写前端代码。




     
    
    



    
输入框1(窗体大小调整时,会把窗体高度值更新到这里 ——实时更新)
输入框2(=输入框1的值,自动更新 ——非实时更新,快速调整窗口高度时可以看出效果差异)
(读取输入框1的值传递给C#进行winform弹窗)
(读取C#定义的参数值,然后进行js弹窗)

TinyMCE快速开始示例

三、运行界面

界面如下图。

  • 点击“测试弹出框”可以读取“输入框1”的值并由C#弹窗。
  • 点击“读取信息”可以读取C#定义参数并由JS弹窗。
  • 调整Winform应用程序窗口的大小,可以看到2个输入框的值都在随着变动。
  • 点击底部“提交”按钮,会把TinyMCE的内容提交到后台并进行C#弹窗。

四、补充说明

1. 代码已上传GitHub

地址:
https://github.com/Griked/CefSharp-TinyMCE

2. 劝退提醒

使用Winform内嵌谷歌浏览器(CefSharp)的方法,生成的文件目录非常大,上面程序调试生成的文件夹接近300MB,因为几乎把开源的谷歌浏览器放进去了。

相关推荐

探索Java项目中日志系统最佳实践:从入门到精通

探索Java项目中日志系统最佳实践:从入门到精通在现代软件开发中,日志系统如同一位默默无闻却至关重要的管家,它记录了程序运行中的各种事件,为我们排查问题、监控性能和优化系统提供了宝贵的依据。在Java...

用了这么多年的java日志框架,你真的弄懂了吗?

在项目开发过程中,有一个必不可少的环节就是记录日志,相信只要是个程序员都用过,可是咱们自问下,用了这么多年的日志框架,你确定自己真弄懂了日志框架的来龙去脉嘛?下面笔者就详细聊聊java中常用日志框架的...

物理老师教你学Java语言(中篇)(物理专业学编程)

第四章物质的基本结构——类与对象...

一文搞定!Spring Boot3 定时任务操作全攻略

各位互联网大厂的后端开发小伙伴们,在使用SpringBoot3开发项目时,你是否遇到过定时任务实现的难题呢?比如任务调度时间不准确,代码报错却找不到方向,是不是特别头疼?如今,随着互联网业务规模...

你还不懂java的日志系统吗 ?(java的日志类)

一、背景在java的开发中,使用最多也绕不过去的一个话题就是日志,在程序中除了业务代码外,使用最多的就是打印日志。经常听到的这样一句话就是“打个日志调试下”,没错在日常的开发、调试过程中打印日志是常干...

谈谈枚举的新用法--java(java枚举的作用与好处)

问题的由来前段时间改游戏buff功能,干了一件愚蠢的事情,那就是把枚举和运算集合在一起,然后运行一段时间后buff就出现各种问题,我当时懵逼了!事情是这样的,做过游戏的都知道,buff,需要分类型,且...

你还不懂java的日志系统吗(javaw 日志)

一、背景在java的开发中,使用最多也绕不过去的一个话题就是日志,在程序中除了业务代码外,使用最多的就是打印日志。经常听到的这样一句话就是“打个日志调试下”,没错在日常的开发、调试过程中打印日志是常干...

Java 8之后的那些新特性(三):Java System Logger

去年12月份log4j日志框架的一个漏洞,给Java整个行业造成了非常大的影响。这个事情也顺带把log4j这个日志框架推到了争议的最前线。在Java领域,log4j可能相对比较流行。而在log4j之外...

Java开发中的日志管理:让程序“开口说话”

Java开发中的日志管理:让程序“开口说话”日志是程序员的朋友,也是程序的“嘴巴”。它能让程序在运行过程中“开口说话”,告诉我们它的状态、行为以及遇到的问题。在Java开发中,良好的日志管理不仅能帮助...

吊打面试官(十二)--Java语言中ArrayList类一文全掌握

导读...

OS X 效率启动器 Alfred 详解与使用技巧

问:为什么要在Mac上使用效率启动器类应用?答:在非特殊专业用户的环境下,(每天)用户一般可以在系统中进行上百次操作,可以是点击,也可以是拖拽,但这些只是过程,而我们的真正目的是想获得结果,也就是...

Java中 高级的异常处理(java中异常处理的两种方式)

介绍异常处理是软件开发的一个关键方面,尤其是在Java中,这种语言以其稳健性和平台独立性而闻名。正确的异常处理不仅可以防止应用程序崩溃,还有助于调试并向用户提供有意义的反馈。...

【性能调优】全方位教你定位慢SQL,方法介绍下!

1.使用数据库自带工具...

全面了解mysql锁机制(InnoDB)与问题排查

MySQL/InnoDB的加锁,一直是一个常见的话题。例如,数据库如果有高并发请求,如何保证数据完整性?产生死锁问题如何排查并解决?下面是不同锁等级的区别表级锁:开销小,加锁快;不会出现死锁;锁定粒度...

看懂这篇文章,你就懂了数据库死锁产生的场景和解决方法

一、什么是死锁加锁(Locking)是数据库在并发访问时保证数据一致性和完整性的主要机制。任何事务都需要获得相应对象上的锁才能访问数据,读取数据的事务通常只需要获得读锁(共享锁),修改数据的事务需要获...