Add dynamic key, value pairs to JavaScript array or hash table

前端 未结 5 1597
醉话见心
醉话见心 2020-12-12 19:51

I\'m trying to add a key value pair to an existing javascript associative array. The key needs to be a variable. This is for JSON encoding. I realize there are many plugins

相关标签:
5条回答
  • 2020-12-12 20:02

    The following code will help you

    ary.push( {[name]: val} );
    

    See below example

    let allData = [{name: "Cat", type: "Animal"}]
    let finalData: any = [];
    for (let i = 0; i < allData.length; i++)
    {
      let obj = allData[i];
      for (let KEY in obj)
      {
        //Pushing data to other array as object
        this.finalData.push({ [KEY] : obj[KEY] });
      }
    }
    
    0 讨论(0)
  • 2020-12-12 20:05
    var ary = [];
    
    function pushToAry(name, val) {
       var obj = {};
       obj[name] = val;
       ary.push(obj);
    }
    
    pushToAry("myName", "myVal");
    

    Having just fully read your question though, all you need is the following

    $(your collection of form els).serializeArray();
    

    Good old jQuery

    0 讨论(0)
  • 2020-12-12 20:09

    An "associative array" is really just an object. You don't use push, you just assign properties to the object:

    ary[name] = val;
    
    0 讨论(0)
  • 2020-12-12 20:18

    In ES6...

    In ES6, you can use a destructuring assignment;

    ary.push({[name]: val});
    

    However, given this is ES6 syntax, the usual caveats apply; this will not work in some browsers (noticably, IE and Edge 13)... although Babel will transpile this for you.


    Without ES6 (legacy browser support)...

    You need to define an object and use square bracket notation to set the property;

    var obj = {};
    
    obj[name] = val;
    
    ary.push(obj);
    

    If you get the urge to read into it more, see this article on the differences between square bracket and dot notation.

    0 讨论(0)
  • 2020-12-12 20:18
    const tStyles = [];
    for (const i of iStyles) {
      const temp = {};
      temp[`${style}`] = `../dist/css/uikit.${wFile}.${style}.css`;
      tStyles.push(temp);
    }
    

    json : {"black-beige":"../dist/css/uikit.or.black-beige.css"}

    0 讨论(0)
提交回复
热议问题