- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
将 Excel 加载项提交到 Office 商店时。 list 文件中应引用哪个版本的 Excel API?
我们经历过因为没有引用最新版本的 Excel API 而被拒绝的经历。但是如果我们的 Excel 加载项支持旧版本的 API。我们不应该引用这个吗?
最佳答案
Office.js 库的版本控制有几个方面。
首先,是实际 JavaScript 源文件的版本控制。幸运的是,这部分非常简单:您总是想要最新最好的 Office.js 产品,可以通过我们的 CDN 方便地获得:https://appsforoffice.microsoft.com/lib/1/hosted/Office.js .这些文件也作为 NuGet 包提供,以允许企业防火墙开发,但 NuGet 可能比 CDN 滞后几周——无论如何,需要任何存储绑定(bind)的加载项引用 CDN 位置。因此,就 Office.js 版本而言,那里并没有真正的版本控制:只有一个且唯一的常青、经常更新、始终向后兼容、商店需要的 CDN 版本。
(关于 CDN 的主题:我们还有一个 beta CDN,可在 https://appsforoffice.microsoft.com/lib/beta/hosted/Office.js 获得。这个非常适合测试新实现但尚未正式标记为完成的功能,您将在我们的开放规范中找到:http://dev.office.com/reference/add-ins/openspec。但是,其中的任何新 API 都应被视为严格的“测试版”,它们很可能会被重命名、重新分组或推迟——因此您的应用不应依赖它们,因为我们明确保留在 beta 分支上打破 pack-compat 的权利。一个 API 在 IntelliSense ande 文档中被列为完整之前,直到它在生产 CDN 上可用,*并且直到它的 isSetSupported
返回 true
—— 稍后会详细介绍)。
版本控制更有趣的一点是每个主机提供的实际 API 功能。 Office.js 库将具有最新的 JS 代码以能够运行它们,但较旧的主机可能无法支持某些功能。例如,如果您查看 https://dev.office.com/reference/add-ins/requirement-sets/excel-api-requirement-sets ,您将看到 2016 年的 Excel API 浪潮——分组在“ExcelApi”要求集下——迄今为止有三个版本:1.1、1.2 和 1.3。 ExcelApi 1.1 是 2015 年 9 月随 Office 2016 RTM 一起提供的; 1.2 2016年3月上旬发货;和 1.3 刚刚发布,并且正在向 CDN 推出。每个 API 集版本都有一个对应的 Office 主机版本支持这个 API 集(对于大多数 API,必须同时有 JS 和主机端的更改;很少有东西可以是纯 JS 的添加)。版本号列在表中,表下方有链接可找到从内部版本号到日期的映射。
每个 API 集版本都包含许多相当大的功能,以及对现有功能的增量改进。每个需求集的主题(如上面的链接)将提供每个功能的详细列表。在编程时,如果您使用的是 JavaScript 或 TypeScript IntelliSense,您应该能够看到作为 IntelliSense 的一部分显示的每个 API 的 API 版本:
您可以通过以下两种方式之一使用需求集。您可以在 list 中声明“我需要 API 集 ExcelApi 1.2,否则我的加载项根本不起作用”——这很好,但是当然您无法为旧主机提供服务,因此您的加载项甚至不会出现在那里。或者,如果您的加载项可以sorta在 1.1 环境中工作,但您希望在支持它的较新主机上点亮其他功能,您可以使用 list 仅声明所需的最小 API 集(例如 ExcelApi 1.1),然后通过 isSetSupported
API 对更高版本号进行运行时检查。 Neat ways to get environment (i.e. Office version)对此 isSetSupported API 检查有非常详细的解释。
希望这对您有所帮助!
关于office-addins - 为 Office 应用商店提交加载项时,应在 list 文件中引用哪个版本的 Excel API?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40845130/
我对 React 真的很陌生,需要问。 我可以有一个 ReactJs Redux store在库中,然后在也有 Redux 商店的应用程序中使用该库? 他们俩都这样做: ..A
我有两个商店版本的 Magento 安装:商店 A 和商店 B。当您转到“mydomain.com”时,我收到以下错误消息: 'There was no Home CMS page configure
我有一个按钮,单击该按钮时,将使用提供的 url 创建一个 JSONstore。然后将商店加载到网格中。如果再次单击该按钮,它会再次添加所有信息(因此会列出两次)。我想要这样,当用户单击按钮时,它会清
已结束。 这个问题是 off-topic .它目前不接受答案。 想要改进这个问题? Update the question所以它是on-topic堆栈溢出。 关闭 9 年前。 Improve this
我在 main.js 中进行 session API 调用,并将响应中的值用作我的根存储的初始值。在 vuex 中,它是这样处理的, DataService.getSession() .then(
我正尝试在 Svelte 商店中维护实时股票报价,以便屏幕上的出价和要价实时更新。我不确定商店的结构如何来保持数据的 react 性和效率。数据来自 websocket,如下所示: {'symbol'
将 Magento 商店从企业版 1.10.1.1 降级到社区版 1.7.0.0 应遵循什么程序? 我做的步骤是: 备份 Magento EE 1.10.1.1 数据库 :) 将此数据库导入到一个名为
我试图在过去 2 天使用内部应用程序共享上传我的应用程序,但无论我做什么,我都无法让它工作。这就是我所做的: 在控制台中,我点击了应用 -> 发布 -> 内部应用共享 我上传了 apk 我将自己添加到
现在的情况: 我有一个实时系统并且运行良好。 我没有测试系统。 我们的实时系统是一个多商店,在一个网站上有多个商店 View 。 问题: 我需要再添加一个 storeview 并在该 livesyst
我正在建立一个拥有零售店和批发商商店的网站。每个产品中的产品都不同,因此不仅仅是针对用户类型调整定价的问题。我需要保护批发部分的密码,以便它只对登录用户可用。我正在使用一个模块来实现这一点,但它只适用
我在应用商店上有几个应用程序,我每天都会检查所有可用的国家/地区,看看是否有人对我的应用程序留下了评论以及它在付费评级最高的位置中处于什么位置。 花时间看 iTunes 变得非常无聊。但我得到的信息非
我正在从 appsettings.json 加载配置文件,其中保存了 api url。 我已经建立了带有效果的ngrx 7商店。我在 app.component.ts onInit 中调度 loadc
我正在尝试为 Angular ngrx 存储架构中的操作编写 reducer : 这是我的 reducer : export const registration = (state: any, {ty
我创建了一个 Windows 商店应用程序,并使用 Visual Studio IDE 将其与商店相关联。在 Visual Studio IDE 中有用于创建应用程序包和上传应用程序包的菜单选项。 我
我有这个代码可以过滤我的商店 onLicenseGridSelect: function(rowmodel, record, index, eOpts) { Ext.getStore('Lic
我已将应用程序发布到 Play 商店。问题是我的应用程序的标题是 XXX YYY,但是当我输入 XXX YYY 时,搜索列表/索引中没有应用程序,但是如果我输入 XXXYYY,我可以找到我的应用程序。
我需要将所有翻译从主存储导出到另一个。 最佳答案 导出数据库中core_translate 表的内容。您可以为此使用 phpmyadmin。 关于php - 如何将内联翻译导出到另一个 Magento
我正在尝试将某些组件 (USERS) 连接到我的商店。我将向您展示每个步骤。 首先我在 index.js 中创建我的商店: // composeWithDevTools helps to follow
我不久前问过这个问题,并大致了解了商店的用途以及为什么使用它的基本解释。 但是,我目前正在为我的公司开发一个网络应用程序,并且遇到了一些计算问题。 首先,我有大约 35 个数据变量。一次只使用其中的几
我是 ngrx 的新手,我只是想了解它,让它工作起来。 我已将 ngrx(8.3 版)添加到我的应用程序中。 我希望有一些东西处于根状态(如果可能的话),然后我的每个功能都有单独的状态。我从根状态开始
我是一名优秀的程序员,十分优秀!