Console.log 仅显示打印对象的更新版本

IT技术 javascript json google-chrome sorting console
2021-01-26 00:02:24
String.prototype.width = function(font) {

  var f = font || '12px arial',
      o = $('<div>' + this + '</div>')
            .css({'position': 'absolute', 'float': 'left', 'white-space': 'nowrap', 'visibility': 'hidden', 'font': f})
            .appendTo($('body')),
      w = o.width();

  o.remove();

  return w;
}


function sortCustomFunction(a, b) {
  if (a['text'].width() < b['text'].width())
     return -1;
  if (a['text'].width() > b['text'].width())
     return 1;
  // a must be equal to b
  return 0;
}

var annoObj = {
        'anno' : [
            //an paikseis me auta (px to teleutaio na mpei prwto kok) oi mikres metatwpiseis ofeilontai sto padding.
            { "label" : "fifth" , "text"  : "This is a sample text another one" , 'color' : 'red' },
            { "label" : "first" , "text"  : "This is a sample" , 'color' : 'grey' },
            { "label" : "second" , "text" : "sample" , 'color' : 'green' },
            { "label" : "sixth" , "text"  : "This is a sample text another one text one mooooorreee" , 'color' : 'lightgreen' },
            { "label" : "third" , "text"  : "another one" , 'color' : 'blue' },
            { "label" : "forth" , "text"  : "one mooooorreee" , 'color' : 'purple' }        
        ]
    };

    console.log(annoObj.anno);   //This should print the unsorted array (but it prints the sorted array).
    annoObj.anno.sort(sortCustomFunction); //Sort the array
    console.log(annoObj.anno);  //This should print the sorted (and it does)

我正在执行上述操作,一切正常。json 对象内部的数组按数组的 json 元素中 'text' 键的宽度值排序。我注意到的是 console.log 中的这种奇怪行为。我在排序之前和排序之后打印数组,并且在两次打印中都是相同的。它打印排序后的数组。为什么是这样?

JSFIDDLE

3个回答

您对排序没有问题,但这是大多数浏览器控制台的众所周知的特性(优化):仅在您打开对象时使用对象的新值构建树。

如果您想在记录时查看对象的状态,假设它是一个足够小且不是自引用的对象,您可以像这样克隆它:

console.log(JSON.parse(JSON.stringify(annoObj.anno)));
请注意,如果您确实需要记录大对象和递归对象,您还有一个解决方案:JSON.prune.log但大多数情况下,您可以将日志限制为足够小的部分。
2021-03-30 00:02:24

当那个关闭时,我正在回答这个重复的问题。作为一个相关的注意事项,Stackoverflow 的代码片段确实打印了对象的实际当前值,而没有浏览器的错误。

let dummyArr = [
    {"name" : "a", "isChecked" : true},
    {"name" : "b", "isChecked" : false},
    {"name" : "c", "isChecked" : true}
];

console.log(dummyArr);
document.getElementById('a').innerHTML = JSON.stringify(dummyArr);

for(var i = 0; i < dummyArr.length ; i++){
    dummyArr[i].isChecked = false;
}

console.log(dummyArr);
document.getElementById('b').innerHTML = JSON.stringify(dummyArr);
<div id="a"></div>
<div id="b"></div>

使用console.table的表格布局。在 Firebug 和最新版本的 Google Chrome 中受支持。

https://developers.google.com/chrome-developer-tools/docs/tips-and-tricks#console-table

就我而言,它没有按预期工作。仍然只得到更新的值。
2021-03-31 00:02:24