美文网首页
Web页面嵌入到Qt注意事项

Web页面嵌入到Qt注意事项

作者: shujuan0618 | 来源:发表于2019-11-07 09:55 被阅读0次

目前,web页面嵌入Qt框架方式:

Qt:系统、一级、二级菜单框架;底部消息栏。

Web:三级菜单子页面。

开发方式:在web环境下开发完成后,将单独页面嵌入到qt中,html、js等文件都作为资源加入到qt工程中。

1、html页面中引入webchannel库:

<script src="../../../../lib/qwebchannel.js"></script>

<script src="../../../../js/component/webchannel.js"></script>

其中,webchannel.js中,初始化了qt与web之间的通道,并定义qt与web之间的消息类型和内容。消息类型对应各个页面具体功能。新加的页面消息需要在该文件中添加。

2、Qt中相应子页面中加入web页面路径:

例如 epvl模型研判页面 JudgePool.qml:

image.png

以上步骤完成,就可以在Qt中看到web页面了。接下来需要注意的事项:

3、每个web页面下的初始化函数都必须在qt侧调用,因为初始化用到的一些如userinfo等信息需要Qt侧传入。并且在web页面初始化完成后调用。

(1)web页面中,加入页面初始化完成信号。

image.png

(2)Qt页面中,加入消息接收,并发送到web页面初始化消息。

image.png

(3)在webchannel.js中,加入web页面初始化函数。

image.png

4、遇到的问题:

(1)html中引入的js,如placecode.js等,都有初始化函数,凡是涉及到userinfo的都需要在qt侧调用。

(2)web中对文件名称大小写不区分,在Qt中严格区分。

(3)父页面弹窗中是一个iframe的情况,iframe初始化问题解决方法:

  1. iframe页面同样要包含这两个js
image.png
  1. 在父页面的初始化函数中动态加载iframe的src
image.png

iframe的路径不能在父页面静态加载,这样会导致iframe的js先于父页面的js加载,正常逻辑应该父页面的js先加载

  1. iframe的js中全局变量和方法的使用需要加上parent. 这样才能成功发出iframe子页面的信号
image.png image.png
  1. qt成功获取到iframe的信号之后,应该开始调用iframe的初始化方法,如果直接调用的话会报undefined

需要在父页面定义一个方法来触发iframe的初始化方法

image.png image.png

(4)页面跳转之后,需要调用跳转目的界面方法的问题:

1.web端js需要发出跳转信号

举例:案事件库的案件详情界面中跳转至【案件比对】(case_lib.js)


image.png

2.qt端qml接收跳转信号,调用CommonFun.jumpSystemPage方法,再向web端发信号调用目的界面的方法

注意: 目的界面有可能是初次打开,需要等目的界面初始化完成才能发调用web端方法(CaseLib.qml)

image.png

3.qt端目的界面需要定义初始化完成的信号,便于其他qt界面知道界面初始化完成:

(<u>compare_case.js</u>)

image.png

(<u>CompareCase.qm</u>l)

image.png

相关文章

  • Web页面嵌入到Qt注意事项

    目前,web页面嵌入Qt框架方式: Qt:系统、一级、二级菜单框架;底部消息栏。 Web:三级菜单子页面。 开发方...

  • web页面嵌入到Qt

    标签(空格分隔): plug 开发方式:在web环境下开发完成后,将单独页面嵌入到qt中,html、js等文件都作...

  • Android Deeplink基础使用

    Deeplink定义 deeplink是用于设置一个web链接,将链接嵌入到web页面中,当用户点击外部链接时由浏...

  • Kibana嵌入web系统 账号免登录

    我们知道Kibana通过url嵌入到web系统,但是如果elk配置了安全密码,kibana嵌入到web系统之后会,...

  • 给PM讲技术:Web

    在移动端App中使用Web加载的方式打开Web页面,就可以将Web页面嵌入移动App中,实现二者的相互混合。这种方...

  • 使用 CMake 将 Qt 项目部署到嵌入式设备

    运行 Qt 项目时,Qt Creator 首先通过 ssh 将项目部署到远程嵌入式 Linux 设备上,然后在远程...

  • Qt开发系列1——Qt环境搭建

    Qt开发系列1——Qt环境搭建 Qt环境搭建 本文给出linux下Qt环境搭建的具体过程,尤其是嵌入式Qt的环境搭...

  • XSS 跨站脚本攻击Cross Site Script)

    XSS简介 xss就是攻击者在web页面插入恶意的Script代码,当用户浏览该页之时,嵌入其中web里面的Scr...

  • Qt 嵌入式图形开发大全和QT开发手册

    Qt 嵌入式图形开发大全和QT开发手册,感觉这个资料会很多人要,毕竟学习嵌入式的人还蛮多的,各种找嵌入式的资料,今...

  • 小程序随笔4:嵌入网页

    今天简单的说一下嵌入网页,使用一个新控件web-view,每个页面只能有一个 web-view,web-view ...

网友评论

      本文标题:Web页面嵌入到Qt注意事项

      本文链接:https://www.haomeiwen.com/subject/ndymbctx.html