CN102981845A - 浏览器进行页面元素处理的方法及装置 - Google Patents

浏览器进行页面元素处理的方法及装置 Download PDF

Info

Publication number
CN102981845A
CN102981845A CN2012104543205A CN201210454320A CN102981845A CN 102981845 A CN102981845 A CN 102981845A CN 2012104543205 A CN2012104543205 A CN 2012104543205A CN 201210454320 A CN201210454320 A CN 201210454320A CN 102981845 A CN102981845 A CN 102981845A
Authority
CN
China
Prior art keywords
dom object
dom
browser
page
handler
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN2012104543205A
Other languages
English (en)
Other versions
CN102981845B (zh
Inventor
唐曦
陈志�
李鸣
任寰
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing Qihoo Technology Co Ltd
Original Assignee
Beijing Qihoo Technology Co Ltd
Qizhi Software Beijing Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Beijing Qihoo Technology Co Ltd, Qizhi Software Beijing Co Ltd filed Critical Beijing Qihoo Technology Co Ltd
Priority to CN201210454320.5A priority Critical patent/CN102981845B/zh
Publication of CN102981845A publication Critical patent/CN102981845A/zh
Priority to US14/442,227 priority patent/US9996512B2/en
Priority to PCT/CN2013/083706 priority patent/WO2014075509A1/zh
Application granted granted Critical
Publication of CN102981845B publication Critical patent/CN102981845B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Information Transfer Between Computers (AREA)

Abstract

本发明公开了一种浏览器进行页面元素处理的装置,包括:至少一个DOM对象处理器,设置在浏览器侧,每个DOM对象处理器配置为存储有特定DOM对象的定制处理;页面解析器,配置为在浏览器侧加载获取页面,并对获取页面的页面元素进行解析,将各页面元素转换为DOM对象;DOM处理器,耦接到页面解析器和至少一个DOM对象处理器,配置为调用设置的至少一个DOM对象处理器,对转换的DOM对象中的至少一个进行设置的定制处理。采用本发明能够根据用户需求对网页进行个性化定制。本发明还公开了相对应的方法。

Description

浏览器进行页面元素处理的方法及装置
技术领域
本发明涉及网络应用领域,尤其是涉及一种浏览器进行页面元素处理的方法及装置。
背景技术
随着国际互联网的快速发展,基于国际互联网的应用和信息也呈现出爆发性的增长。网络浏览器为互联网用户提供了一种访问网络信息和使用网络应用的方式,该方式适用性强,越多越多的用户已经习惯于通过网络浏览器来获取各种信息和使用各种应用。网络信息和应用供应商提供以诸如HTML(超文本标记语言,Hypertext MarkupLanguage)之类格式的语言编写的网页,网络浏览器在用户处呈现这些网页,从而使得网络浏览器的用户可以获取相关信息。随着网络技术的快速发展,由网络浏览器呈现的内容也越来越丰富,因此网络浏览器的呈现功能也越来越强大和重要。目前常见的网页浏览器有微软公司的Internet Explorer、Mozilla Firefox、谷歌公司的Chrome、Opera以及苹果公司的Safari等等。
在相关技术中,网络浏览器利用渲染引擎(Rendering Engine)来解释网页中的内容(如HTML、JavaScript)并渲染(显示)网页。渲染引擎决定了浏览器如何显示网页的内容以及页面的格式信息。不同的渲染引擎对网页编写语法的解释也有不同,因此同一网页在不同渲染引擎的浏览器里的渲染(显示)效果也可能不同。
目前网页浏览器的渲染引擎通过将HTML中的各个元素以及j s代码转换成DOM模型来进行渲染。在进行转换时,整个HTML文档被构建DOM树,HTML中的各元素被转换成DOM树中的对象,而对象之间的关系被构造为节点和子节点之间的关系来构造,通过使用有关对象的方法,可以对这些对象进行寻址和操作。DOM模型已经具有很多公共的规范和定义。
当网页浏览器处理HTML页面时,浏览器中的渲染引擎对HTML页面语言进行分析,将其处理为DOM模型,随后利用DOM模型来构造用于在浏览器中显示页面的内部结构。DOM API还向js代码提供了监控或者修改网页的接口。
渲染引擎引入了基于事件的机制来处理DOM对象。每个DOM对象具有相关联的多个事件,并且这些事件可以被触发。例如,渲染引擎分析网页中的JS代码,并且将相应JS代码和事件相关联,从而使得到特定事件被触发时,执行相应的JS代码。
然而,在目前的网页浏览器中,渲染引擎通常仅仅根据HTML网页中的JS代码来控制相应DOM对象,因此,用户使用浏览器时很难对DOM对象,即网页中的各个元素进行定制渲染。
综上可知,现在的网络浏览器在呈现网页时,通常根据网络应用和信息提供商所要求的方式来呈现网页内容,而并未充分考虑用户对页面呈现方式的偏好。因此现有的网络浏览器虽然具有不同的渲染引擎,当其呈现效果基本相同,这使得用户无法充分个性化定制网络浏览器呈现的内容,降低用户的感受体验。
发明内容
鉴于上述问题,提出了本发明以便提供一种克服上述问题或者至少部分地解决上述问题的浏览器进行页面元素处理的装置和相应的浏览器进行页面元素处理的方法。
依据本发明的一个方面,提供了一种浏览器进行页面元素处理的装置,包括:至少一个DOM对象处理器,设置在浏览器侧,每个DOM对象处理器配置为存储有特定DOM对象的定制处理;页面解析器,配置为在浏览器侧加载获取页面,并对获取页面的页面元素进行解析,将各页面元素转换为DOM对象;DOM处理器,耦接到页面解析器和至少一个DOM对象处理器,配置为调用设置的至少一个DOM对象处理器,对转换的DOM对象中的至少一个进行设置的定制处理。
可选地,上述装置还包括:树生成器,耦接到DOM处理器,配置为利用经过设置的定制处理的DOM对象生成最终的DOM树,并对DOM树进行渲染。
可选地,DOM处理器还配置为在对象处理注册表中查询是否存在对当前DOM对象进行处理的DOM对象处理器,其中,对象处理注册表中登记有设置的至少一个DOM对象处理器的登记信息;若是,根据登记信息查找到对该DOM对象进行处理的DOM对象处理器,并调用。
可选地,DOM处理器还配置为当浏览器中存在对当前DOM对象进行处理的DOM对象处理器时,调用该DOM对象处理器,对该DOM对象进行设置的定制处理;当浏览器中不存在为当前DOM对象进行处理的DOM对象处理器时,对该DOM对象进行缺省处理。
可选地,每个DOM对象处理器存储有对特定DOM对象已经加载完成时触发的事件ContentReady进行处理的处理方式。
可选地,每个DOM对象处理器还存储有对获取页面的HTML全部加载完成时触发的事件DocumentReady进行处理的处理方式。
可选地,DOM处理器设置在浏览器的渲染引擎中。
可选地,DOM处理器配置为利用浏览器提供的对网页元素进行渲染的接口调用至少一个DOM对象处理器。
可选地,DOM对象包括:文本框元素;密码输入框元素。
依据本发明的另一方面,还提供了一种浏览器进行页面元素处理的方法,在浏览器侧设置至少一个DOM对象处理器,其中每个DOM对象处理器存储有特定DOM对象的定制处理,该方法包括:在浏览器侧加载获取页面,并对获取页面的页面元素进行解析,将各页面元素转换为DOM对象;调用设置的至少一个DOM对象处理器,对转换的DOM对象中的至少一个进行设置的定制处理。
可选地,对转换的DOM对象中的至少一个进行设置的定制处理之后,还包括:利用经过设置的定制处理的DOM对象生成最终的DOM树;对DOM树进行渲染。
可选地,调用设置的至少一个DOM对象处理器,包括:在对象处理注册表中查询是否存在对当前DOM对象进行处理的DOM对象处理器,其中,对象处理注册表中登记有设置的至少一个DOM对象处理器的登记信息;若是,根据登记信息查找到对该DOM对象进行处理的DOM对象处理器,并调用。
可选地,调用设置的至少一个DOM对象处理器,对转换的DOM对象中的至少一个进行设置的定制处理,包括:当浏览器中存在对当前DOM对象进行处理的DOM对象处理器时,调用该DOM对象处理器,对该DOM对象进行设置的定制处理;当浏览器中不存在为当前DOM对象进行处理的DOM对象处理器时,对该DOM对象进行缺省处理。
可选地,每个DOM对象处理器存储有对特定DOM对象已经加载完成时触发的事件ContentReady进行处理的处理方式。
可选地,每个DOM对象处理器还存储有对获取页面的HTML全部加载完成时触发的事件DocumentReady进行处理的处理方式。
可选地,调用设置的至少一个DOM对象处理器,包括:根据浏览器提供的、对网页元素进行渲染的接口调用至少一个DOM对象处理器。
可选地,浏览器为IE浏览器时,浏览器所在的客户端在WebBrowser插件设置第一接口IElementBehaviorFactory、第二接口IElementBehavior以及第三接口IDocHostUIHandler,其中,第一接口和第二接口用于调用各DOM对象处理器,第三接口用于将各DOM对象处理器注册到对象处理注册表中;调用设置的至少一个DOM对象处理器,包括:内核引擎根据浏览器所在的客户端提供的行为名称BehaviorName,通过第二接口调用与第一接口连接的至少一个DOM对象处理器;以及内核引擎根据客户端提供的页面元素标识TAG加载对应的页面元素时,调用元素行为通知方法,通知客户端页面元素的加载状态。
可选地,内核引擎调用至少一个DOM对象处理器,包括:内核引擎与获取页面提供的第四接口IElementBehaviorSite关联,通过第四接口确定当前DOM对象是定已有定制处理。
可选地,DOM对象包括:文本框元素;密码输入框元素。
在本发明实施例中,对于每个DOM对象,在浏览器侧设置对其进行定制处理的DOM对象处理器,在页面的获取过程中,利用DOM处理器调用选择的DOM对象处理器对DOM对象进行设置的定制处理。由此可见,采用本发明实施例提供的浏览器网页元素处理的装置,能够分别对于每个DOM对象进行处理,其处理的方式是由DOM处理器进行选择调用,由此呈现的网页内容能够实现个性化定制处理,而并非是根据网络应用和信息提供商所要求的固定方式,进而实现了用户能够对网络浏览器呈现的内容进行个性化定制的目的,满足不同的用户的偏好,提高用户的感受体验。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:
图1示出了根据本发明一个实施例的浏览器进行页面元素处理的装置的结构示意图;
图2示出了根据本发明一个实施例的浏览器进行页面元素处理的方法的流程图;以及
图3示出了根据本发明一个实施例的DOM对象处理器的查询流程图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
相关技术中提到,现在的网络浏览器在呈现网页时,通常根据网络应用和信息提供商所要求的方式来呈现网页内容,而并未充分考虑用户对页面呈现方式的偏好。因此现有的网络浏览器虽然具有不同的渲染引擎,当其呈现效果基本相同,这使得用户无法充分个性化定制网络浏览器呈现的内容,降低用户的感受体验。
为解决上述技术问题,本发明实施例提供了一种在浏览器侧进行页面元素处理的装置,用于实现改进的网页元素处理方式,该装置可以允许用户来个性化定制网页元素的呈现方式,从而增强页面的显示效果。
图1示出了本发明一个实施例的浏览器进行页面元素处理的装置的结构示意图。参见图1,该装置包括设置在浏览器侧的至少一个DOM对象处理器110,页面解析器120以及DOM处理器130。
其中,DOM对象处理器110包括至少一个,且预先设置在浏览器侧,在每个DOM对象处理器110中存储有特定DOM对象的定制处理。DOM对象处理器的数量可以是1个,也可以是2个,也可以是3个、4个、5个或更多,具体的数量根据特定DOM对象的数量以及定制处理的数量决定。图1中为了示意,将其设置为3个。
在对获取的一个页面进行处理时,页面解析器120在浏览器侧加载该获取页面,并对获取页面的页面元素进行解析。考虑到页面以及页面元素并不能够直接进行处理,因此,页面解析器120在解析过程中将各页面元素转换为DOM对象,以供后续DOM处理器130处理。
参见图1,DOM处理器130,耦接到页面解析器120和至少一个DOM对象处理器110。当页面解析器120解析结束后,启动DOM处理器130。DOM处理器130在转换的DOM对象中选择至少一个作为当前准备处理的DOM对象,调用设置的至少一个DOM对象处理器110,对选择出的DOM对象进行设置的定制处理。
在本发明实施例中,对于每个DOM对象,在浏览器侧设置对其进行定制处理的DOM对象处理器,在页面的获取过程中,利用DOM处理器调用选择的DOM对象处理器对DOM对象进行设置的定制处理。由此可见,采用本发明实施例提供的浏览器网页元素处理的装置,能够分别对于每个DOM对象进行处理,其处理的方式是由DOM处理器进行选择调用,由此呈现的网页内容能够实现个性化定制处理,而并非是根据网络应用和信息提供商所要求的固定方式,进而实现了用户能够对网络浏览器呈现的内容进行个性化定制的目的,满足不同的用户的偏好,提高用户的感受体验。
参见图1,浏览器进行网页元素处理的装置还包括树生成器140,耦接到DOM处理器130。当DOM处理器130调用DOM对象处理器110,对DOM对象进行定制处理结束后,树生成器140利用经过设置的定制处理的DOM对象生成最终的DOM树,并对DOM树进行渲染。
其中,对于DOM对象处理器110的调用操作,DOM处理器130需要知道每个DOM对象处理器110的地址,进而进行相应的调用,若DOM对象处理器较多且存储地址相对分散的情况下,DOM处理器130的调用就会存在一定的难度。现提供一种优选的调用方式,本例中,设置对象处理注册表,在该表格中登记所有的DOM对象处理器的登记信息,此处的登记信息可以包括各DOM对象处理器的存储地址、每个DOM对象处理器的定制操作、是否正在被调用等等。DOM处理器130可以在对象处理注册表中查询是否存在对当前DOM对象进行处理的DOM对象处理器。可选的,若查询结果为是,DOM处理器130就会根据登记信息查找到对该DOM对象进行处理的DOM对象处理器110,并调用。可选的,若查询结果为否,则证明当前不存在对该DOM对象进行处理的DOM对象处理器110。
在调用的过程中,若DOM处理器130确定浏览器中存在对当前DOM对象进行处理的DOM对象处理器时,调用该DOM对象处理器,对该DOM对象进行设置的定制处理。而DOM处理器130确定浏览器中不存在为当前DOM对象进行处理的DOM对象处理器时,对该DOM对象进行缺省处理。
对于每个DOM对象,都存在有至少两个事件,一个是该DOM对象已经加载完成时触发的事件ContentReady,另一个是整个HTML都已经加载完成时触发的事件DocumentReady。为了对网页元素进行定制,本发明实施例的构思为:在与网页元素相对应的DOM对象的ContentReady事件被触发时,就调用在网页浏览器处预先编制的定制处理,从而实现对特定网页元素的定制处理。与该构思相对应,在每个DOM对象处理器110存储有对特定DOM对象已经加载完成时触发的事件ContentReady进行处理的处理方式。进一步,由于DOM对象还存在整个页面已加载完成时触发的事件,因此,每个DOM对象处理器110还可以存储有对获取页面的HTML全部加载完成时触发的事件DocumentReady进行处理的处理方式。
由于最终呈现的是一个完整的网页,而现有技术中网页的呈现是由渲染引擎渲染结束后呈现的,因此,为便于页面呈现,本发明实施例提供的DOM处理器设置在浏览器的渲染引擎中。
在现有技术中,渲染引擎通常仅仅根据HTML网页中的JS代码来控制相应DOM对象,渲染引擎提供了与JS代码间的接口。而JS代码通常由网络应用自身或业务提供商控制,因此,渲染引擎所渲染出的网页页面是相类似的。而本例中,DOM处理器130能够利用浏览器提供的对网页元素进行渲染的接口调用至少一个DOM对象处理器110,从该接口可以实现用户的个性化定制。
优选的,上述各实施例中提及的DOM对象包括文本框元素、密码输入框元素。当然,DOM对象不仅仅包括上述两种元素,其他的网页元素均可以实现。
上述的浏览器进行页面元素处理的装置的各部分构架是根据其功能提供的,实际构架并不仅限于上述各部分,还可以包括其他部分、模块、器件等。
图2示出了根据本发明实施例的一种浏览器进行页面元素处理的方法的流程图,在浏览器侧设置至少一个DOM对象处理器,其中每个DOM对象处理器存储有特定DOM对象的定制处理。该方法的处理流程包括步骤S202至步骤S204。
步骤S202、在浏览器侧加载获取页面,并对获取页面的页面元素进行解析,将各页面元素转换为DOM对象。
步骤S204、调用设置的至少一个DOM对象处理器,对步骤S202转换的DOM对象中的至少一个进行设置的定制处理。
在本发明实施例中,对于每个DOM对象,在浏览器侧设置对其进行定制处理的DOM对象处理器,在页面的获取过程中,调用选择的DOM对象处理器对DOM对象进行设置的定制处理。由此可见,采用本发明实施例提供的浏览器网页元素处理的装置,能够分别对于每个DOM对象进行处理,其处理的方式是根据DOM对象进行选择调用,由此呈现的网页内容能够实现个性化定制处理,而并非是根据网络应用和信息提供商所要求的固定方式,进而实现了用户能够对网络浏览器呈现的内容进行个性化定制的目的,满足不同的用户的偏好,提高用户的感受体验。
参见图2所示流程,步骤S204在实施之后,利用经过设置的定制处理的DOM对象生成最终的DOM树,并对对DOM树进行渲染,将渲染后的网页呈现给用户。
步骤S204中提及调用设置的至少一个DOM对象处理器,通过调用是需要知道调用对象(每个DOM对象处理器)的地址,进而进行相应的调用,若DOM对象处理器较多且存储地址相对分散的情况下,调用就会存在一定的难度。现提供一种优选的调用方式,本例中,设置对象处理注册表,在该表格中登记所有的DOM对象处理器的登记信息,此处的登记信息可以包括各DOM对象处理器的存储地址、每个DOM对象处理器的定制操作、是否正在被调用等等。其具体的调用方法请参见图3。
图3示出了根据本发明一个实施例的DOM对象处理器的调用方法的流程图。参见图3,该步骤包括步骤S302至步骤S306。
步骤S302、在对象处理注册表中查询是否存在对当前DOM对象进行处理的DOM对象处理器。
步骤S304、当步骤S302的查询结果为是时,根据登记信息查找到对该DOM对象进行处理的DOM对象处理器,并调用。
步骤S306、当步骤S302的查询结果为否时,确定不存在对当成当前DOM对象进行处理的DOM对象处理器。
在调用的过程中,当浏览器中存在对当前DOM对象进行处理的DOM对象处理器时,调用该DOM对象处理器,对该DOM对象进行设置的定制处理。而当浏览器中不存在为当前DOM对象进行处理的DOM对象处理器时,则直接对该DOM对象进行缺省处理。
对于每个DOM对象,都存在有至少两个事件,一个是该DOM对象已经加载完成时触发的事件ContentReady,另一个是整个HTML都已经加载完成时触发的事件DocumentReady。为了对网页元素进行定制,本发明实施例的构思为:在与网页元素相对应的DOM对象的ContentReady事件被触发时,就调用在网页浏览器处预先编制的定制处理,从而实现对特定网页元素的定制处理。与该构思相对应,在每个DOM对象处理器存储有对特定DOM对象已经加载完成时触发的事件ContentReady进行处理的处理方式。进一步,由于DOM对象还存在整个页面已加载完成时触发的事件,因此,每个DOM对象处理器还可以存储有对获取页面的HTML全部加载完成时触发的事件DocumentReady进行处理的处理方式。
在现有技术中,渲染引擎通常仅仅根据HTML网页中的JS代码来控制相应DOM对象,渲染引擎提供了与JS代码间的接口。而JS代码通常由网络应用自身或业务提供商控制,因此,渲染引擎所渲染出的网页页面是相类似的。而本例中,浏览器提供了能够对网页元素进行渲染的接口,利用该接口调用至少一个DOM对象处理器,实现用户的个性化定制。
实施例一
本发明实施例中提及到的浏览器可以为多种,例如微软公司的Internet Explorer(简称IE)、Mozilla Firefox、谷歌公司的Chrome、Opera以及苹果公司的Safari等等。
现以IE浏览器为例对本发明实施例提供的网页元素的具体处理方法进行详细地阐述和说明。
当浏览器为IE浏览器时,浏览器所在的客户端在WebBrowser插件设置第一接口IElementBehaviorFactory、第二接口IElementBehavior以及第三接口IDocHos tUIHandler,其中,第一接口和第二接口用于调用各DOM对象处理器,第三接口用于将各DOM对象处理器注册到对象处理注册表中。
对于针对每个网页元素的特定处理,可能需要实现IElementBehavior(元素行为)
Implementing the IElementBehavior Interface(执行元素行为接口)
Implementing the Notify Method(执行通知方法)
Implementing the Init Method  (执行初始化方法)
Implementing the Detach Method(执行分离方法)
IElementBehaviorFactory(元素行为工厂行为)
IElementNamespaceFactory(元素命名空间工厂接口)
IElementNamespaceFactoryCallback(元素命名空间回调接口)
初始化设置后,IE浏览器中的客户端WebBrowser(网络浏览器)插件实现网页元素的具体处理步骤如下:
步骤1、客户端WebBrowser插件实现IElementBehaviorFactory接口和IElementBehavior接口。
步骤2、客户端WebBrowser插件实现IDocHostUIHandler接口。
注:这里的WebBrowser插件就是在针对特定DOM对象的特定处理器在IE中的具体实施方式,实现IDocHostUIHandler接口用于把特定处理器注册到对象注册表中由DOM处理器采用,实现IElementBehaviorFactory和IElementBehavior接口用于说明具体的定制处理实现。
步骤3、页面创建时,MSHTML会调用IDocHostUIHandler的GetHostInfo方法,客户端程序向MSHTML提供页面元素TAG及对应的Behavior Name
注:MSHTML对应于内核引擎,这个步骤对应于DOM处理器查询所有的DOM对象处理器列表。
步骤4、页面加载时,MSHTML会根据以上提供的Behavior Name,逐个调用IElementBehaviorFactory的FindBehavior方法,由客户端提供IElementBehavior接口实现。
此处,优选的,,并与页面提供的对应接口IElementBehaviorSite关联,以确定是否定制行为。
步骤5、若客户端提供了IElementBehavior实现,MSHTML在加载对应TAG的页面元素时,调用元素行为通知方法,通知客户端页面元素的加载状态。
注:元素行为通知方法在IE中实现可利用IElementBehavior::Notify。
其中,值得注意的是,步骤4和步骤5对应于DOM处理器查调用相应的DOM对象处理器对DOM对象进行处理。
本实施例的方法并不仅限IE浏览器,对于其他浏览器,其实现方式是相类似的。
优选的,上述各实施例中提及的DOM对象包括文本框元素、密码输入框元素。当然,DOM对象不仅仅包括上述两种元素,其他的网页元素均可以实现。现以文本框元素为例进行说明。
实施例二
对于Textarea(文本框)页面单元,为用户提供了在网页中输入大量文字的输入框,但是在当前的网页呈现方式下,用户仅仅可以textarea中输入简单的文字,而无法输入预订格式的文字、图像等内容。而通过在浏览器处提供对textarea的定制渲染,可以使得在textarea中输入更加丰富的内容。
本例中对于文本框元素的具体操作提供相应的说明。
1、首先,进行事件定义,在IDocHostUIHandler的GetHostInfo方法中,对浏览器的结构和标识进行自定义。在文本框元素上设置一个div层,利用pCSSBuffer指针调度,将涉及文本框元素的操作均牵引在div层上执行。
2、IElementBehaviorFactory的FindBehavior方法中,返回IElementBehavior的实现对象CTextAreaElementBehavior,并保存MSHTML提供的IElementBehaviorSite对象指针。
3、MSHTML 调用文本框元素行为通知(CTextAreaElementBehavior::Notify)方法时,对涉及文本框元素的操作进行实施。
在加载对应TAG的文本框元素时,调用元素行为通知方法,通知客户端文本框元素的加载状态。在div层对文本框元素中的内容进行处理,该处理涉及调整文本框元素内容的宽度、高度、播放效果等。
在div层处理结束后,将文本框元素的内容和div层的处理效果重叠,将重叠后的效果呈现给用户。
使用本发明实施例能够实现利用浏览器进行页面元素(文本框元素)进行处理的方法,实现用户的个性化定制,提高用户的感受体验。
采用本发明提供的装置和方法,能够达到如下有益效果:
在本发明实施例中,对于每个DOM对象,在浏览器侧设置对其进行定制处理的DOM对象处理器,在页面的获取过程中,利用DOM处理器调用选择的DOM对象处理器对DOM对象进行设置的定制处理。由此可见,采用本发明实施例提供的浏览器网页元素处理的装置,能够分别对于每个DOM对象进行处理,其处理的方式是由DOM处理器进行选择调用,由此呈现的网页内容能够实现个性化定制处理,而并非是根据网络应用和信息提供商所要求的固定方式,进而实现了用户能够对网络浏览器呈现的内容进行个性化定制的目的,满足不同的用户的偏好,提高用户的感受体验。
在此提供的算法和显示不与任何特定计算机、虚拟系统或者其它设备固有相关。各种通用系统也可以与基于在此的示教一起使用。根据上面的描述,构造这类系统所要求的结构是显而易见的。此外,本发明也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多的特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
本发明的各个部件实施例可以以硬件实现,或者以在一个或者多个处理器上运行的软件模块实现,或者以它们的组合实现。本领域的技术人员应当理解,可以在实践中使用微处理器或者数字信号处理器(DSP)来实现根据本发明实施例的浏览器进行页面元素处理的装置中的一些或者全部部件的一些或者全部功能。本发明还可以实现为用于执行这里所描述的方法的一部分或者全部的设备或者装置程序(例如,计算机程序和计算机程序产品)。这样的实现本发明的程序可以存储在计算机可读介质上,或者可以具有一个或者多个信号的形式。这样的信号可以从因特网网站上下载得到,或者在载体信号上提供,或者以任何其他形式提供。
应该注意的是上述实施例对本发明进行说明而不是对本发明进行限制,并且本领域技术人员在不脱离所附权利要求的范围的情况下可设计出替换实施例。在权利要求中,不应将位于括号之间的任何参考符号构造成对权利要求的限制。单词“包含”不排除存在未列在权利要求中的元件或步骤。位于元件之前的单词“一”或“一个”不排除存在多个这样的元件。本发明可以借助于包括有若干不同元件的硬件以及借助于适当编程的计算机来实现。在列举了若干装置的单元权利要求中,这些装置中的若干个可以是通过同一个硬件项来具体体现。单词第一、第二、以及第三等的使用不表示任何顺序。可将这些单词解释为名称。

Claims (19)

1.一种浏览器进行页面元素处理的装置,包括:
至少一个DOM对象处理器,设置在浏览器侧,每个DOM对象处理器配置为存储有特定DOM对象的定制处理;
页面解析器,配置为在所述浏览器侧加载获取页面,并对所述获取页面的页面元素进行解析,将各页面元素转换为DOM对象;
DOM处理器,耦接到所述页面解析器和所述至少一个DOM对象处理器,配置为调用所述设置的至少一个DOM对象处理器,对所述转换的DOM对象中的至少一个进行设置的定制处理。
2.根据权利要求1所述的装置,其特征在于,所述装置还包括:
树生成器,耦接到所述DOM处理器,配置为利用经过所述设置的定制处理的DOM对象生成最终的DOM树,并对所述DOM树进行渲染。
3.根据权利要求1或2所述的装置,其特征在于,所述DOM处理器还配置为在对象处理注册表中查询是否存在对当前DOM对象进行处理的DOM对象处理器,其中,所述对象处理注册表中登记有所述设置的至少一个DOM对象处理器的登记信息;
若是,根据登记信息查找到对该DOM对象进行处理的DOM对象处理器,并调用。
4.根据权利要求1所述的装置,其特征在于,所述DOM处理器还配置为当所述浏览器中存在对当前DOM对象进行处理的DOM对象处理器时,调用该DOM对象处理器,对该DOM对象进行设置的定制处理;
当所述浏览器中不存在为当前DOM对象进行处理的DOM对象处理器时,对该DOM对象进行缺省处理。
5.根据权利要求1至4任一项所述的装置,其特征在于,每个DOM对象处理器存储有对所述特定DOM对象已经加载完成时触发的事件ContentReady进行处理的处理方式。
6.根据权利要求5所述的装置,其特征在于,每个DOM对象处理器还存储有对所述获取页面的HTML全部加载完成时触发的事件DocumentReady进行处理的处理方式。
7.根据权利要求1至6任一项所述的装置,其特征在于,所述DOM处理器设置在所述浏览器的渲染引擎中。
8.根据权利要求1至7任一项所述的装置,其特征在于,所述DOM处理器配置为利用所述浏览器提供的对所述网页元素进行渲染的接口调用所述至少一个对象处理器。
9.根据权利要求8所述的装置,其特征在于,所述DOM对象包括:文本框元素;密码输入框元素。
10.一种浏览器进行页面元素处理的方法,在浏览器侧设置至少一个DOM对象处理器,其中每个DOM对象处理器存储有特定DOM对象的定制处理,该方法包括:
在浏览器侧加载获取页面,并对所述获取页面的页面元素进行解析,将各页面元素转换为DOM对象;
调用所述设置的至少一个DOM对象处理器,对所述转换的DOM对象中的至少一个进行设置的定制处理。
11.根据权利要求10所述的方法,其特征在于,对所述转换的DOM对象中的至少一个进行设置的定制处理之后,还包括:
利用经过所述设置的定制处理的DOM对象生成最终的DOM树;
对所述DOM树进行渲染。
12.根据权利要求10或11所述的方法,其特征在于,调用所述设置的至少一个DOM对象处理器,包括:
在对象处理注册表中查询是否存在对当前DOM对象进行处理的DOM对象处理器,其中,所述对象处理注册表中登记有所述设置的至少一个DOM对象处理器的登记信息;
若是,根据登记信息查找到对该DOM对象进行处理的DOM对象处理器,并调用。
13.根据权利要求10所述的方法,其特征在于,调用所述设置的至少一个DOM对象处理器,对所述转换的DOM对象中的至少一个进行设置的定制处理,包括:
当所述浏览器中存在对当前DOM对象进行处理的DOM对象处理器时,调用该DOM对象处理器,对该DOM对象进行设置的定制处理;
当所述浏览器中不存在为当前DOM对象进行处理的DOM对象处理器时,对该DOM对象进行缺省处理。
14.根据权利要求10至13任一项所述的方法,其特征在于,每个DOM对象处理器存储有对所述特定DOM对象已经加载完成时触发的事件ContentReady进行处理的处理方式。
15.根据权利要求14所述的方法,其特征在于,每个DOM对象处理器还存储有对所述获取页面的HTML全部加载完成时触发的事件DocumentReady进行处理的处理方式。
16.根据权利要求10至15任一项所述的方法,其特征在于,调用所述设置的至少一个DOM对象处理器,包括:
根据所述浏览器提供的、对所述网页元素进行渲染的接口调用所述至少一个DOM对象处理器。
17.根据权利要求12至16任一项所述的方法,其特征在于,所述浏览器为IE浏览器时,所述浏览器所在的客户端在WebBrowser插件设置第一接口IElementBehaviorFactory、第二接口IElementBehavior以及第三接口IDocHostUIHandler,其中,所述第一接口和所述第二接口用于调用各DOM对象处理器,所述第三接口用于将各DOM对象处理器注册到所述对象处理注册表中;
调用所述设置的至少一个DOM对象处理器,包括:
内核引擎根据所述浏览器所在的客户端提供的行为名称BehaviorName,通过所述第二接口调用与所述第一接口连接的所述至少一个DOM对象处理器;以及
所述内核引擎根据所述客户端提供的页面元素标识TAG加载对应的页面元素时,调用元素行为通知方法,通知所述客户端页面元素的加载状态。
18.根据权利要求17所述的方法,其特征在于,所述内核引擎调用所述至少一个DOM对象处理器,包括:
所述内核引擎与所述获取页面提供的第四接口IElementBehaviorSite关联,通过所述第四接口确定当前DOM对象是定已有定制处理。
19.根据权利要求10至18任一项所述的方法,其特征在于,所述DOM对象包括:文本框元素;密码输入框元素。
CN201210454320.5A 2012-11-13 2012-11-13 浏览器进行页面元素处理的方法及装置 Active CN102981845B (zh)

Priority Applications (3)

Application Number Priority Date Filing Date Title
CN201210454320.5A CN102981845B (zh) 2012-11-13 2012-11-13 浏览器进行页面元素处理的方法及装置
US14/442,227 US9996512B2 (en) 2012-11-13 2013-09-18 Customized processing of DOM objects
PCT/CN2013/083706 WO2014075509A1 (zh) 2012-11-13 2013-09-18 浏览器进行页面元素处理的方法及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201210454320.5A CN102981845B (zh) 2012-11-13 2012-11-13 浏览器进行页面元素处理的方法及装置

Publications (2)

Publication Number Publication Date
CN102981845A true CN102981845A (zh) 2013-03-20
CN102981845B CN102981845B (zh) 2016-06-29

Family

ID=47855910

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201210454320.5A Active CN102981845B (zh) 2012-11-13 2012-11-13 浏览器进行页面元素处理的方法及装置

Country Status (1)

Country Link
CN (1) CN102981845B (zh)

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102999578A (zh) * 2012-11-13 2013-03-27 北京奇虎科技有限公司 页面元素处理方法和装置
WO2014075509A1 (zh) * 2012-11-13 2014-05-22 北京奇虎科技有限公司 浏览器进行页面元素处理的方法及装置
CN106855856A (zh) * 2015-12-08 2017-06-16 北京金山安全软件有限公司 一种信息展示方法、装置及电子设备
CN107437158A (zh) * 2016-05-26 2017-12-05 北京京东尚科信息技术有限公司 基于浏览器插件的数据查询方法和装置
CN108509189A (zh) * 2018-04-13 2018-09-07 南京新贝金服科技有限公司 一种基于dom的h5时间选择器的组件统一实现方法
CN109086114A (zh) * 2018-07-26 2018-12-25 郑州云海信息技术有限公司 一种生成web前端交互界面的方法、装置及终端
CN110597738A (zh) * 2019-09-19 2019-12-20 浪潮软件集团有限公司 一种内存释放方法、终端及计算机可读存储介质

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1310415A (zh) * 2000-02-24 2001-08-29 国际商业机器公司 基于风格表和一个目标设备的服务器端的html定制
WO2008122202A1 (en) * 2007-04-04 2008-10-16 The Hong Kong University Of Science And Technology Custom rendering of webpages on mobile devices
CN102214244A (zh) * 2011-07-07 2011-10-12 深圳市万兴软件有限公司 docx文件信息解析方法及系统
CN102999578A (zh) * 2012-11-13 2013-03-27 北京奇虎科技有限公司 页面元素处理方法和装置

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1310415A (zh) * 2000-02-24 2001-08-29 国际商业机器公司 基于风格表和一个目标设备的服务器端的html定制
WO2008122202A1 (en) * 2007-04-04 2008-10-16 The Hong Kong University Of Science And Technology Custom rendering of webpages on mobile devices
CN102214244A (zh) * 2011-07-07 2011-10-12 深圳市万兴软件有限公司 docx文件信息解析方法及系统
CN102999578A (zh) * 2012-11-13 2013-03-27 北京奇虎科技有限公司 页面元素处理方法和装置

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102999578A (zh) * 2012-11-13 2013-03-27 北京奇虎科技有限公司 页面元素处理方法和装置
WO2014075509A1 (zh) * 2012-11-13 2014-05-22 北京奇虎科技有限公司 浏览器进行页面元素处理的方法及装置
CN102999578B (zh) * 2012-11-13 2016-06-01 北京奇虎科技有限公司 页面元素处理方法和装置
CN106855856A (zh) * 2015-12-08 2017-06-16 北京金山安全软件有限公司 一种信息展示方法、装置及电子设备
CN107437158A (zh) * 2016-05-26 2017-12-05 北京京东尚科信息技术有限公司 基于浏览器插件的数据查询方法和装置
CN108509189A (zh) * 2018-04-13 2018-09-07 南京新贝金服科技有限公司 一种基于dom的h5时间选择器的组件统一实现方法
CN109086114A (zh) * 2018-07-26 2018-12-25 郑州云海信息技术有限公司 一种生成web前端交互界面的方法、装置及终端
CN110597738A (zh) * 2019-09-19 2019-12-20 浪潮软件集团有限公司 一种内存释放方法、终端及计算机可读存储介质
CN110597738B (zh) * 2019-09-19 2023-09-12 浪潮软件集团有限公司 一种内存释放方法、终端及计算机可读存储介质

Also Published As

Publication number Publication date
CN102981845B (zh) 2016-06-29

Similar Documents

Publication Publication Date Title
CN102999578A (zh) 页面元素处理方法和装置
CN102999579B (zh) 页面文本框处理浏览器和页面文本框元素处理方法
CN102981848B (zh) 网页主体元素处理浏览器和方法
CN102981845A (zh) 浏览器进行页面元素处理的方法及装置
CN108984714B (zh) 页面渲染方法、装置、电子设备及计算机可读介质
CN102981844B (zh) 对网页主体元素进行处理的浏览器及方法
US8990289B2 (en) Server based framework for improving Ajax performance
JP5480892B2 (ja) Webページ対話に基づく広告提示
US10346501B2 (en) Mobile enablement of existing web sites
CN105094786B (zh) 基于JavaScript定制页面的方法及系统
US8682964B1 (en) Progressively loading network content
CN102982161A (zh) 网页信息的获取方法和装置
CN104077387A (zh) 一种网页内容显示方法和浏览器装置
CN101876897A (zh) 用于在Web浏览器上处理Widget的系统和方法
CN103019817B (zh) 一种用于页面交互的方法与装置
US9996512B2 (en) Customized processing of DOM objects
CN102385580A (zh) 一种定制网页内容的方法和装置
CN102982162A (zh) 网页信息的获取系统
CN103034700B (zh) 富文本内容的处理方法及系统
CN102981846A (zh) 对密码输入框元素进行处理的方法及浏览器
CN103559097A (zh) 一种浏览器中进程间通信的方法、装置和浏览器
CN103177115A (zh) 一种提取网页页面链接的方法和装置
CN102981847B (zh) 对页面文本框进行处理的浏览器及方法
CN105528369B (zh) 网页转码方法、装置以及服务器
CN103034622A (zh) 富文本内容的处理方法和服务器

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant
TR01 Transfer of patent right

Effective date of registration: 20220801

Address after: Room 801, 8th floor, No. 104, floors 1-19, building 2, yard 6, Jiuxianqiao Road, Chaoyang District, Beijing 100015

Patentee after: BEIJING QIHOO TECHNOLOGY Co.,Ltd.

Address before: 100088 room 112, block D, 28 new street, new street, Xicheng District, Beijing (Desheng Park)

Patentee before: BEIJING QIHOO TECHNOLOGY Co.,Ltd.

Patentee before: Qizhi software (Beijing) Co.,Ltd.

TR01 Transfer of patent right