vue3与cef3交互

cef版本:92.0.27+g274abcf+chromium-92.0.4515.159_windows64

node:v22.22.0

vue: "^3.5.26"

1、vue3组件调用C++方法:

C++中:

cpp 复制代码
RenderDelegate::OnWebKitInitialized()
{
	  CefRefPtr<CefV8Handler> handler = m_v8handler;
	  std::string app_code =
		  "var APP;"
		  "if (!APP)"
		  "    APP= {};"
		  "(function() {"

		  "    APP.call_c_p_p= function(param,callback) {"
		  "        native function call_c_p_p();"
		  "        return call_c_p_p(param,callback);"
		  "     };"

		  "})();";

	  CefRegisterExtension("v8/APP", app_code, handler);
}

Vue3组件中:

javascript 复制代码
const handleFunc = async () => {
        if (typeof (window.APP) == "undefined") {
    }
    else {
        var ret = window.APP.call_c_p_p("msg param", (result) => {
            alert("result:" + result);
        });
    }
    return
}

2、C++调用vue3:

C++代码:

cpp 复制代码
CefRefPtr<CefBrowser> browser = context->GetRootWindowManager()->GetActiveBrowser();
CString callparam;

callparam.Format(_T("call_vue('%s');"), _T("来自CEF3的调用"));

browser->GetMainFrame()->ExecuteJavaScript(callparam.GetBuffer(), browser->GetMainFrame()->GetURL(), 0);

Vue组件:

javascript 复制代码
onMounted(() => {
window.call_vue = (param) =>
{
	alert("receive msg from CEF3: " + param);
}
})

不管是vue调C++还是C++调vue,vue中都要通过window对象来访问。

相关推荐
咕噜咕噜啦啦1 天前
Vue3响应式开发
前端·javascript·vue.js
huangql5201 天前
布局单位与设计稿换算:从「看清」到「量准」
前端
牛奶1 天前
你不知道的JS(下):深入编程
前端·javascript·电子书
牛奶1 天前
你不知道的JS(下):深入JS(下)
前端·javascript·电子书
牛奶1 天前
你不知道的JS(下):总结与未来
前端·javascript·电子书
牛奶1 天前
你不知道的JS(下):深入JS(上)
前端·javascript·电子书
CappuccinoRose1 天前
HTML语法学习文档(五)
前端·html·html5·表单
硅基动力AI1 天前
如何判断一个关键词值不值得做?
java·前端·数据库
yq1982043011561 天前
使用Django构建视频解析网站 从Naver视频下载器看Web开发全流程
前端·django·音视频
李明卫杭州2 天前
在 JavaScript 中,生成器函数(Generator Function)
前端·javascript