节内容是"VBA信息获取与处理"教程中第八个专题"VBA与HTML文档"的第五节。,希望想掌握这方面知识的朋友能参考我的教程学习。
大家好,我们继续对HTML文档进行学习,在前几节中我们认识了网页文档上面的各种元素,那么我们又该怎么访问他们呢,是如何实现呢?其实,HTML文档,提供了访问其元素的端口,这就是HTML DOM,其定义了一套标准的针对 HTML 文档的对象访问或操作的机制。HTML DOM 定义了所有 HTML 元素的对象和属性,以及访问它们的方法。换言之,HTML DOM 是关于如何获取、修改、添加或删除 HTML 元素的标准。
每个载入浏览器的 HTML 文档都会成为 Document 对象。Document 对象使我们可以从脚本中对 HTML 页面中的所有元素进行访问。Document 对象是 HTML 文档的根节点。
特别注意:Document 对象是 Window 对象的一部分,可通过 window.document 属性对其进行访问。
集合 描述
all[] 提供对文档中所有 HTML 元素的访问。
anchors[] 返回对文档中所有 Anchor 对象的引用。
applets 返回对文档中所有 Applet 对象的引用。
forms[] 返回对文档中所有 Form 对象引用。
images[] 返回对文档中所有 Image 对象引用。
links[] 返回对文档中所有 Area 和 Link 对象引用。
VBA直接支持调用的对象有限,如下:
对象 描述
Document 代表整个 HTML 文档,可被用来访问页面中的所有元素
Anchors 代表 <a> 元素集合
Body 代表 <body> 元素
Forms 代表 <form> 元素集合
Frames 代表 <frame> 元素或<iframe> 元素集合
Images 代表 <img> 元素集合
Links 代表 <link> 元素集合
Options 代表 <option> 元素集合(select元素里面可以直接使用)
Cells 代表 <td> 元素集合(table元素里面可以直接使用)
Rows 代表 <tr> 元素集合(table元素里面可以直接使用)
All 对象集合,提供对文档中所有 HTML 元素的访问。
上述VBA支持直接调用对象的元素,调用起来就非常方便了,可以用序号调用,例如forms(0),也可以按名称/ID调用,例如forms("名称/ID")。其他没法直接调用对象的元素,可以间接从通用all对象集合中去调用该元素或该元素对应的dom对象。
在HTML DOM中,所有事物都是节点。DOM 是被视为节点树的 HTML文档的每一部分都是节点,整个文档被定义为一个文档节点,每个标签是一个元素节点,包含在元素中的文本是文本节点,每一个元素的属性是一个属性节点。如下:
1)整个文档是一个文档节点
2)每个 HTML 元素是元素节点
3)HTML 元素内的文本是文本节点
4)每个 HTML 属性是属性节点
5)注释是注释节点
HTML DOM 将 HTML 文档视作树结构。这种结构被称为节点树,这时一个非常形象的比喻,根节点就是html,主干就是body等,枝干就是body内含的各种元素节点,叶子和花就是元素节点关联的元素的属性(属性节点)或内含文本(文本节点)。
通过 HTML DOM,树中的所有节点均可通过 JavaScript 进行访问。所有 HTML 元素(节点)均可被修改,也可以创建或删除节点。节点树中的节点彼此拥有层级关系。父(parent)、子(child)和同胞(sibling)等术语用于描述这些关系。父节点拥有子节点。同级的子节点被称为同胞(兄弟或姐妹)。
网页文档,可以说是由元素组合而成的,也可以说是由节点连接而成的树构造的。节点是文档树结构中特有的名词,元素是节点,但是节点不一定是元素,节点还有文档节点、文本节点、属性节点等;元素是元素节点的扩展,元素可以拥有属性还有文本。初学者不是很必要纠结元素和节点的区别,这个需要甚至数据结构、类和继承等知识。可大致理解为,同一个html dom对象,提供的两个不同接口。如下的程序,你会发现,他既有支持node(节点)的相关属性和方法,也提供了element(元素)的相关属性和方法。
Sub MYNZ()
Dim ie, dmt, bd
Set ie = CreateObject("InternetExplorer.Application") '创建一个IE对象
With ie
.Visible = True '显示它
.navigate "http://www.baidu.com" '加载某个页面
Do Until .ReadyState = 4 '等待页面加载完毕
DoEvents
Loop
Set dmt = .document '将IE浏览器加载的页面文档,赋予dmt变量
Set bd = dmt.body '将文档的body赋予bd变量
End With
End Sub
代码截图:
按F8键运行截图:
属性是节点(HTML 元素)的值,您能够获取或设置。所有 HTML 元素被定义为对象,而编程接口则是对象方法和对象属性。我们看看下面一些常见的属性:
1)innerHTML 属性 对象内部的HTML代码,是获取元素内容的最简单方法。innerHTML 属性对于获取或替换 HTML 元素的内容很有用。
下面的代码获取 id="intro" 的 <p> 元素的 innerHTML:
<script>
var txt=document.getElementById("intro").innerHTML;
document.write(txt);
2)OuterHtml:对象的HTML代码,包括对象本身的HTML标签
3)innerText:对象内部的文本
4)OuterText:对象的文本,包括对象本身的文本
5)nodeName 属性 nodeName 属性规定节点的名称。
nodeName 是只读的
元素节点的 nodeName 与标签名相同
属性节点的 nodeName 与属性名相同
文本节点的 nodeName 始终是 #text
文档节点的 nodeName 始终是 #document
注释:nodeName 始终包含 HTML 元素的大写字母标签名。
6)nodeValue 属性 nodeValue 属性规定节点的值。
元素节点的 nodeValue 是 undefined 或 null
文本节点的 nodeValue 是文本本身
属性节点的 nodeValue 是属性值
7)nodeType 属性 nodeType 属性返回节点的类型。nodeType 是只读的。
比较重要的节点类型有:
元素类型 NodeType
元素 1
属性 2
文本 3
注释 8
文档 9
以上只是给出了属性值,大家在使用的时候要注意。
本节知识点回向:
什么是HTML DOM文档的属性,常用的属性有哪些。
本节参考文件:008工作表.xlsm
在我的系列书籍中一直在强调"搭积木"的编程思路,这也是学习利用VBA的主要方法,特别是职场人员,更是要采用这种方案。其主要的内涵:
1 代码不要自己全部的录入。你要做的是把积木放在合适的位置然后去修正代码,一定要拷贝,从你的积木库中去拷贝,然后修正代码,把时间利用到高效的思考上。
2 建立自己的"积木库"。平时在学习过程中,把自己认为有用的代码放在一起,多积累,在用到的时候,可以随时拿来。你的积木库资料越多,你做程序的思路就会越广。
VBA是利用Office实现个人小型办公自动化的有效手段(工具)。这是我对VBA的应用界定。在取代OFFICE新的办公软件没有到来之前,谁能在数据处理方面做到极致,谁就是王者。其中登峰至极的技能非VBA莫属!
我记得20年前自己初学VBA时,那时的资料甚少,只能看源码自己琢磨,真的很难。20年过去了,为了不让学习VBA的朋友重复我之前的经历,我根据自己多年VBA实际利用经验,推出了六部VBA专门教程:
第一套:VBA代码解决方案 是VBA中各个知识点的讲解,教程共147讲,覆盖绝大多数的VBA知识点,初学必备;
第二套:VBA数据库解决方案 数据库是数据处理的专业利器,教程中详细介绍了利用ADO连接ACCDB和EXCEL的方法和实例操作,适合中级人员的学习。
第三套:VBA数组与字典解决方案 数组和字典是VBA的精华,字典是VBA代码水平提高的有效手段,值得深入的学习,是初级及中级人员代码精进的手段。
第四套:VBA代码解决方案之视频 是专门面向初学者的视频讲解,可以快速入门,更快的掌握这门技能。这套教程是第一套教程的视频讲解,听元音更易接受。
第五套:VBA中类的解读和利用 这是一部高级教程,讲解类的虚无与肉身的度化,类的利用虽然较少,但仔细的学习可以促进自己VBA理论的提高。这套教程的领会主要是读者的领悟了,领悟一种佛学的哲理。
第六套教程:《VBA信息获取与处理》,这是一部高级教程,涉及范围更广,实用性更强,面向中高级人员。教程共二十个专题,包括:跨应用程序信息获得、随机信息的利用、电子邮件的发送、VBA互联网数据抓取、VBA延时操作,剪切板应用、Split函数扩展、工作表信息与其他应用交互,FSO对象的利用、工作表及文件夹信息的获取、图形信息的获取以及定制工作表信息函数等等内容。
大家可以根据以上资料1→3→2→6→5或者是4→3→2→6→5的顺序逐渐深入的逐渐学习。教程提供讲解的同时提供了大量的积木,如需要可以WeChat: NZ9668
如太白诗云:众鸟高飞尽,孤云独去闲。相看两不厌,只有敬亭山。学习的过程也是修心的过程,修一个平静的心。在代码的世界中,心平静了,心情好了,身体自然而然就好。心静则正,内心里没有那么多邪知邪见,也就没有那么多妄想。利人就是利己。这些教程也是为帮助大家起航,助上我自己之力,我的上述教程是我多的经验的传递,
"水善利万物而不争",绵绵密密,微则无声,巨则汹涌。学习亦如此,知道什么是自己所需要的,不要蜷缩在一小块自认为天堂的世界里,待到暮年时再去做自欺欺人的言论。要努力提高自己,用一颗充满生机的心灵,把握现在,这才是进取。越是有意义的事情,困难会越多。愿力决定始终,智慧决定成败。不管遇到什么,都是风景。看淡纷争,看轻得失。茶,满也好,少也好,不要计较;浓也好,淡也好,其中自有值得品的味道。去感悟真实的时间,静下心,多学习,积累福报。而不是天天混日子,也不是天天熬日子。在后疫情更加严峻的存量残杀世界中,为自己的生存进行知识的储备,特别是新知识的储备。学习时微而无声,利用时则巨则汹涌。
每一分收获都是成长的记录,怎无凭,正是这种执着,成就了朝霞的灿烂。最后将一阙词送给致力于VBA学习的朋友,让大家感受一下学习过程的枯燥与执着:
浮云掠过,暗语无声,
唯有清风,惊了梦中啼莺。
望星,疏移北斗,
奈将往事雁同行。
阡陌人,昏灯明暗,
忍顾长亭。
多少VBA人,
暗夜中,悄声寻梦,盼却天明。
怎无凭!
回向学习利用VBA的历历往事,不胜感慨,谨以这些文字给大家,分享我多年工作实际经验的成果,随喜这些有用的东西,给确实需要利用VBA的同路人。
分享成果,随喜正能量
JavaScript是网络上最流行的语言。如果你曾经使用过JavaScript,那么你会知道开发和维护一个广泛的应用程序需要付出很多努力。想学习JavaScript框架的小伙伴可以参加Web前端培训,理论知识和实战项目一起学,可以获得快速提升。
那么,你使用JavaScript框架和库吗?JavaScript框架支持结构、HTTP请求等等。这是一个用于构建web应用程序的完整工具箱。Javascript库是一组简化开发过程的函数、方法或特性。
2023年最佳JavaScript前端框架和库
1.Svelte
Svelte是一个用于构建UI组件的JavaScript框架。就像React、Angular或Vue一样。但与同行不同的是,Svelte是一个编译器,同行向浏览器提供JavaScript运行时以使代码正常工作。
Svelte将你喜欢的声明性代码转换为与本机浏览器API无缝配合的命令式代码,从而在紧凑的包中生成高效的代码
2.Solid
Solid是一个声明性JavaScript框架,旨在构建快速UI,同时保持对反应性的最大控制。它由Ryan Carneto于2018年开发,因其实用性和卓越的性能而在开发者中广受欢迎。
从表面上看,Solid与React有许多相似之处,因为组件都是为UI返回JSX的JavaScript函数。然而,与React不同,它没有虚拟DOM。在Web前端培训中,有很多关于Solid框架的学习和各种技能的使用,全面系统的课程,封闭式学习,专业老师面授指导教学,可以在学习上少走很多弯路。
Solid使用一个编译器,很像Svelte,它把你的代码转换成普通的JavaScript,让你更接近DOM。
该框架本身是轻量级的,只有6.7KB,在运行时性能基准测试中表现出色,不需要在代码中使用任何额外的技巧或非传统的技巧。
最重要的是,Solid是真正反应性的,因为函数组件只被调用一次。
3.Qwik
Qwik是一个web框架,与其他框架一样,它呈现一个组件树来创建一个交互式应用程序。然而,其独特性在于其实现目标的方法。
Qwik旨在通过两个主要策略提供即时启动应用程序,甚至是在移动设备上:
l 尽可能延迟JavaScript的执行和下载。
l 在服务器上序列化应用程序和框架的执行状态,并在客户机上恢复它。
它的目标是最小化应用程序的下载和执行需求。更多关于Qwik的相关知识,可以考虑通过参加web前端培训来学习,有专业老师指导,有全面系统的课程,学起来又快又轻松。
Qwik应用程序启动很快,因为JavaScript代码执行很少。最简单的形式是,Qwik应用程序只需要1KB的JavaScript就可以实现交互。
4.React
React是一个广泛使用的JavaScript库,用于构建用户界面,由Facebook开发和维护。
它提供了一种声明式的编程方法,使开发人员更容易推断应用程序的状态并预测其行为。
React拥有强大的生态系统和社区,提供了丰富的工具、库和资源来支持开发人员创建健壮的应用程序。
React采用了组件的概念,组件是可重用的代码片段,可以很容易地组合起来构建复杂的ui。
React中的组件是返回JSX的JavaScript函数,这是JavaScript的语法扩展,类似于HTML。
JSX用于定义用户界面的结构和外观。
React的性能优化策略基于虚拟DOM,它是实际DOM的内存表示。在Web前端培训中,你会学到很多前端框架和库的使用技巧,包括React.js,提升自己的前端开发能力。
5.Vue
Vue.js是一个渐进的JavaScript框架,用于构建既可接近又通用的用户界面。它由Evan You于2014年创建,以其简单、易于集成和强大的性能而广受欢迎。
Vue.js允许开发人员构建小型到大型的应用程序,同时保持组件和逻辑之间关注点的清晰分离。
像React和Solid一样,Vue.js组件是JavaScript函数,它返回一个模板来定义UI的结构。
Vue.js使用类似HTML的模板语法,带有绑定数据和处理事件的指令。这使得阅读和理解UI的结构变得容易,即使对于那些不熟悉Vue.js的人来说也是如此。
Vue.js使用的是反应式数据系统,这意味着当数据发生变化时,UI会自动更新。
结论
总之,为你的项目选择正确的JavaScript框架取决于各种因素,如性能、易用性、学习曲线和特定需求。每个框架都有其优点和缺点,因此选择正确的框架最终取决于项目的独特需求和约束。在选择最合适的框架之前,仔细评估你的个人需求和项目需求是至关重要的,这可以确保开发过程的顺利和成功。参加web前端培训,可以帮助你快速掌握框架的使用技能,更好地进行开发工作。
项目中,我们有时需要封装一些组件,为了高内聚,我们有时可以把文件都写法一个js文件中。vite官方给我们提供了jsx写法插件 @vitejs/plugin-vue-jsx,并且可以随便找个css in js 库,这里我用@styils/vue
使用插件步骤:
npm i @vitejs/plugin-vue-jsx
npm i @styils/vue
//vite.config.js
// 引入jsx官方插件
import vueJsx from '@vitejs/plugin-vue-jsx'
export default defineConfig({
plugins: [
//更多配置看github
vueJsx({
include:/\.[jt]s$/
})
]
})
示例:
// App.vue
<template>
<div>
<el-button @click="Alerst" type="primary">弹框</el-button>
</div>
</template>
<script setup>
import { alert } from './utils/Alert'
const messageProp = '弹出框数据'
const Alerst = () => {
alert(messageProp)
}
</script>
// src/utils/Alert/index.js
import { render } from 'vue'
import { styled } from '@styils/vue';
export const alert = (propsData) => {
//创建一个有样式div
const Mydiv = styled('div', {
position: "fixed",
top: '50%',
left: '50%',
transform: 'translate(-50%,-50%)',
})
const container = document.createElement('div')
document.body.appendChild(container)
const VNode = (
<Mydiv> //替换原来没有样式的<div>
<h1>登录成功</h1>
<p>{propsData}</p>
<button onClick={() => {
container.remove();
}}>关闭</button>
</Mydiv>
)
render(VNode, container)
}
效果
*请认真填写需求信息,我们会在24小时内与您取得联系。