Home > Back-end >  Finding value inside an object, that's within an array
Finding value inside an object, that's within an array

Time:11-27

I have two arrays I want to compare. The state of each object could be either true, false or null depending on what the user has selected.
I then want to compare the two arrays, and push the name of the activity into a separate array if they match each other.
If it compares the first one for example, which would be "free", and the user has checked this, making { free: true }, then this activity ("Go to the cinema") will not be pushed into the new array.

//user input
filtersChecked: [
    { free: null },
    { indoors: null },
    { city: null },
    { winter: null },
    { physical: null },
],

//compared against:

name: "Go to the cinema",
filters: [
    { free: false },
    { indoors: true },
    { city: true },
    { winter: null },
    { physical: false },
],

What I'm struggling with is comparing the "index" of the objects state if that makes any sense...
My attempt looks like this:

function checkFilter(index, isChecked) {
    if (isChecked) {
        model.input.filtersChecked[index] = true;
    } else if (!isChecked) {
        model.input.filtersChecked[index] = false;
    }
}

function suggestActivities() {
    let userFilters = model.input.filtersChecked;
    let activityFilters;
    let tempArray = [];

    for (let i = 0; i < model.data.activities.length; i  ) {
        activityFilters = model.data.activities[i].filters;
        for (let j = 0; j < userFilters.length; j  ) {
            if (userFilters[j] === activityFilters[j]) {
                tempArray.push(model.data.activities[i].name);
                console.log(tempArray);
                continue;
            }
        }
    }
    console.log(tempArray);
}

I hope it's detailed enough. Been stuck on this for way too long now.
Also worth a mention that I would like it to be vanilla JavaScript, since this is a school assignment. So no jQuery please!

Thank you in advance!

CodePudding user response:

Here is a sample of how you could do this comparison, with the subproblems you could break it down into. Use it as a template with how to solve your assignment's problem. Let me know if it helps.

const userInput = [
    { free: null },
    { indoors: null },
    { city: null },
    { winter: null },
    { physical: null },
 ]

const compared = {
    name: "Go to movies"
    filters: [
       { free: false },
       { indoors: true },
       { city: true },
       { winter: null },
       { physical: false },
    ]
}
const tempArr = []

function compareObjects (userInput, compared) {
    //loop through userInput filters
    for (let i=0; i<userInput.length; i  ){
       //grab key from current index of array (like "free", "indoors", etc)
       let key = Object.keys(userInput[i])[0]

        //compare stored filters with user filters
        //if not equal, we can stop searching through the filters entirely and exit the function,
        // since if one of them doesnt match, we wont push at all
        //Note, I can reuse the userInput key for the compared keys, because both arrays are of equal length. 
        //If they weren't the same length, the keys wouldn't match, and you would have to sort the array first
        //so the index order and keys matched for both inputs.   
        if(userInput[i][key] !== compared.filters[i][key]) return
    }
    // if we made it through this loop without exiting the function, we can 
    // push the name since it means they all matched
    tempArr.push(compared.name)
}

//call the function and pass in variables
compareObjects(userInput, compared)
  • Related