当前位置: 首页 > news >正文

【Delphi】如何解决使用webView2时主界面置顶,而导致网页选择文件对话框被覆盖问题

一、问题描述:

        在Delphi 中使用WebView2控件,如果预先把主界面置顶(Self.FormStyle := fsStayOnTop;),此时,如果在Web页面中有使用(<input type="file" id="fileInput" accept=".txt, .pdf, .doc, .docx" required>  )选择文件,这样就会导致选择文件的对话框被覆盖,从而无法操作。

二、解决方案

        由于WebView2通过H5打开文件选择窗口时,Delphi无法直接获取到事件通知,因为文件选择时由浏览器进程管理的,所以需要使用一些技巧来解决。

使用javascript监听文件选择事件:

        可以通过在 WebView2 中注入 JavaScript 代码来监听文件选择窗口的打开和关闭事件,然后通过 WebView2 的事件机制将这些事件传递到 Delphi 端。

操作步骤:

  1. 注入 JavaScript 代码:在页面加载完成后,注入 JavaScript 代码来监听文件选择窗口的打开和关闭事件。
  2. 通过 WebMessage 传递事件:将事件通过 `window.chrome.webview.postMessage` 传递到 Delphi 端。
  3. 在 Delphi 中处理事件:在 Delphi 中监听 WebView2 的 `WebMessageReceived` 事件,并根据接收到的消息调整主窗体的置顶状态。

示例代码:

JavaScript 代码:

document.addEventListener('focus', function(event) {
    if (event.target.tagName === 'INPUT' && event.target.type === 'file') {
        window.chrome.webview.postMessage('fileDialogOpen');
    }
}, true);

document.addEventListener('blur', function(event) {
    if (event.target.tagName === 'INPUT' && event.target.type === 'file') {
        window.chrome.webview.postMessage('fileDialogClose');
    }
}, true);

Delphi 代码:

procedure TForm1.WebView2NavigationCompleted(ASender: TObject; const Args: ICoreWebView2NavigationCompletedEventArgs);
begin
  // 注入 JavaScript 代码
  WebView2.ExecuteScript(
    'document.addEventListener(''click'', function(event) {' +
    '    if (event.target.tagName === ''INPUT'' && event.target.type === ''file'') {' +
    '        window.chrome.webview.postMessage(''fileDialogOpen'');' +
    '    }' +
    '}, true);',
    
    nil
  );
end;

procedure TBase_Form.WebViewWebMessageReceived(Sender: TObject; const Source,
  MessageHTML, Json: WString);
begin

        if MessageHTML = 'fileDialogOpen' then
           begin
             Self.FormStyle := fsNormal;
             FH5OpenDialog := True;
           end;
    
end;

        因为文件选择按键获取焦点的同时只要点击,就立即失去了焦点,所以没有解决问题,这就需要配合Delphi的TApplicationEvents控件中的OnActivate事件来共同处理。

注意

      定义公用变量:FH5OpenDialog

procedure TBase_Form.ApplicationEvents1Activate(Sender: TObject);
begin
    if FH5OpenDialog then
       begin
         Self.FormStyle := fsStayOnTop;
         FH5OpenDialog := False;
       end;
end;

相关文章:

  • 【定昌Linux系统】部署了java程序,设置开启启动
  • 【最大半连通子图——tarjan求最大连通分量,拓扑排序,树形DP】
  • 大数据学习(52)-MySQL数据库基本操作
  • E22-xxxT22D lora模块介绍
  • 请说明字符串中 string str = null string str = ““ string str = string.Empty 三者的区别
  • 电商平台项目需求文档(精简版)
  • 实用AI推荐
  • 机器学习数学通关指南
  • C++STL---<limits>
  • 【Linux网络-HTTP协议】HTTP基础概念+构建HTTP
  • MySQL中like模糊查询如何优化?
  • 2025AI 有哪些重要的发展趋势?
  • Centos7部署k8s(单master节点安装)
  • 协议-Airkiss
  • LINUX网络基础 - 初识网络,理解网络协议
  • 一、Redis 通用命令大全
  • SoapUI 结合 Postman 测试 WebService 协议
  • 一个py文件搞定mysql查询+Json转换+表数据提取+根据数据条件生成excel文件+打包运行一条龙
  • AI日记app
  • 前端文件分片上传深度解析:从原理到实践
  • “十五五”时期长三角需创新机制,形成高水平一体化合作路径
  • 香港今年新股集资额已超600亿港元,暂居全球首位
  • 小米汽车机盖门陷谈判僵局,车主代表称小米表示“退订会造成崩塌”
  • 恒生银行回应裁员传闻:受影响的员工数目占银行核心业务员工总数约1%
  • 马上评|中学生被操场地面烫伤,谁的“大课间”?
  • 当番茄霸总遇上晋江古言,短剧IP小变局