在 WebBrowser 控件中检测滚动到底部
Detect scroll to bottom in WebBrowser control
我正在创建一个 Windows 表单来接受公司的一些条款和条件。所以条款和条件在网络上,它通过 WebBrowser 控件导航到 WinForm。只有在整个文档滚动到底部后才需要启用接受按钮。我正在 VScrollBar 控件(如下所述)或任何其他选项中搜索类似于 ValueChanged 事件的事件。
private void vScrollBar1_ValueChanged(object sender, EventArgs e)
{
if (vScrollBar1.Value+9 == vScrollBar1.Maximum)
{
acceptBtn.Enabled = true;
}
}
滚动条不是 WebBrowser 控件的一部分,而是 Html 显示的一部分。您必须订阅显示的 Document
的 Window 的 Scroll 事件
webBrowser1.Document.Window.Scroll += MyScrollCode;
https://msdn.microsoft.com/en-us/library/system.windows.forms.htmlwindow.scroll(v=vs.110).aspx
您应该处理 window
对象的 onscroll
事件并检查 scrollHeight - scrollTop
是否等于 documentElement
的 clientHeight
。为此:
private void webBrowser1_DocumentCompleted(object sender,
WebBrowserDocumentCompletedEventArgs e)
{
this.webBrowser1.Document.Window.AttachEventHandler("onscroll", OnScroll);
}
void OnScroll(object sender, EventArgs e)
{
var script =
@"(function()
{
var e = document.documentElement;
if (e.scrollHeight - e.scrollTop === e.clientHeight)
return true;
else
return false;
})();";
var result = webBrowser1.Document.InvokeScript("eval", new object[] { script });
if ((bool)result)
MessageBox.Show("Scrolled to end!");
}
我正在创建一个 Windows 表单来接受公司的一些条款和条件。所以条款和条件在网络上,它通过 WebBrowser 控件导航到 WinForm。只有在整个文档滚动到底部后才需要启用接受按钮。我正在 VScrollBar 控件(如下所述)或任何其他选项中搜索类似于 ValueChanged 事件的事件。
private void vScrollBar1_ValueChanged(object sender, EventArgs e)
{
if (vScrollBar1.Value+9 == vScrollBar1.Maximum)
{
acceptBtn.Enabled = true;
}
}
滚动条不是 WebBrowser 控件的一部分,而是 Html 显示的一部分。您必须订阅显示的 Document
的 Window 的 Scroll 事件webBrowser1.Document.Window.Scroll += MyScrollCode;
https://msdn.microsoft.com/en-us/library/system.windows.forms.htmlwindow.scroll(v=vs.110).aspx
您应该处理 window
对象的 onscroll
事件并检查 scrollHeight - scrollTop
是否等于 documentElement
的 clientHeight
。为此:
private void webBrowser1_DocumentCompleted(object sender,
WebBrowserDocumentCompletedEventArgs e)
{
this.webBrowser1.Document.Window.AttachEventHandler("onscroll", OnScroll);
}
void OnScroll(object sender, EventArgs e)
{
var script =
@"(function()
{
var e = document.documentElement;
if (e.scrollHeight - e.scrollTop === e.clientHeight)
return true;
else
return false;
})();";
var result = webBrowser1.Document.InvokeScript("eval", new object[] { script });
if ((bool)result)
MessageBox.Show("Scrolled to end!");
}