Tell us what’s happening:
This is my first experience with javascript.
In this follow challenge we have a function with parameters:
function updateRecords(records, id, prop, value) {…} - so far all right.
But during looking for a solution I found out, that we have to assing those parameters to each other? But how? And why should it work?
I can imagine, the function parameters are independent variables like getAgeOfAPerson(name, age, id, sex){…}, so we can change and manage them to achieve what we need, and the same with function(records, id, prop, value)…
But how can we assign those parameters to each other e.g. “name[age][id] = sex” or like in our case: “records[id][prop] = value”??? Why? What is the sense? How does it work?
Im sorry, but I totally don
t get this challenge so far and I would be thankful for any help, additional info, links or explanation
Your code so far
// Setup
const recordCollection = {
2548: {
albumTitle: 'Slippery When Wet',
artist: 'Bon Jovi',
tracks: ['Let It Rock', 'You Give Love a Bad Name']
},
2468: {
albumTitle: '1999',
artist: 'Prince',
tracks: ['1999', 'Little Red Corvette']
},
1245: {
artist: 'Robert Palmer',
tracks: []
},
5439: {
albumTitle: 'ABBA Gold'
}
};
// Only change code below this line
function updateRecords(records, id, prop, value) {
if(prop !== "tracks" && value !== ""){ records[id][prop] = value; }
else if (prop === "tracks" && value !== "" && records[id].hasOwnProperty("tracks") === false) { records[id][prop] = [value];}
else if (prop === "tracks" && value !== "") { records[id][prop].push(value);}
else if (value === "") { delete records[id][prop];}
return records;
}
updateRecords(recordCollection, 5439, 'artist', 'ABBA');
Your browser information:
User Agent is: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/109.0.0.0 Safari/537.36
Challenge: Basic JavaScript - Record Collection
Link to the challenge: