发布在即!企业 AIGC 应用程度测评,3 步定制专属评估报告。抢首批测评权益>>> 了解详情
写点什么

在 Microsoft Word 中,Node 是如何替代宏的

  • 2016-04-05
  • 本文字数:1861 字

    阅读完需:约 6 分钟

最近的 30 年来,宏(macros)成为了 Microsoft Word 的关键卖点。WordBASIC 最初是在 1989 年引入的,它能够让受过极少培训的打字员都能进行计算机编程,从而简化他们的日常工作。

在那个时代,竞争非常激烈。除了 Word,还有 WordStar 和后来居上的 WordPerfect,它们都有自己的宏编程语言。随着竞争的持续,业务用户的需求越来越多,更新也变得非常频繁。

在上世纪 90 年代末期,发生了一些有意思的事情。Microsoft 创建了 Visual Basic for Applications(VBA),这个语言具有(有限的)OOP 能力以及与其相匹配的 IDE,用以替代 WordBASIC,它所创建的并不仅仅是另外一个嵌入式组件。最初的时候,Microsoft 预期将这项技术用在所有的 MS Office 产品之中,随后他们意识到可以对这项技术进行许可认证。很快,众多的公司都提供了对 VBA 的支持,包括 ArcGIS AutoCAD SolidWorks CorelDraw ,甚至还有 WordPerfect

在世纪之交不久,人们就看到了宏的大幅下滑。所谓的“宏病毒”造成了严重的破坏。因为它们隐藏在 Word 文档中,所以病毒扫描器很难发现它们。

作为回应,Microsoft 锁定了 VBA 编程接口。它依然很强大,但是关闭了安全功能,所以使用它实际上很有挑战性。大多数的病毒扫描器会拒绝所有通过 email 共享的带有宏的文档。

尽管它处于下滑的状态之中,Visual Basic for Applications 依然还是存在的。最新的 7.1 版本是在 2013 年发布的,并且从 2010 年开始它就有 64 位版本了。但是随着基于 Web 的字处理器变得越来越流行,VBA 也似乎走入了死胡同。它基于上世纪 90 年代的 COM 技术,并没有可行的方案将其放到 Web 应用中。随着人们逐渐将语言从 BASIC 替换为 JavaScript,再创建一个“Web 版本的 VBA”显得就有点不合时宜了。

.NET 与 Office

为了让人们放弃过时的 VBA 技术,Microsoft 还创建过 Visual Studio Tools for Office(VSTO)。这个开发工具集和库不仅能够创建 Office 插件,还允许独立的应用操纵 Office 文档。

至少在理论上是这样的。但实际上,在这两方面 VSTO 都失败了。

普通的程序员并不想要安装 Visual Studio 并从头开始创建 Office 插件。他们想要录制一个宏,然后对其修改以满足他们的需求。培训学习的成本从“编辑直到可用为止”变成了完全从头开始,这是难以承受的。

另外,还有版本的问题。VBA 风格的宏会存储为纯文本,这意味着只要你不使用只有新版本才有的特性的话,你所编写的代码能够用到任意版本的 Office 之中。而编写 VSTO 插件时,你需要针对特定的 Office 版本进行编程。这意味着开发人员只能使用公司中最老的版本。

另一方面,专业的开发人员对插件基本上没有太大的兴趣。他们希望构建使用和 / 或生成文档的服务器。VSTO 基于 COM 的自动化,这意味着在做实际的工作之前,首先要有 Word 或 Excel 的一个副本。对于 Web 站点的每个用户,都要运行一个重量级桌面应用的副本,这种做法显然是站不住脚的。

与 VBA 类似,我们实际上无法在基于浏览器的 Web 处理器上使用 VSTO。

使用 Node 构建 Office 的 Add-In

如我们前文所述,JavaScript 现在已经成了通用的编程语言。业余爱好者(以及类似的专业开发人员)不想要或不喜欢重量级的 IDE,如 Eclipse 或 Visual Studio,于是 Node 变成了他们的开发平台。所以,Microsoft 选择这些工具来构建 Office add-in,我们也不应该感到意外。

首先,我们需要安装 Node。然后从命令行中,运行下面的两条命令:

复制代码
npm install -g tsd bower gulp yo generator-office
yo office

yeoman generator 会询问我们想要构建哪种类型的 add-in(ribbon command、 task pane 等)、支持哪些 Office 产品以及想要使用 Angular 还是纯 HTML/JavaScript 进行构建。接下来需要执行的命令就是搭建本地的服务器,用来托管你的 add-in。

gulp serve-static这是用于基本的冒烟测试的,对于实际环境来说,你需要在 Web 上运行 Office。在打开一个空文档之后,可以上传 add-in 的 manifest,然后查看它的实际效果。

