Constructing MovieModel
In this lesson, you'll learn to create a MovieModel object from a JSON formatted API response.
Introduction
In this lesson, we’ll create a MovieModel
Dart class to parse the JSON response returned from API.
MovieModel
class will have properties for each of the data['results']
JSON attributes returned as API response.
Revisiting TMDB API response structure
The JSON response returned from TMDB API looks like a huge blob of string. It could be hard to access the attributes by calling their names every time from code. A spelling mistake can make debugging very hard.
To avoid this problem, it makes sense to create a Dart object mapped to the response. We will call this class MovieModel
.
Earlier, if you would want to access the “title” of the movie, you had to do data['results']['title']
.
After mapping data
to MovieModel
class, you can access “title” as movieModelObj.title
and so on.
TMDB API JSON response
{
"page":1,
"total_results":10000,
"total_pages":500,
"results":[
{
"popularity":407.45,
"vote_count":2334,
"video":false,
"poster_path":"\/xBHvZcjRiWyobQ9kxBhO6B2dtRI.jpg",
"id":419704,
"adult":false,
"backdrop_path":"\/5BwqwxMEjeFtdknRV792Svo0K1v.jpg",
"original_language":"en",
"original_title":"Ad Astra",
"genre_ids":[
12,
18,
9648,
878,
53
],
"title":"Ad Astra",
"vote_average":6,
"overview":"The near future, a time when both hope and hardships drive humanity to look to the stars and beyond. While a mysterious phenomenon menaces to destroy life on planet Earth, astronaut Roy McBride undertakes a mission across the immensity of space and its many perils to uncover the truth about a lost expedition that decades before boldly faced emptiness and silence in search of the unknown.",
"release_date":"2019-09-17"
}
]
}
Constructing MovieModel
Let’s create a MovieModel
class to hold the API movie listing data set. MovieModel
class will have properties for each attribute of the JSON response.
The MovieModel.fromJson()
MovieModel.fromJson(Map<String, dynamic> json)
takes a JSON map and assigns corresponding values to the MovieModel
object’s properties. Now, the movie object’s title can be accessed as movieObject.title
.
MovieModel
class MovieModel {
//Class fields for mapping to JSON properties
final int id;
final num popularity;
final int vote_count;
final bool video;
final String poster_path;
final String backdrop_path;
final bool adult;
final String original_language;
final String original_title;
final List<dynamic> genre_ids;
final String title;
final num vote_average;
final String overview;
final String release_date;
//Takes JSON formatted map, and returns `MovieModel` object.
MovieModel.fromJson(Map<String, dynamic> json)
: id = json['id'],
popularity = json['popularity'],
vote_count = json['vote_count'],
video = json['video'],
poster_path = json['poster_path'],
adult = json['adult'],
original_language = json['original_language'],
original_title = json['original_title'],
genre_ids = json['genre_ids'],
title = json['title'],
vote_average = json['vote_average'],
overview = json['overview'],
release_date = json['release_date'],
backdrop_path = json['backdrop_path'];
}
Get hands-on with 1300+ tech skills courses.