- Migration from contentful.js 5.x
- Migration from contentful.js 4.x
- Migration from contentful.js 3.x
- Migration to contentful.js 3.x from previous versions
- Migration from contentful.js 2.x and older
From version 3.0.0 onwards, you can access documentation for a specific version by visiting https://contentful.github.io/contentful.js/contentful/<VERSION>
We dropped support for Node v4 and older. Please ensure you are running Node v5 or newer.
The bundle for browsers is now called contentful.browser.min.js
to mark it clearly as browser only bundle. If you need to support IE 11 or other old browsers, you may use the contentful.legacy.min.js
. Node will automatically use the contentful.node.min.js
while bundlers like Webpack will resolve to the new ES-modules version of the library.
No changes to the API of the library were made.
From version 4.0.0 and up contentful.js is exported as a single umd
bundle the cdn distribution has changed, there is no more browser-dist
. the new link format is https://unpkg.com/contentful@version/dist/contentful.min.js instead of https://unpkg.com/contentful@version/browser-dist/contentful.min.js. to access version 3 you can still use https://unpkg.com/[email protected]/browser-dist/contentful.min.js
(March 8th, 2016)
contentful.js 3.x was a major rewrite, with some API changes. While the base functionality remains the same, some method names have changed, as well as some internal behaviors.
The two major changes you should look out for are the method renamings, and the way link resolution works.
This file lists the changes to the API and behavior, and how you should proceed to update your code.
For more specific details consult the reference documentation for the current version.
Future releases will have any changes listed in the changelog on the releases page.
Before contentful.js 3.x, the main methods were named such as entry()
or entries()
. Now they have changed to getEntry()
or getEntries()
.
This helps bring the API of this SDK more in line with that of contentful-management.js.
For contentful.js, all of these methods were renamed, apart from sync()
. The complete list is on the following table:
Old name | New name |
---|---|
space() |
getSpace() |
entry() |
getEntry() |
entries() |
getEntries() |
contentType() |
getContentType() |
contentTypes() |
getContentTypes() |
asset() |
getAsset() |
assets() |
getAssets() |
sync() |
sync() |
Before contentful.js 3.x, collection replies were essentially JavaScript Arrays with some additional properties (total
, skip
and limit
) added to their prototypes.
Now, collection replies are Objects, with those same properties, and an additional items
property containing an array with all the items returned. This is more similar to what is actually returned from the REST API.
While not documented, older version of this SDK supported a callback API such as entry('id', function(data){})
.
This has now been removed.
Before contentful.js 3.x, the entities returned from the API such as Entries or Content Types were wrapped in prototype based classes.
From contentful.js 3.x this is not the case anymore.
The objects returned by the promises are now frozen JavaScript Objects, which contain the relevant data and some helper methods (more to come in the future).
You can get a plain version of this object with only the data by using the toPlainObject()
method.
Also note that Date fields such as sys.createdAt
are not turned into JavaScript Date
objects anymore, and are now plain ISO-8601 strings.
In previous versions of contentful.js, Links to other entries and assets were resolved by replacing the link objects with references to the objects containing the Entry or Asset.
This caused problems with serialization when circular links were present, which meant that if you used JSON.stringify
you would get an exception, and you'd be required to use something like json-stringify-safe and have some additional work around the circular links.
From contentful.js 3.x onwards, links are now resolved by getter methods, and their results memoized. This means that you can use them the same way as before, but you won't get problems with resolution of circular links when serializing them.
However, you can still turn off link resolution if you so wish.
contentful.js 3.x was a major rewrite, with some API changes. While the base functionality remains the same, some method names have changed, as well as some internal behaviors.