你可能会问,既然要上传 manifest,为什么还要启动本地服务器呢?这是因为 manifest 在你的电脑同时运行 Office 的时候,它就允许浏览器从电脑上加载 add-in。在实践中,这意味着你可以修改 add-in,点击浏览器的刷新按钮,就能马上看到实际的效果,不需要在每次变化之后都重新上传 add-in。

因为这是一个 Web 应用,所以可以使用浏览器内置的调试工具进行调试。

要看实际效果的话,可以观看 Harrison Shapley 的 Build Office Add-ins with Any Code Editor and Office Online 演示。

查看英文原文: How Node Replaced Macros in Microsoft Word

2016-04-05 19:002993

评论

发布
暂无评论
发现更多内容

一文让你知道等保测评和渗透测试的区别与联系

行云管家

信息安全 渗透测试 等级保护 等保测评

你了解Vue3组合式API吗?

OpenTiny社区

Vue 前端框架 开源组件库

在langchain中使用带简短知识内容的prompt template

程序那些事

人工智能 AI 程序那些事 AI大语言模型 大语言模型

Inpaint Anything:一键进行多种图像修补

华为云开发者联盟

人工智能 华为云 华为云开发者联盟 企业号 7 月 PK 榜

从税务管理的数智化转型之路中我们能看到什么?

用友BIP

税务管理

Cloud Kernel SIG 月度动态:支持龙芯和申威架构,合入两个内存新特性

OpenAnolis小助手

开源 架构 内存 内核 龙蜥sig

@开源技术爱好者,龙蜥邀您一起玩转系统运维 MeetUp

OpenAnolis小助手

Linux 系统运维 ebpf Meetup 龙蜥社区

用Rust生成Ant-Design Table Columns | 京东云技术团队

京东科技开发者

rust swagger 企业号 7 月 PK 榜 Columns

英特尔合作埃森哲推出一套共计34个开源AI参考套件

E科讯

金山云与平凯星辰达成全面战略合作 技术创新模式助力企业数字化转型

PingCAP

金山云 数字化 TiDB pingCAP 平凯星辰

值得关注的五个先进代码补全服务

这我可不懂

人工智能 代码补全

一键登录教你如何解决APP通讯诈骗问题

MobTech袤博科技

App

【从零开始学爬虫】采集全国各行业经销商网点数据

前嗅大数据

大数据 爬虫 数据采集 爬虫教程 爬虫入门

HTML5智慧景区三维可视化管理平台

2D3D前端可视化开发

智慧景区 智慧旅游 景区三维可视化 数字景区 智慧景区系统

架构训练营模块一作业

Kleven

架构实战营

伙伴云「页面」上线!网站、博客、资源库、文档、周报,拖拽即刻实现

联营汇聚

再获权威认可!MIAOYUN荣获中国信通院一云多芯优秀案例,荣登《云管理产品与服务图谱》

MIAOYUN

中国信通院 一云多芯解决方案 一云多芯 可信云大会 云管理产品与服务图谱

AREX:携程新一代自动化回归测试工具的设计与实现

AREX 中文社区

开源 测试工具 回归测试 流量回放

前端程序员入门:先学Vue3还是Vue2?

互联网工科生

vue.js Vue 前端

四步法建立企业内部人才市场

用友BIP

人力资源

暑假提升休闲两不误,与华为阅读一起开启高质量听书

最新动态

暑期读书指南 | 用缤纷字体读精品好书,华为阅读上新啦!

最新动态

一文帮你全面认识方天视窗引擎

openEuler

Linux 开源 操作系统 openEuler 视窗引擎

并发编程-FutureTask解析 | 京东物流技术团队

京东科技开发者

并发编程 源码剖析 FutureTask 企业号 7 月 PK 榜

大型企业数智化转型,工程化体系建设至关重要

用友BIP

数智底座

资源成本降低70%!华为MetaERP资产核算的Serverless架构实践

华为云开发者联盟

云计算 后端 华为云 华为云开发者联盟 企业号 7 月 PK 榜

【观察】智能运维的“下半场”,看云智慧如何“开新局”

云智慧AIOps社区

算法 运维 智能运维 大模型 IT运维

MySQL 的解析器以及 MySQL8.0 做出的改进 | StoneDB技术分享 #2

StoneDB

MySQL 数据库 HTAP StoneDB

灵动AI推出业内首个工业级“AI商品图”生成工具 并获小米联合创始人黎万强天使投资

TE智库

长连接:ChatGPT流式响应背后的逻辑 | 京东物流技术团队

京东科技开发者

websocket 长连接 企业号 7 月 PK 榜 sse

用友发布业界首个企业服务大模型YonGPT

用友BIP

在Microsoft Word中,Node是如何替代宏的_.NET_Jonathan Allen_InfoQ精选文章