gpt4 book ai didi

excel - 在 Excel Online 中,OfficeJS API 不再将 host_Info_ 参数传递给 Excel 加载项

转载 作者:行者123 更新时间:2023-12-05 01:03:59 27 4
gpt4 key购买 nike

我不知道这是什么时候开始发生的,或者事情是否发生了变化,但是 _host_Info 参数没有被框架传递到我在 Excel Online 中的 Excel 加载项。

它传递一个空的 "et=" 参数,这在这种情况下是可以的,因为我处于开发模式。 Excel 桌面客户端仍然通过它。

这是我的加载项在 Excel Online 和 Excel for Windows 之间切换功能所必需的。

我检查了文档,但没有发现任何更改。

最佳答案

补充 Sudhi 的回答:根据 Sudhi 回答中的链接提供官方 API,我们已经继续并在 OfficeJsHelpers 中为 API 添加了一个“垫片”。图书馆。

shim 仍然使用 Sudhi 提到的解决方法代码 -- window.sessionStorage['hostInfoValue'] -- 但它将它包装在一个与官方 Office 中非常相似的 API 中。 js。一旦官方 API 可用,我们将切换 shim 代码以使用它。这种方法的美妙之处在于,如果你通过 NPM 包使用 OfficeJsHelpers,你所要做的就是更新你的包依赖,你会突然从一个非官方的和潜在脆弱的解决方法变成一个 100% 官方依赖的 API -公开的属性——所有这些都无需更改您自己的代码!同样,如果那时您决定切换回使用官方 Office.js 版本,API 的相似性(本质上只是 namespace 差异)应该使切换实现变得微不足道。

帮助程序 API 是 OfficeHelpers.Utilities.host(它将返回 WORDEXCEL 等。 ) 和 OfficeHelpers.Utilities.platform(将返回 IOSPCOFFICE_ONLINE,或 MAC)。这些常量在 OfficeHelpers.HostTypeOfficeHelpers.PlatformType 中定义。

您可以在 https://www.npmjs.com/package/@microsoft/office-js-helpers 找到 NPM 包,然后通过 NPM 安装它,或者使用像 Unpkg 这样的 CDN 来快速试用它:https://unpkg.com/@microsoft/office-js-helpers@0.4.2/dist/office.helpers.min.js

console.log(OfficeHelpers.Utilities.host);
console.log(OfficeHelpers.Utilities.platform);

if (OfficeHelpers.Utilities.platform === OfficeHelpers.PlatformType.OFFICE_ONLINE) {
console.log("Yep, I'm on the web client");
}

作为临时措施,我希望以上内容对您有所帮助,一旦官方 API 发布,我们一定会更新此 StackOverflow 线程(和 OfficeJsHelpers 代码)。

关于excel - 在 Excel Online 中,OfficeJS API 不再将 host_Info_ 参数传递给 Excel 加载项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40688057/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com