page_type | urlFragment | products | languages | extensions | description | ||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
sample |
office-add-in-shared-runtime-global-data |
|
|
|
This sample shows how to share data across the ribbon, task pane, and custom functions. |
This sample shows how to set up a basic project that uses the shared runtime. The shared runtime runs all parts of the Excel add-in (ribbon buttons, task pane, custom functions) in a single browser runtime. This makes it easy to shared data through local storage, or through global variables.
- Share data globally with ribbon buttons, the task pane, and custom functions.
- To get started, use a provided manifest XML file to create a new project with a shared runtime.
- Excel on Windows, Mac, and in a browser.
- Microsoft 365
Solution | Author(s) |
---|---|
Office Add-in share global data with a shared runtime | Microsoft |
Version | Date | Comments |
---|---|---|
1.0 | 3-15-2020 | Initial release |
1.1 | May 26, 2021 | Updated to use GitHub pages for hosting |
This sample enables a user to store and retrieve key/value pairs by using the task pane or custom functions. The user can select which type of storage is used. They can choose to store key/value pairs in local storage, or choose to use a global variable.
You can run this sample in Excel in a browser. The add-in web files are served from this repo on GitHub.
- Download the manifest.xml file from this sample to a folder on your computer.
- Open Office on the web.
- Choose Excel, and then open a new document.
- Open the Insert tab on the ribbon and choose Office Add-ins.
- On the Office Add-ins dialog, select the MY ADD-INS tab, choose Manage My Add-ins, and then Upload My Add-in.
- Browse to the add-in manifest file, and then select Upload.
- Verify that the add-in loaded successfully. You will see a Show Taskpane button on the Home tab on the ribbon.
Once the add-in is loaded use the following steps to try out the functionality.
- On the
Home
tab, chooseShow TaskPane
. - In the task pane, enter a key/value pair, and choose
Store key/value pair
. - In any spreadsheet cell, enter the formula
=CONTOSO.GETVALUEFORKEYCF("1")
. Pass the value of the key you created from the task pane. - In any spreadsheet cell, enter the formula
=CONTOSO.SETVALUEFORKEYCF("2","oranges")
. The formula should return the textStored key/value pair
. - In the task pane, enter the key from the previous formula
2
and chooseGet value for key
. The task pane should display the valueoranges
.
The task pane and custom function share data via a global variable in the shared runtime. You can switch the method of storage by choosing either the Global variable
or Local storage
radio buttons on the task pane.
The manifest.xml is configured to use the shared runtime by using the Runtimes
element as follows:
<Runtimes>
<Runtime resid="Shared.Url" lifetime="long" />
</Runtimes>
In other parts of the manifest, you'll see that the custom functions and task pane are also configured to use the Shared.Url
because they all run in the same runtime. Shared.Url
points to taskpane.html
which loads the shared runtime.
Global state is tracked in a window object retrieved using a getGlobal()
function. This is accessible to custom functions, the task pane, and the ribbon (because all the code is running in the same JavaScript runtime.)
There are no commands.html or functions.html files. These are not necessary because their purpose is to load individual runtimes. These do not apply when using the shared runtime.
If you prefer to host the web server for the sample on your computer, follow these steps:
-
You need http-server to run the local web server. If you haven't installed this yet you can do this with the following command:
npm install --global http-server
-
Use a tool such as openssl to generate a self-signed certificate that you can use for the web server. Move the cert.pem and key.pem files to the root folder for this sample.
-
From a command prompt, go to the root folder and run the following command:
http-server -S --cors . -p 3000
-
To reroute to localhost run office-addin-https-reverse-proxy. If you haven't installed this you can do this with the following command:
npm install --global office-addin-https-reverse-proxy
To reroute run the following in another command prompt:
office-addin-https-reverse-proxy --url http://localhost:3000
-
Follow the steps in Run the sample, but upload the
manifest-localhost.xml
file for step 6.
- Did you experience any problems with the sample? Create an issue and we'll help you out.
- We'd love to get your feedback about this sample. Go to our Office samples survey to give feedback and suggest improvements.
- For general questions about developing Office Add-ins, go to Microsoft Q&A using the office-js-dev tag.
Copyright (c) 2020 Microsoft Corporation. All rights reserved.
This project has adopted the Microsoft Open Source Code of Conduct. For more information, see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.