在CDHTMLDialog中扩展浏览器脚本以及在HTML中增加MFC消息响应

简介: 扩展浏览器脚本假设我们创建了一个CMyDHTMLDialog对话框类,包含两个文件MyDHTMLDialog.
扩展浏览器脚本
假设我们创建了一个CMyDHTMLDialog对话框类,包含两个文件MyDHTMLDialog.h和MyDHTMLDialog.cpp
1、让类自身支持自动化
    EnableAutomation();     //只要是从CCmdTarget派生下来的类都可以支持
                            //可以放在CMyDHTMLDialog::CMyDHTMLDialog()中调用

2、将自身暴露给Script引擎
    SetExternalDispatch(GetIDispatch(TRUE));        //将浏览器控件的扩展接口设置为对话框自身的IDispatch
                                                    //放在CMyDHTMLDialog::OnInitDialog中调用

3、声明DISPATCH_MAP
    DECLARE_DISPATCH_MAP()                          //MyDHTMLDialog.h的类声明中

4、定义DISPATCH映射
    BEGIN_DISPATCH_MAP(CMyDHtmlDialog, CDHtmlDialog)        //在MyDHTMLDialog.cpp文件中
    END_DISPATCH_MAP()

5.定义一个方法  //MyDHTMLDialog.h的类声明中
    afx_msg void Func1();

6、编写具体的方法
    BEGIN_DISPATCH_MAP(CMyDHtmlDialog, CDHtmlDialog)
        DISP_FUNCTION(CMyDHTMLDialog, "Func1", Func1, VT_EMPTY, VTS_NONE)        //每个方法都需要在这里添加映射
    END_DISPATCH_MAP()

    void CMyDHTMLDialog::Func1()
    {
        MessageBox(_T("Hello!"));
    }

7.重载CanAccessExternal
    virtual BOOL CanAccessExternal();////在MyDHTMLDialog.h文件中
    BOOL CWebUIAppDlg::CanAccessExternal() //在MyDHTMLDialog.cpp文件中
    {
        return TRUE;
    }

8、测试
    修改资源中的MyDHTMLDialog.htm文件
    添加一个按钮,
    <INPUT id="Button1" type="button" value="Button1" name="Button1" onclick="external.Func1();">
    注意:所有暴露出去的方法都是在external.中提供,而这个external就是对话框自己,就是SetExternalDispatch中所传递的参数。
    总结:上面所做的所有工作,无非就是将一个IDispatch接口指针传递给浏览器,浏览器中的脚本引擎就可以通过external这个对象句柄来访问我们自定义的方法。

备注:重载CanAccessExternal,返回true,即可消除“在此页上的Activex控件和本页上的其它部分的交互可能不安全,您想允许交互吗?”警告

HTML中增加MFC消息响应
    1.Web中增加一标签
        <a ID="LinkSubmit">提交</a>

    2.申明消息处理函数
        HRESULT OnLinkSubmit(IHTMLElement *pElement);

    3.消息映射
    BEGIN_DHTML_EVENT_MAP(CWebUIAppDlg)
        DHTML_EVENT_ONCLICK(_T("LinkSubmit"), OnLinkSubmit)
    END_DHTML_EVENT_MAP()

    4.函数实现
    HRESULT CWebUIAppDlg::OnLinkSubmit(IHTMLElement* pElement)
    {
        AfxMessageBox(L"OnLinkSubmit");
        return S_OK;
    }
目录
相关文章
|
8月前
|
Web App开发
在 HTML 中禁用 Chrome 浏览器的 Google 翻译功能
在 html 标签中添加 translate=“no” 属性,浏览器将不会翻译整个页面。
358 0
|
5月前
|
Linux iOS开发 MacOS
谷歌浏览器中的谷歌翻译失效了?如何解决谷歌翻译不响应问题?
本文分析了谷歌翻译在谷歌浏览器中失效的原因,并提供了针对Mac OS、Windows和Linux系统的解决方案,包括下载和执行特定软件以修复翻译服务不响应的问题。
388 0
谷歌浏览器中的谷歌翻译失效了?如何解决谷歌翻译不响应问题?
|
2月前
|
JSON 移动开发 JavaScript
在浏览器执行js脚本的两种方式
【10月更文挑战第20天】本文介绍了在浏览器中执行HTTP请求的两种方式:`fetch`和`XMLHttpRequest`。`fetch`支持GET和POST请求,返回Promise对象,可以方便地处理异步操作。`XMLHttpRequest`则通过回调函数处理请求结果,适用于需要兼容旧浏览器的场景。文中还提供了具体的代码示例。
在浏览器执行js脚本的两种方式
|
2月前
|
JavaScript 前端开发
HTML 脚本2
&lt;noscript&gt;标签用于在浏览器禁用或不支持脚本时提供替代内容。该元素可包含所有常见的 HTML body 元素。当脚本不可用时,&lt;noscript&gt; 中的内容将被显示。例如:`&lt;noscript&gt;抱歉,你的浏览器不支持 JavaScript!&lt;/noscript&gt;`
|
2月前
|
JavaScript 前端开发
HTML 脚本1
JavaScript 通过 `&lt;script&gt;` 标签嵌入 HTML,增强页面的动态和交互性。它可以包含内联脚本或引用外部脚本文件,常用于图片操作、表单验证和内容动态更新。
|
2月前
|
JavaScript 前端开发
HTML 脚本3
本教程介绍JavaScript的基本用法,包括在HTML中直接输出文本、响应事件和处理HTML样式。示例代码展示了如何使用`document.write()`输出文本,通过点击按钮触发事件,以及利用`document.getElementById().style`修改元素样式。
|
7月前
|
Web App开发
在HTML中用meta控制浏览器默认模式
在HTML文档的`&lt;head&gt;`标签中,通过添加不同的`&lt;meta&gt;`标签可指定浏览器默认使用的内核。使用`&lt;meta name=&quot;renderer&quot; content=&quot;webkit&quot;&gt;
93 1
|
4月前
|
Web App开发 存储 安全
Python编写脚本,打开浏览器输入网址,自动化登陆网站
Python编写脚本,打开浏览器输入网址,自动化登陆网站
217 4
|
6月前
|
缓存 JavaScript 前端开发
浏览器处理预检请求的响应
浏览器处理预检请求的响应
|
6月前
|
JavaScript 前端开发 物联网
文本,Vue实现打印的方式,打印机的种类有多少,浏览器打印html,右键,2打印插件,3指令打印,vue-print-nb
文本,Vue实现打印的方式,打印机的种类有多少,浏览器打印html,右键,2打印插件,3指令打印,vue-print-nb