- 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/
SQLite、Content provider 和 Shared Preference 之间的所有已知区别。 但我想知道什么时候需要根据情况使用 SQLite 或 Content Provider 或
警告:我正在使用一个我无法完全控制的后端,所以我正在努力解决 Backbone 中的一些注意事项,这些注意事项可能在其他地方更好地解决......不幸的是,我别无选择,只能在这里处理它们! 所以,我的
我一整天都在挣扎。我的预输入搜索表达式与远程 json 数据完美配合。但是当我尝试使用相同的 json 数据作为预取数据时,建议为空。点击第一个标志后,我收到预定义消息“无法找到任何内容...”,结果
我正在制作一个模拟 NHL 选秀彩票的程序,其中屏幕右侧应该有一个 JTextField,并且在左侧绘制弹跳的选秀球。我创建了一个名为 Ball 的类,它实现了 Runnable,并在我的主 Draf
这个问题已经有答案了: How can I calculate a time span in Java and format the output? (18 个回答) 已关闭 9 年前。 这是我的代码
我有一个 ASP.NET Web API 应用程序在我的本地 IIS 实例上运行。 Web 应用程序配置有 CORS。我调用的 Web API 方法类似于: [POST("/API/{foo}/{ba
我将用户输入的时间和日期作为: DatePicker dp = (DatePicker) findViewById(R.id.datePicker); TimePicker tp = (TimePic
放宽“邻居”的标准是否足够,或者是否有其他标准行动可以采取? 最佳答案 如果所有相邻解决方案都是 Tabu,则听起来您的 Tabu 列表的大小太长或您的释放策略太严格。一个好的 Tabu 列表长度是
我正在阅读来自 cppreference 的代码示例: #include #include #include #include template void print_queue(T& q)
我快疯了,我试图理解工具提示的行为,但没有成功。 1. 第一个问题是当我尝试通过插件(按钮 1)在点击事件中使用它时 -> 如果您转到 Fiddle,您会在“内容”内看到该函数' 每次点击都会调用该属
我在功能组件中有以下代码: const [ folder, setFolder ] = useState([]); const folderData = useContext(FolderContex
我在使用预签名网址和 AFNetworking 3.0 从 S3 获取图像时遇到问题。我可以使用 NSMutableURLRequest 和 NSURLSession 获取图像,但是当我使用 AFHT
我正在使用 Oracle ojdbc 12 和 Java 8 处理 Oracle UCP 管理器的问题。当 UCP 池启动失败时,我希望关闭它创建的连接。 当池初始化期间遇到 ORA-02391:超过
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 9 年前。 Improve
引用这个plunker: https://plnkr.co/edit/GWsbdDWVvBYNMqyxzlLY?p=preview 我在 styles.css 文件和 src/app.ts 文件中指定
为什么我的条形这么细?我尝试将宽度设置为 1,它们变得非常厚。我不知道还能尝试什么。默认厚度为 0.8,这是应该的样子吗? import matplotlib.pyplot as plt import
当我编写时,查询按预期执行: SELECT id, day2.count - day1.count AS diff FROM day1 NATURAL JOIN day2; 但我真正想要的是右连接。当
我有以下时间数据: 0 08/01/16 13:07:46,335437 1 18/02/16 08:40:40,565575 2 14/01/16 22:2
一些背景知识 -我的 NodeJS 服务器在端口 3001 上运行,我的 React 应用程序在端口 3000 上运行。我在 React 应用程序 package.json 中设置了一个代理来代理对端
我面临着一个愚蠢的问题。我试图在我的 Angular 应用程序中延迟加载我的图像,我已经尝试过这个2: 但是他们都设置了 src attr 而不是 data-src,我在这里遗漏了什么吗?保留 d
我是一名优秀的程序员,十分优秀!