ฉันไม่แนะนำให้คุณใช้ Object.keys เนื่องจากไม่รองรับใน IE เวอร์ชันเก่า แต่ถ้าคุณต้องการสิ่งนั้นจริงๆคุณสามารถใช้รหัสด้านบนเพื่อรับประกันความเข้ากันได้ด้านหลัง:
if (!Object.keys) {
Object.keys = (function () {
var hasOwnProperty = Object.prototype.hasOwnProperty,
hasDontEnumBug = !({toString: null}).propertyIsEnumerable('toString'),
dontEnums = [
'toString',
'toLocaleString',
'valueOf',
'hasOwnProperty',
'isPrototypeOf',
'propertyIsEnumerable',
'constructor'
],
dontEnumsLength = dontEnums.length;
return function (obj) {
if (typeof obj !== 'object' && typeof obj !== 'function' || obj === null) throw new TypeError('Object.keys called on non-object');
var result = [];
for (var prop in obj) {
if (hasOwnProperty.call(obj, prop)) result.push(prop);
}
if (hasDontEnumBug) {
for (var i=0; i < dontEnumsLength; i++) {
if (hasOwnProperty.call(obj, dontEnums[i])) result.push(dontEnums[i]);
}
}
return result;
}})()};
คุณสมบัติ Firefox (Gecko) 4 (2.0) Chrome 5 Internet Explorer 9 Opera 12 Safari 5
ข้อมูลเพิ่มเติม: https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Global_Objects/Object/keys
แต่ถ้าคุณต้องการเพียงอันแรกเราสามารถจัดการวิธีแก้ปัญหาให้สั้นกว่าเช่น:
var data = {"key1":"123","key2":"456"};
var first = {};
for(key in data){
if(data.hasOwnProperty(key)){
first.key = key;
first.content = data[key];
break;
}
}
console.log(first); // {key:"key",content:"123"}