About three years ago I bought a domain name, intending, as always, to launch a project with it. Here we are three years later and I've done exactly no work on the project ¯_(ツ)_/¯
To practice some JavaScript, I decided to explore Unsplash's API to create an interactive placeholder in the meantime.
Breaking it down
const numItemsToGenerate = 1;
This just sets us up for the number of items we’ll request from the service.
function renderItem(){
fetch(`https://source.unsplash.com/1600x900/?beach`).then((response) => {
let item = document.createElement('div');
item.classList.add('item');
item.innerHTML = `<img class="beach-image" src="${response.url}" alt="beach image"/>`
document.body.appendChild(item);
})
}
This actually pulls the photo in and passes it to the div
it created (item
). In the URL https://source.unsplash.com/1600x900/?beach
you could remove the slug or input another search term instead. Use their documentation to further customize, including images from specific users, particular sizes of image, or lots of other parameters.
Because I just wanted to set the image as the full background, I’m appending the img
to innerHTML
, rather than targeting a particular div or section on the page.
If you wanted to target a specific ID or class, you’d add something like this to the script:
let item = document.getElementByID('existing');
item.existing = `<img class="beach-image" src="${response.url}" alt="beach image"/>`
Then to pass through and render the image:
for(let i=0;i<numItemsToGenerate;i++){
renderItem();
}
In retrospect
At first, it was wild to think about using JS only and not building in any HTML to display the image, so first I tried building a div
into the HTML body. I tried using class names and setting IDs, and I couldn't seem to target it, so I flipped to this different strategy using a tutorial as a guide.
Once I got the API working and displaying, the image dimensions were wild - turns out I was including the image dimensions in the source URL, so I pulled that out and created a CSS class for img
since there was only going to be one displaying.
I made this just as a way to practice JavaScript and generate random images that would make me happy to look at. It's also the first time I've explored an API or read up on documentation for a purpose other than proofing/editing/writing.
In revisiting it now, I'm seeing another way I could have set the image as the body-background
rather than creating a div
and using a CSS class to size the photo which is kind of exciting - I'm ~ learning ~!
Top comments (7)
Nice! I just used Lorem Picsum for a quick mess around pen I did but I like the idea of using Unsplash API for learning, going to have to give it a try.
Unsplash's is basically the same, looks like, I just really wanted beachy photos!
Came up with an idea with co-workers the other day to build a custom lorem picsum similar to fillmurray.com/ but featuring someone else. Maybe someday I'll find the time!
My only issue with Picsum is that it pulls the same image in each place I am using it. I was hoping it would display a random one each time :(
fillmurray is great, never seen it before, makes me want to do the same! I think my favorite part of the site though is that they use the Crazy Nic Cage pic for the favicon!
Co-creator of picsum.photos here! 👋
You can actually have the image change by appending a cache-busting query string to the end:
Here is a demonstration! ✨
Oh dang, nice! Thanks for the heads up!
nice! ty. unfortunately the official unsplash API is quite restrictive for public requests. Could get my random pic with searchterm now, at least 😌 but without author field and very little data in general :(
This is great! Thanks!