Shantha Kumar T
Get List based on url using PnP JavaScript Library
In this blog, we are going to see how to get the list based on the url using PnP JavaScript component.
To know more about this JavaScript library, check the below links
JavaScript Example:
The below steps and code snippets used to get the SharePoint list based on url using PnP JavaScript library,
- Download Required files to use PnP-JS-Core library from the below links and upload that to Site Asstes or Style Library
- Download pnp.js PnP JS file
- Download fetch.js Used by PnP js file to handle web requests and responses (Required in IE)
- Download promise.js Used by PnP js file to handle web requests and responses (Required in IE)
- Create new web part page and insert Content Editor web part
- Create a sample.html file in Site Assets or Style library and insert the below code snippet
[code lang=”js”]
<script type="text/javascript" src="/siteassets/scripts/fetch.js"></script>
<script type="text/javascript" src="/siteassets/scripts/promise.min.js"></script>
<script type="text/javascript" src="/siteassets/scripts/pnp.min.js"></script>
<span id="listInfo"></span>
<script type="text/javascript">
//web.getList(‘<RelativeURL>’) returns the SharePoint list based on the relative url
$pnp.sp.web.getList("/sites/development/Lists/sample")
.get().then(function(data) {
console.log(data);
document.getElementById("listInfo").innerHTML = "List is available.";
}).catch(function(err) {
console.log("Error: " + err);
document.getElementById("folderInfo").innerHTML = "Error in getting List: " + err;
});
</script>
[/code]
- On Success, it returns the list information.
- On Failure , the code returns the below exception
ProcessHttpClientResponseException: Error making HttpClient request in queryable: [404] Not Found
Typescript Example:
Typescript is the superset of JavaScript and this PnP JS library is developed using the typescript specification. For developing the SharePoint Framework web parts and make the client side development easier, we can vote for typescript. The below is the typescript example for getting the SharePoint List based on relative url.
[code lang=”js”]
import pnp from "sp-pnp-js";
pnp.sp.web.getList("/sites/development/Lists/sample").get().then(data => {
this.domElement.querySelector("#listInfo").innerHTML = "List is available"
}).catch(err => {
this.domElement.querySelector("#listInfo").innerHTML = "Error in getting List: "+ err
});
[/code]
Promise.js url gives 404 error
URL was changes, so use the link below for promise.js
https://github.com/stefanpenner/es6-promise/blob/master/dist/es6-promise.js
Interesting ! This article is a blessing in disguise .
Legend. Thank you very much. The official documentation skips this.