Winform 下使用WebBrowser的HTML编辑控件—WinHtmlControl 在win7 IE9下的问题

简介: 问题是这样的,有一个需要用到富文本的地方,由于是winform的程序,而且程序是上一代老员工留下的,错误百出,现在要尽量修复,至少保证能正常使用,于是就开始一点点问题修复. 在win7 64位系统下出现无法激活编辑状态,或者说无法获得光标,总之无法写入任何字符就是了.

问题是这样的,有一个需要用到富文本的地方,由于是winform的程序,而且程序是上一代老员工留下的,错误百出,现在要尽量修复,至少保证能正常使用,于是就开始一点点问题修复.

在win7 64位系统下出现无法激活编辑状态,或者说无法获得光标,总之无法写入任何字符就是了. 

开始怀疑是32位和64位的原因,  编译了一个64位的版本测试,结果还是不行.

找到了@liust 仁兄的一篇文章,豁然开朗,原来是ie9在捣鬼,还不是64位的原因,  由于win7 64位只能安装ie9 所以问题还是得解决.

直接复制下面的代码,似乎是有些用,但是产生了其他问题

当然博主忘了说 要注册事件的.

要在private void SetupBrowser() 里

注册事件
webBrowser1.DocumentCompleted += new WebBrowserDocumentCompletedEventHandler(webBrowser1_DocumentCompleted);
 

由于我的系统是上一代老员工留下的,所以在DocumentCompleted 事件里有一些其他的代码.

导致出现了一个新的问题. "该文档已被修改,是否保存修改结果?"

image

 

出现了这个问题,再继续搜索,走了一些弯路

webBrowser1.Document.Write(webBrowser1.DocumentText); 应该是这句惹得祸

但是如何又能加载数据,又可以避免在这个地方修改控件的值呢,  我的想法应该是在设置On之前就把数据加载好

 

在调试中发现次触发焦点事件时首先会走到这个函数

private void SetupBrowser(bool edit)

在这个函数里有一个标志 edit   

如果为真 则设置了 doc.designMode = "On" 

之后又做了一些其他的操作,没有细看

为什么明明设置了"On"了 到了DocumentCompleted 又要再设置一次呢? 

与其在那猜测,还不如调试呢,于是装上IE9, 开始调试

发现程序在IE9下跑到DocumentCompleted 时   ie9下的designMode为"Inherit"

难怪又要再设置一次"On" 于是根据SetupBrowser(bool edit) 这个里面的edit  在DocumentCompleted 中修改了一下代码

其中toolStrip.Visible 是控件的工具条是否显示,由于是个全局变量,所以就直接拿来用了,因为toolStrip.Visible = edit ; 否则楼主是想自己建个全局变量来保存edit的状态的

if (toolStrip.Visible)
{
    if (doc.designMode != null && doc.designMode != "On")
        doc.designMode = "On";

}

目录
相关文章
|
1月前
|
前端开发 JavaScript 搜索推荐
react-app框架——使用monaco editor实现online编辑html代码编辑器
react-app框架——使用monaco editor实现online编辑html代码编辑器
78 3
|
1月前
|
前端开发 JavaScript API
react搭建在线编辑html的站点——引入grapes实现在线拖拉拽编辑html
react搭建在线编辑html的站点——引入grapes实现在线拖拉拽编辑html
25 0
|
1月前
|
数据安全/隐私保护
HTML表单(Form)常用控件
HTML表单(Form)常用控件。
27 1
|
1月前
|
JavaScript C#
C#winForm程序与html JS交互调用
C#winForm程序与html JS交互调用
|
1月前
|
移动开发 HTML5
HTML5编辑规范
HTML5编辑规范。
53 1
|
1月前
|
Web App开发 前端开发 JavaScript
新的 HTML 控件登陆 Safari
# html # 网络开发者
32 1
|
1月前
|
JSON 定位技术 API
HTML新特性【规划公交路线、规划步行路线、定位、自定义视角动画、账号和获取密钥、初始化、变更地图类型、添加控件、改变控件位置】(五)-全面详解(学习总结---从入门到深化)(下)
HTML新特性【规划公交路线、规划步行路线、定位、自定义视角动画、账号和获取密钥、初始化、变更地图类型、添加控件、改变控件位置】(五)-全面详解(学习总结---从入门到深化)
43 0
|
1月前
|
移动开发 HTML5 容器
HTML5——周技能检测——菜单编辑——2022年11月22日(考完)
HTML5——周技能检测——菜单编辑——2022年11月22日(考完)
26 0
|
1月前
|
移动开发 JavaScript 前端开发
HTML新特性【规划公交路线、规划步行路线、定位、自定义视角动画、账号和获取密钥、初始化、变更地图类型、添加控件、改变控件位置】(五)-全面详解(学习总结---从入门到深化)(上)
HTML新特性【规划公交路线、规划步行路线、定位、自定义视角动画、账号和获取密钥、初始化、变更地图类型、添加控件、改变控件位置】(五)-全面详解(学习总结---从入门到深化)
65 0
|
1月前
|
JSON 定位技术 数据格式
HTML新特性【账号和获取密钥、初始化、变更地图类型、添加控件、改变控件位置、添加覆盖物、自定义标注图标、添加文本标注】(四)-全面详解(学习总结---从入门到深化)(下)
HTML新特性【账号和获取密钥、初始化、变更地图类型、添加控件、改变控件位置、添加覆盖物、自定义标注图标、添加文本标注】(四)-全面详解(学习总结---从入门到深化)
42 0