Return object with default values from array in Javascript

后端 未结 4 461
离开以前
离开以前 2021-01-22 14:10
    const fields = [\'email\', \'password\'];

    const objFields = {};
    fields.forEach(value => {
      objFields[value] = \'\';
    });

    console.log(objFiel         


        
4条回答
  •  梦毁少年i
    2021-01-22 14:43

    You need to transform your array which contains keys into a real object.

    To do it you have many possibilites, but you still have to do something, there is no magical trick.

    My favorite soluce is to use a function to insert into your Utilitary class. So it's easy to read and re-usable.


    number 1 : The function

    function initializeKeys(keys, initialValue, object) {
      return keys.reduce((tmp, x) => {
        tmp[x] = initialValue;
    
        return tmp;
      }, object);
    }
    
    const objFields = initializeKeys(['email', 'password'], '', {
      otherKey: 'a',
    });
    
    console.log(objFields);


    number 2 : The forEach

    const fields = ['email', 'password'];
    
    const objFields = {};
    
    fields.forEach(value => {
      objFields[value] = '';
    });
    
    console.log(objFields);


    number 3 : The reduce

    const fields = ['email', 'password'];
    
    const objFields = {
      ...fields.reduce((tmp, x) => {
        tmp[x] = '';
    
        return tmp;
      }, {}),
    };
    
    console.log(objFields);

提交回复
热议问题