Can I loop through a javascript object in reverse order?

后端 未结 4 728
感情败类
感情败类 2021-02-03 17:44

So I have a JavaScript object like this:

foo = {
  \"one\": \"some\",
  \"two\": \"thing\",
  \"three\": \"else\"
};

I can loop this like:

相关标签:
4条回答
  • 2021-02-03 18:11

    Javascript objects don't have a guaranteed inherent order, so there doesn't exist a "reverse" order.

    4.3.3 Object An object is a member of the type Object. It is an unordered collection of properties each of which contains a primitive value, object, or function. A function stored in a property of an object is called a method.

    Browsers do seem to return the properties in the same order they were added to the object, but since this is not standard, you probably shouldn't rely on this behavior.

    A simple function that calls a function for each property in reverse order as that given by the browser's for..in, is this:

    // f is a function that has the obj as 'this' and the property name as first parameter
    function reverseForIn(obj, f) {
      var arr = [];
      for (var key in obj) {
        // add hasOwnPropertyCheck if needed
        arr.push(key);
      }
      for (var i=arr.length-1; i>=0; i--) {
        f.call(obj, arr[i]);
      }
    }
    
    //usage
    reverseForIn(obj, function(key){ console.log('KEY:', key, 'VALUE:', this[key]); });
    

    Working JsBin: http://jsbin.com/aPoBAbE/1/edit

    Again i say that the order of for..in is not guaranteed, so the reverse order is not guaranteed. Use with caution!

    0 讨论(0)
  • 2021-02-03 18:22

    This answer is similar to a couple of the others, but some users might find the code below easier to copy-paste for their own uses:

    Object.keys(foo).reverse().forEach(function(key) { console.log(foo[key]) });
    

    For an object "foo" as described in the question, this code will output the object elements in reverse order: "else", "thing", "some"

    0 讨论(0)
  • 2021-02-03 18:24

    Why there is no one has mentioned Object.keys() ?

    you can get Array of Object's properties ordered as it is, then you can reverse it or filter it as you want with Array methods .

    let foo = {
      "one": "some",
      "two": "thing",
      "three": "else"
    };
    
    // Get REVERSED Array of Propirties
    let properties = Object.keys(foo).reverse();
    // "three"
    // "two"
    // "one"
    
    // Then you could use .forEach / .map
    properties.forEach(prop => console.log(`PropertyName: ${prop}, its Value: ${foo[prop]}`));
    
    // PropertyName: three, its Value: else
    // PropertyName: two, its Value: thing
    // PropertyName: one, its Value: some

    0 讨论(0)
  • 2021-02-03 18:33

    There is no way to loop through an object backwards, but if you recreate the object in reverse order then you are golden! Be cautions however, there is nothing that says the order of the object will stay the same as it changes and so this may lead to some interesting outcome, but for the most part it works...

    function ReverseObject(Obj){
        var TempArr = [];
        var NewObj = [];
        for (var Key in Obj){
            TempArr.push(Key);
        }
        for (var i = TempArr.length-1; i >= 0; i--){
            NewObj[TempArr[i]] = [];
        }
        return NewObj;
    }
    

    The just do the swap on your object like this-

    MyObject = ReverseObject(MyObject);
    

    The loop would then look like this-

    for (var KeysAreNowBackwards in MyObject){
        alert(MyObject[KeysAreNowBackwards]);
    } 
    
    0 讨论(0)
提交回复
热议问题