Instafeed is a simple way to display your Instagram photos on your website.
We're in the process of launching instafeed.js v2, powered by the new Instagram Basic Display API. Guides and documentation are being created and will be added to the project's wiki.
See the v2 migration guide for help on updating from v1, or a basic demonstration with code examples.
For the now-non-functional v1.x library, please see the Legacy API branch.
Setting up Instafeed is pretty straight-forward - there are 3 main steps.
- Create a Facebook app linked to Instagram, and add yourself as a test user. See Managing User Tokens.
- Create an access token and provide it to an Instagram Token service
- Add the instafeed.js script to your web page and provide some simple options. See Basic Usage
<script type="text/javascript" src="path/to/instafeed.min.js"></script>
Note: Instafeed.js is also compatible with require.js and commonJS exports
<div id="instafeed"></div>
<script type="text/javascript">
var feed = new Instafeed({
accessToken: 'your-token'
});
feed.run();
</script>
Instafeed will automatically look for a <div id="instafeed"></div>
and fill it with linked thumbnails. Of course, you can easily change this behavior using standard options. Also check out the advanced options for some advanced ways of customizing Instafeed.js.
- A Facebook developer account, and an Instagram account with some media posted to it.
- A Facebook app linked to your Instagram account, and a token generated through that app.
- A service to keep your access token fresh
Here are some of the most commonly used options:
Key | Default Value | Valid types | Description |
---|---|---|---|
accessToken |
null |
String, Function | Required. The Instagram access token, either as a string, or a function which returns a string |
debug |
false |
Boolean | Set to true to display debugging information |
filter |
null |
Function | A function used to exclude images from your results. The function will be given the image data as an argument, and expects the function to return a boolean. |
limit |
null |
Number | Display a maximum of this many posts |
sort |
null |
Function | A custom function to sort the media, rather than the default 'most recent' sorting |
target |
'instafeed' |
String, DOM Element | Either the ID or the DOM element itself where you want to add the images. |
template |
'<a href="{{link}}"><img title="{{caption}}" src="{{image}}" /></a>' |
String | A mustache template used to produce HTML for the document. |
transform |
null |
Function | A function used to transform the image data before it is rendered. |
See Options in the wiki for the complete reference.
The easiest way to control the way Instafeed.js looks on your website is to use the template option. You can write your own HTML markup and it will be used for every image that Instafeed.js fetches. See Templating.
See CHANGELOG.md.