Basic JavaScript - Record Collection

Tell us what’s happening:

Describe your issue in detail here.
can anyone find me the bug.

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 (!value){
    delete records[id][prop]
  } else if (prop != 'tracks') {
    records[id][prop] =value
  } else {
    if (!record[id].hasOwnProperty('tracks')) 
    records[id].tracks = []
  }
  records[id].tracks.push(value)
  
}
return records;
}

console.log(updateRecords(recordCollection, 5439, 'album title'));

Your browser information:

User Agent is: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36

Challenge Information:

Basic JavaScript - Record Collection

Hi @adnan1.

There are a few bugs here in your code.

On this line, you have record instead of records.

You have an extra ending curly brace here:

}
return records;
}

I would remove the one right before return records since you need to always return the records object.

Also, this line:

records[id].tracks.push(value)

is outside of where it should be. It’s only applicable for the tracks property.

Tell us what’s happening:

Describe your issue in detail here.
I have removed what was suggested in the last post after I posted kindly look into this code again and suggest so I can move on further.

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 (!value){
delete records[id][prop]
} else if (prop != ‘tracks’) {
records[id][prop] =value
} else {
if (!record[id].hasOwnProperty(‘tracks’))
record[id].tracks =
}

return records;
}

console.log(updateRecords(recordCollection, 5439, ‘album title’));

// 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 (!value){
    delete records[id][prop]
  } else if (prop != 'tracks') {
    records[id][prop] =value
  } else {
    if (!record[id].hasOwnProperty('tracks')) 
    record[id].tracks = []
  }
 
return records;
}

console.log(updateRecords(recordCollection, 5439, 'album title'));

Your browser information:

User Agent is: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36

Challenge Information:

Basic JavaScript - Record Collection

I have merged your two topics together.

You have not followed all the advices you were given, for example

1 Like

This topic was automatically closed 182 days after the last reply. New replies are no longer allowed.