Filtering Movielist Javascript
Solution 1:
First of all, you'll need a helper function to performs XMLHttpRequest
properly in order to return data asynchronously. For example:
var newXHR = null;
functionsendXHR(options, callback) {
newXHR = newXMLHttpRequest() || newwindow.ActiveXObject("Microsoft.XMLHTTP");
options.contentType = options.contentType || "application/x-www-form-urlencoded";
newXHR.open(options.type, options.url, true);
newXHR.setRequestHeader("Content-Type", options.contentType);
newXHR.send(options.data);
newXHR.onreadystatechange = function() {
if (this.status === 200 && this.readyState === 4) {
callback(this.response);
}
};
}
In this example, we show how to configure the XMLHttpRequest
object to perform asynchronous requests and assign the response in a callback function.
Usage:
sendXHR({
url: "https://gist.githubusercontent.com/dannyjhonston/288a0555179f379008e901d9d5f034a3/raw/03519253848040cd8c7d68dceb0e5a53755e5f52/movies.json",
type: "GET"
}, function(response) {
console.log(response); // Contains data from the url.// Performs other operations with the response.
});
With the given response, fill the categories with this function:
functionfillCategories(data) {
var selection = document.getElementById("selection"), html = "", len = data.categories.length;
html += "<option>-- Select Genre --</option>";
for (var i = 0; i < len; i++) {
html += "<option value=\"";
html += data.categories[i];
html += "\">";
html += data.categories[i];
html += "</option>";
}
selection.innerHTML = html; // Render the html.
selection.onchange = function() { // When the selection field is changed call the printOutput function.printOutput(this.value); // this.value is the selected genre.
};
}
With the selected genre, fill the output with this function:
functionprintOutput(genre) {
var result = data.movies.filter(function(x) {
return x.categories.indexOf(genre) > -1;
}), output = document.getElementById("output"), len = result.length, html = "";
for (var i = 0; i < len; i++) {
html += "<li>";
html += result[i].title;
html += "</li>";
}
output.innerHTML = html;
}
In the previous function, I'm using Array.prototype.filter()
to return a new array with the movies that correspond to the selected category, by using x.categories.indexOf (genre) > -1;
.
Something like this:
(function() {
var newXHR = null; // Once initialized with the XMLHttpRequest object, you can use the abort() method from anywhere in the code.var data = {}; // This variable is declared in the global scope.functionsendXHR(options, callback) {
newXHR = newXMLHttpRequest() || newwindow.ActiveXObject("Microsoft.XMLHTTP");
options.contentType = options.contentType || "application/x-www-form-urlencoded";
newXHR.open(options.type, options.url, true);
newXHR.setRequestHeader("Content-Type", options.contentType);
newXHR.send(options.data);
newXHR.onreadystatechange = function() {
if (this.status === 200 && this.readyState === 4) {
callback(this.response);
}
};
}
sendXHR({
url: "https://gist.githubusercontent.com/dannyjhonston/288a0555179f379008e901d9d5f034a3/raw/03519253848040cd8c7d68dceb0e5a53755e5f52/movies.json",
type: "GET"
}, function(response) {
data = JSON.parse(response);
fillCategories(data);
});
functionprintOutput(genre) {
var result = data.movies.filter(function(x) {
return x.categories.indexOf(genre) > -1;
}), output = document.getElementById("output"), len = result.length, html = "";
for (var i = 0; i < len; i++) {
html += "<li>";
html += result[i].title;
html += "</li>";
}
output.innerHTML = html;
}
functionfillCategories(data) {
var selection = document.getElementById("selection"),
html = "", len = data.categories.length;
html += "<option>-- Select Genre --</option>";
for (var i = 0; i < len; i++) {
html += "<option value=\"";
html += data.categories[i];
html += "\">";
html += data.categories[i];
html += "</option>";
}
selection.innerHTML = html;
selection.onchange = function() {
printOutput(this.value);
};
}
}());
<selectid="selection"></select><ulid="output"></ul>
Solution 2:
Yo have some errors in you logic.
- the loop is associated to movies.length with i variable but you are trying to use it to get categories index as well.
Try to split you logic to manage categories and then movies.I mean create 2 separated loops...
for(var i = 0; i < data.movies.length; i++)
{
//movies html generation
}
for(var i = 0; i < data.categories.length; i++)
{
//categories html generation
}
2 your movies contains categories properties as string and you are trying it as array.
So inside movies loop, do something like this...
for(var i = 0; i < data.movies.length; i++)
{
data.movies[i].categories = data.movies[i].categories.split(',');
//movies html generation
}
Notice You can use the navigator developer tool to debug your code.
Solution 3:
var movieList = {
"movies": [{
"title": "Mad Max",
"categories": "action"
}, {
"title": "Willow",
"categories": "action,fantasy"
}, {
"title": "Alien",
"categories": "action,sci-fi"
}, {
"title": "Silence of the lambs",
"categories": "thriller"
}, {
"title": "The Ring",
"categories": "horror"
}, {
"title": "Gone with the wind",
"categories": "drama"
}, {
"title": "Lion King",
"categories": "animation, family"
}, {
"title": "Jumanji",
"categories": "action,fantasy, family"
}, {
"title": "Heat",
"categories": "action,thriller"
}, {
"title": "Blade runner",
"categories": "action,sci-fi"
}],
"categories": ["action", "sci-fi", "drama", "thriller", "horror", "fantasy", "family", "animation"]
}
var movieArray = movieList.movies.map(function(a) {
return {
"title": a.title,
"categories": a.categories.split(",")
}
})
console.log(movieArray);
console.log(movieArray.filter(function(a) {
return a.categories.includes("thriller")
}));
Hope this helps you with your data formatting.
Post a Comment for "Filtering Movielist Javascript"