效果图
什么是开发者工具?
开发者工具是chromium自带的调试浏览器的工具, 它和chrome, edge浏览器的开发者工具功能一样。
除此之外,我们还可以更深入的使用它。例如自动化处理、dom元素获取。网络资源处理等等。
Go执行开发者工具方法
go
package main
import (
"embed"
"fmt"
"github.com/energye/energy/cef"
"github.com/energye/energy/common/assetserve"
"github.com/energye/energy/ipc"
)
//资源目录,内置到执行程序中
//go:embed resources
var resources embed.FS
func main() {
//全局初始化 每个应用都必须调用的
cef.GlobalInit(nil, &resources)
//创建应用
cefApp := cef.NewApplication(nil)
//主窗口的配置
//指定一个URL地址,或本地html文件目录
cef.BrowserWindow.Config.Url = "http://localhost:22022/execute-dev-tool-method.html"
cef.BrowserWindow.Config.IconFS = "resources/icon.ico"
//chromium配置
config := cef.NewChromiumConfig()
config.SetEnableMenu(true) //启用右键菜单
config.SetEnableDevTools(true) //启用开发者工具
cef.BrowserWindow.Config.SetChromiumConfig(config)
//这里演示使用ipc通信实现js和go互相调用,在go监听事件中执行开发者工具方法
//使用内置http服务和自定义页面
//这里执行的方法是仿真移动端
//1. js使用ipc.emit触发 go事件
//2. go中"execute-dev-method"事件执行,通过context获得browserId
//3. 通过browserId获得chromium
//4. 使用字典对象传递方法参数
//5. 点击Note链接
ipc.IPC.Browser().SetOnEvent(func(event ipc.IEventOn) {
event.On("execute-dev-method", func(context ipc.IIPCContext) {
//获得当前窗口信息
info := cef.BrowserWindow.GetWindowInfo(context.BrowserId())
//字典对象
var dict = cef.NewCefDictionaryValue()
//根据chromium字典设置
dict.SetInt("width", 500)
dict.SetInt("height", 768)
dict.SetInt("x", 100)
dict.SetInt("y", 100)
dict.SetBoolean("mobile", true)
dict.SetDouble("deviceScaleFactor", 1)
TempDict := cef.NewCefDictionaryValue()
TempDict.SetString("type", "portraitPrimary")
TempDict.SetInt("angle", 0)
dict.SetDictionary("screenOrientation", TempDict)
info.Chromium().ExecuteDevToolsMethod(0, "Emulation.setDeviceMetricsOverride", dict)
//设置浏览器 userAgent
dict = cef.NewCefDictionaryValue()
dict.SetString("userAgent", "Mozilla/5.0 (Linux; Android 11; M2102K1G) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.101 Mobile Safari/537.36")
info.Chromium().ExecuteDevToolsMethod(0, "Emulation.setUserAgentOverride", dict)
})
})
//在主进程启动成功之后执行
//在这里启动内置http服务
//内置http服务需要使用 go:embed resources 内置资源到执行程序中
cef.SetBrowserProcessStartAfterCallback(func(b bool) {
fmt.Println("主进程启动 创建一个内置http服务")
//通过内置http服务加载资源
server := assetserve.NewAssetsHttpServer()
server.PORT = 22022 //服务端口号
server.AssetsFSName = "resources" //必须设置目录名和资源文件夹同名
server.Assets = &resources
go server.StartHttpServer()
})
//运行应用
cef.Run(cefApp)
}
html示例代码
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>执行开发者工具方法</title>
<script type="application/javascript">
//按钮点击事件
function devMethod() {
//使用ipc.emit触发Go中监听的事件
ipc.emit("execute-dev-method");
}
</script>
</head>
<body style="overflow: hidden;margin: 0px;padding: 0px;">
<button style="margin: 50px 50px 50px 50px;" onclick="devMethod()">dev-method-仿真</button>
<a href="https://note.yanghy.cn">Note</a>
</body>
</html>
说明
获取window信息
var info = cef.BrowserWindow.GetWindowInfo(context.BrowserId())
创建字段参数对象
var dict = cef.NewCefDictionaryValue()
执行方法
info.Chromium().ExecuteDevToolsMethod(0, "Emulation.setDeviceMetricsOverride", dict)
进程启动后执行回调
cef.SetBrowserProcessStartAfterCallback 在这里创建了内置http服务