mirror of
https://github.com/pnp/sp-dev-fx-webparts.git
synced 2025-03-02 01:39:21 +00:00
95 lines
4.0 KiB
Markdown
95 lines
4.0 KiB
Markdown
---
|
|
page_type: sample
|
|
products:
|
|
- office-sp
|
|
languages:
|
|
- javascript
|
|
- typescript
|
|
extensions:
|
|
contentType: samples
|
|
technologies:
|
|
- SharePoint Framework
|
|
platforms:
|
|
- react
|
|
createdDate: 5/1/2017 12:00:00 AM
|
|
---
|
|
# Using @pnp/js with Async / Await
|
|
|
|
## Summary
|
|
|
|
This web part demonstrates how to use [PnPJS](https://pnp.github.io/pnpjs/) with Async functions into the SharePoint Framework.
|
|
|
|
data:image/s3,"s3://crabby-images/ad59b/ad59bc85ba5406c5cbf207fce844b434844a11a1" alt="React-sp-pnp-js-async-await"
|
|
|
|
## Compatibility
|
|
|
|
## Compatibility
|
|
|
|
data:image/s3,"s3://crabby-images/675bb/675bb6cda155771cd0d51c201bac660ed9a9d639" alt="SPFx 1.4.1"
|
|
data:image/s3,"s3://crabby-images/b872e/b872e9b9def32e8599ffb9f9eca479de70553f12" alt="Node.js v8 | v6"
|
|
data:image/s3,"s3://crabby-images/9ca92/9ca9207d6801960ecc232c1d1a932bfb8a5b0a72" alt="Compatible with SharePoint Online"
|
|
data:image/s3,"s3://crabby-images/b7a9a/b7a9aab069d6b6648091284cc0cb4f035ff425cf" alt="Incompatible with SharePoint 2019"
|
|
data:image/s3,"s3://crabby-images/bd6e3/bd6e33c0870d7cea8429bb78022804578f728b10" alt="Does not work with SharePoint 2016 (Feature Pack 2)"-Incompatible-red.svg "SharePoint Server 2016 Feature Pack 2 requires SPFx 1.1")
|
|
data:image/s3,"s3://crabby-images/6be2b/6be2bd3871d3fd1871cd79b95f9c27a55de54d6a" alt="Local Workbench Incompatible"
|
|
data:image/s3,"s3://crabby-images/13e48/13e4863bd19741b938310439c46d49f126de264a" alt="Hosted Workbench Compatible"
|
|
data:image/s3,"s3://crabby-images/a0418/a0418a71b86ae7090f2fafc18d313a85da48929a" alt="Compatible with Remote Containers"
|
|
|
|
## Applies to
|
|
|
|
* [SharePoint Framework](https://docs.microsoft.com/sharepoint/dev/spfx/sharepoint-framework-overview)
|
|
* [Microsoft 365 developer tenant](https://docs.microsoft.com/sharepoint/dev/spfx/set-up-your-developer-tenant)
|
|
|
|
## Solution
|
|
|
|
Solution|Author(s)
|
|
--------|---------
|
|
react-async-await-sp-pnp-js | Jose Quinto ([@jquintozamora](https://twitter.com/jquintozamora) , [blog.josequinto.com](https://blog.josequinto.com))
|
|
Version 2 refactored as purely a PnPjs sample by Julie Turner ([@jfj1997](https://twitter.com/jfj1997))
|
|
|
|
## Version history
|
|
|
|
Version|Date|Comments
|
|
-------|----|--------
|
|
2.0|Jan 13, 2022|Updated to SPFx 1.14 & PnPjs version 3 & removed logging sample.
|
|
1.2|Jul 20, 2018|Replaced deprecated sp-pnp-js with @pnp/js
|
|
1.1|Mar 6, 2018|Update to 1.4.1
|
|
1.0|May 1, 2017|Initial release
|
|
|
|
## Minimal Path to Awesome
|
|
|
|
1. clone this repo
|
|
1. `$ npm i`
|
|
1. Update online workbench url in the `initialPage` property of the `config/serve.json` file.
|
|
1. `$ gulp serve`
|
|
|
|
> This sample can also be opened with [VS Code Remote Development](https://code.visualstudio.com/docs/remote/remote-overview). Visit https://aka.ms/spfx-devcontainer for further instructions.
|
|
|
|
### Local Mode
|
|
|
|
A browser in local mode (localhost) will be opened.
|
|
https://localhost:4321/temp/workbench.html
|
|
|
|
### SharePoint Mode
|
|
|
|
If you want to try on a real environment, open:
|
|
https://your-domain.sharepoint.com/_layouts/15/workbench.aspx
|
|
|
|
## Usage
|
|
|
|
data:image/s3,"s3://crabby-images/de2eb/de2eb6dba331e45e4937fc01aaf8ca5341aa1faa" alt="React-sp-pnp-js-async-await-code"
|
|
|
|
## Features
|
|
|
|
* [Async / Await functionality working with PnP JS sample](https://github.com/jquintozamora/spfx-react-async-await-sp-pnp-js/blob/master/src/webparts/asyncAwaitPnPJs/components/AsyncAwaitPnPJs.tsx#L93)
|
|
* Tested and working on IE11 (as TypeScript config provides Promise polyfill)
|
|
* React Container for the initial load. [Smart Component](https://github.com/jquintozamora/spfx-react-async-await-sp-pnp-js/blob/master/src/webparts/asyncAwaitPnPJs/components/IAsyncAwaitPnPJsState.ts)
|
|
* [Interface best practices](https://github.com/jquintozamora/spfx-react-async-await-sp-pnp-js/tree/master/src/webparts/asyncAwaitPnPJs/interfaces)
|
|
* [PnP JS and SPFx Logging systems integration](https://blog.josequinto.com/2017/04/30/how-to-integrate-pnp-js-core-and-sharepoint-framework-logging-systems)
|
|
data:image/s3,"s3://crabby-images/b612f/b612f66fa7e2a2b38518a936ce4e1a316ad6e450" alt="React-sp-pnp-js-async-await-code"
|
|
|
|
## Disclaimer
|
|
|
|
**THIS CODE IS PROVIDED *AS IS* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING ANY IMPLIED WARRANTIES OF FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABILITY, OR NON-INFRINGEMENT.**
|
|
|
|
<img src="https://pnptelemetry.azurewebsites.net/sp-dev-fx-webparts/samples/react-async-await-sp-pnp-js" />
|