如何在Page_Load()里获取DataList里的控件值

如何在Page_Load()里获取DataList里的控件值,第1张

不要尝试在page_load里取控件值,没有意义,首先你要在DAL层弄个method,然后你直接拿这个参数用去数据库查所要的值,然后以string方式返回这些值,然后在page_load call那个method就行了,得到值一切搞定,在datalist里拿?net生成的顺序是先Page_load再读页面内的控制,也就是说你的Page_load先于datalist。不信你自己debug下

首先:鼠标API函数

[DllImport("User32")]

public extern static void mouse_event(int dwFlags, int dx, int dy, int dwData, IntPtr dwExtraInfo);

[DllImport("User32")]

public extern static void SetCursorPos(int x, int y);

[DllImport("User32")]

public extern static bool GetCursorPos(out POINT p);

public struct POINT

{

public int X;

public int Y;

}

public enum MouseEventFlags

{

Move = 0x0001,

LeftDown = 0x0002,

LeftUp = 0x0004,

RightDown = 0x0008,

RightUp = 0x0010,

MiddleDown = 0x0020,

MiddleUp = 0x0040,

Wheel = 0x0800,

Absolute = 0x8000

}

其次:载入webBrowser

private void FormBrower_Load(object sender, EventArgs e)

{

webBrowserNavigate(">

上一节中,我们完成了CEF各基本组件的封装,并完成了浏览器基本功能的实现。 >>点这里回顾上节内容

本节我们将尝试扩展所实现的各组件,实现浏览器与页面的双向通信。

本篇的小目标:

上一节曾提到过,CEF应用在默认情况下包含很多子进程,这些进程会共享同一个执行入口。除了主进程的各类处理接口外,CEF还提供了各类子进程的处理接口。而 页面到浏览器的消息通道 就可以借助对 渲染进程 的控制来实现,整体流程如下:

完成上述步骤后,在页面调用对应的消息通道函数时,V8处理器则会相应地进行处理,从而完成消息的发送。

另一方面,实现 浏览器到页面 的消息通道和第二节中基于Qt WebEngine的方法类似,CEF也提供了执行JS脚本的方法,只需在页面中定义好对应的消息接口,并通过执行脚本方法执行该接口即可完成消息的发送。

因此,实现双向通道主要的问题集中在针对渲染进程处理和JS脚本执行的扩展上。接下来先就渲染进程处理进行说明。

为了实现对渲染进程的处理,我们首先需要向上一节中封装的QCefContext中添加对渲染进程入口的解析和处理。具体实现如下:

上面的实现除了处理了CEF主进程外,还判断了子进程是否为渲染进程(Windows环境下的renderer进程和Linux环境下的zygote进程),如果发现当前处理的是渲染进程,则创建一个渲染进程处理器QCefRenderHandler的实例。QCefRenderHandler的声明如下:

和主进程CefApp的实现类似,这里也实现了CefApp接口,此外额外实现了CefRenderProcessHandler接口的OnContextCreated方法,来获取V8上下文的引用,具体实现如下:

上面的实现将sendMessage函数定义为消息通道,并注册到了window对象上。sendMessage函数的具体实现则放在v8Handler的实现中。QCefV8Handler声明如下:

QCefV8Handler通过实现CEF V8处理器的Execute执行方法,完成对所加载的JS函数的过滤,并进行相应的处理,实现如下:

这里首先对函数名和参数进行了校验,之后调用CefBrowser的IPC方法SendProcessMessage向主进程的CefClient发送消息,从而完成页面向浏览器主进程消息的传递。

要实现页面到浏览器的消息通道,除了完成了上面渲染进程的控制扩展,我们还需要在QCefClient中添加接收IPC消息的接口实现。首先在QCefClient头文件中声明对CefClient接口的重载:

然后实现这个接口,完成消息的接收处理:

可以看到这里只是对收到的消息进行了简单的转换,并通过信号发送给感兴趣的下游控件使用。在第四小节的实现中,我们将QCefClient封装到了QCefView中,因此在QCefView中也需要将这个信号转发给它的下游控件:

这样,QCefView接收JS消息的通道就实现完成了。

这里额外讲解一下有关js alert的特殊处理。要实现js调用alert方法时的d窗提醒,需要额外在CefClient中实现CefJSDialogHandler接口的OnJSDialog方法,参考实现如下:

承前所述,浏览器到页面的消息发送通过CEF的JS脚本执行接口实现。首先在QCefView中,声明并实现一个执行JS脚本的方法:

然后指定一个特定的JS方法,作为消息通道使用:

如此,QCefView发送JS的通道也实现完成了。

完成了消息通道的实现,接下来我们实际使用一下我们定义好的消息通道。

首先是Qt端的实现,在MainDlg的initWebView方法中,添加对JS消息的监听,并将监听到的消息通过QMessageBox显示出来:

然后添加文本输入和发送按钮,并在按钮点击信号对应的槽中调用QCefView的消息发送方法:

接下来在页面端实现消息接收和发送的接口msgutilsjs:

可以看到这里我们使用了上面定义的recvMessage和sendMessage两个函数。然后在页面上调用这些接口:

实际运行一下浏览器,并加载我们实现的这个页面,消息发送效果如下:

有关CEF消息通道的讲解就先进行到这里。下一节将分析使用CEF接口实现>

控件初始化的时候,都是用ControlsAdd来添加的,Controls类似一个Array,最后Add的控件,肯定是在Array的第一个遍历的顺序应该是Add的倒序来的最后一个Add的控件被第一个选出来

按照这个思路,我相信你可以想到很多种解决办法了

QWebEngineView QWebEngineView::createWindow(QWebEnginePage::WebWindowType type)

在鼠标左键点击的时候会触发这个方法,你把它重载一下,用你自己的实现就可以了。

默认是白色背景,如果加载的html背景颜色是其他颜色,那么会先显示白色,闪一下以后才会加载出html设置的背景色,为了避免这种情况出现,需要通过webEngineView->page()->setBackgroundColor设置相同颜色,就不会闪出白色了。

1、在stackedwidget下有多个页面,如果有webEngineView的页面不是stackedWidget默认的页面,那么该页面的JS代码无法加载,原因未知。目前解决方法是把page中的UI改为public,在切换到对应页面时手动通过UI获取webEngineView去load页面,这样才能正常显示。

2、load的html中有js文件,且load时使用的是qrc路径,那么js文件也必须加到qrc文件中,否则js文件无法正常加载。

以上就是关于如何在Page_Load()里获取DataList里的控件值全部的内容,包括:如何在Page_Load()里获取DataList里的控件值、WebBrowser浏览器控件,怎么获取页面某网页元素XPATH、Qt嵌入浏览器(六)——QCefView实现JS通信接口等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/10147405.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存