• 如何控制内嵌网页


    最近开发过程中需要和BS结合,但是登陆页面是内嵌的一个HTML,需要控制该HTML里面的元素,例如在登陆对话框中需要初始化单位列表,当选择不同的单位时,填充部门列表,同样选择不同的部门初始化用户列表,这些信息都是从数据库中读取的,但是不能配置 ODBC 或者 JDBC 一类的信息,所以只能在程序内部进行控制;所有这一切可以使用 CDHtmlDialog 来进行,该对话框可以从资源或者网络加载一个网页,然后提供内部控制机制;

    首先来说明如何对选择框的内容进行填充,参考下面的函数:

    填充选择框的函数代码

    有了该函数后,后面就好办了,关键是在不同的地方加上不同的事件响应代码,这些可以使用 DHTMLDialog 的事件映射宏来定义,如下代码所示:

    HTML 事件映射宏定义

    这些事件函数全部返回 HRESULT , 并且有一个 IHTMLElement 接口指针,表明是那个页面元素发生的事件,返回 S_OK ,禁用页面中的事件响应代码,如果返回 S_FALSE ,则继续执行网页中对应的响应代码;
    DHTML_EVENT_ONCLICK 事件是当鼠标单击一个 HTML 元素时发生的事件,例如单击一个按钮,或者一个图片,在这里我就是使用一个图片来作为按钮的,如果需要鼠标在图片上显示为小手的形状,那么使用风格 style="cursor:hand;" 即可;
    DHTML_EVENT_ONKEYDOWN 事件就是在文本或密码输入框中有一个键盘按钮被按下时发生的事件,在这里可能需要对键盘事件进行过滤,所以关键是如何获取键盘事件的按键编码,就是哪一个按键被按下,参考如下代码:

    在密码框上按下键盘的代码

    DHTML_EVENT_ONCHANGE 事件就是选择一个下拉列表框中不同的项目时发生的事件,例如在单位列表发生变化时,我们可以取出单位的编号,然后生成一个SQL语句,然后调用 ResetSelectOptions 函数填充部门列表,在这里可能使用的函数是:

    针对下拉列表框的函数

    上面三个函数分别获取或设置下拉列表框的当前选中项目的值、文本和索引;最后需要注意的是单位的列表必须在一开始就进行初始化,这个初始化工作不能在 InitDialog 中进行,必须在网页加载结束后进行,可以在下列虚函数中进行初始化:

        //----------------------------------------------------------------------------------------------
        
    //    概述:
        
    //        网页加载完成后执行的虚函数
        
    //----------------------------------------------------------------------------------------------
        virtual void OnDocumentComplete( LPDISPATCH pDispatch , LPCTSTR szUrl );
    在该函数中首先调用基类的函数,然后进行单位的初始化即可;
    最后当用户输入错误的密码时,需要显示错误信息,错误信息事先已经在网页中定义了,但是风格设置为隐藏:style="color:#EF0000; 160px; display:none; font-size:10pt; font-weight:bold;",在程序中,如果判断用户密码错误,只需要显示该错误信息就可以了,当然当用户重新输入密码时,隐藏该错误信息,显示和隐藏错误信息的代码如下:
    显示和隐藏页面元素

    使用 SetFocusToElement 可以让网页中的一个元素获取输入焦点,例如密码输入框;
    最后如果要禁用网页上的右键菜单和进行文本选择可以在 BODY 中增加属性:OnContextMenu="return false" OnSelectStart="return false"

  • 相关阅读:
    linux mysql开启远程链接
    Nginx 下无法读取session 导致 thinkphp验证码错误
    Nginx 开启 path_info功能
    让chrome打开手机网页
    vue 组件和全局组件的注册、使用
    Vue 导入文件import、路径@和.的区别
    vue 打包路径不对设置方法
    id
    Ajax GET 和 POST 的区别
    前端笔试题汇总 2018/12/04 (2)
  • 原文地址:https://www.cnblogs.com/WonKerr/p/DlgUserLogin.html
Copyright © 2020-2023  润新知