>웹 프론트엔드 >JS 튜토리얼 >자바스크립트가 객체의 속성값을 탐색하는 방법에 대한 자세한 코드 설명

자바스크립트가 객체의 속성값을 탐색하는 방법에 대한 자세한 코드 설명

伊谢尔伦
伊谢尔伦원래의
2017-07-21 13:07:151760검색

"js에서 객체의 속성과 값을 탐색하는 것"의 필요성에 대해. 그 이유는 테이블 내용을 부분적으로 새로 고치는 js 플러그인을 만들기 위해서입니다.

문제: 속성 이름 배열을 순회하여 개체의 속성 값을 가져오지 못했습니다.

초기 오류 코드는 다음과 같습니다.


for(var i=0;i<dataList.length;i++)
{
  var dataLine="<tr>";   
  for(var j=0;j<filedList.length;j++){
    dataLine+="<td>"+dataList[i].filedList[j]+"</td>"; 
  } 
  dataLine+="</tr>";
  $("#"+tableName).append(dataLine);
}

먼저 개체 배열이 다음 위치에 배치됩니다. dataList; 객체 배열은 fileList에 배치됩니다. 객체의 속성 필드 이름 배열입니다. 처음에는 이렇게 생각해서 dataList를 순회하고 매번 객체를 얻은 다음 for 루프를 중첩하고 fileList를 순회하고 매번 해당 속성 값 중 하나를 가져온 다음 테이블로 함께 조각냅니다. .

예: dataList[0]은 Emp 개체이고 Emp에는 id 및 name과 같은 속성이 있습니다. 일반적으로 dataList[0].id를 통해 현재 Emp 객체의 id 값을 얻을 수 있습니다. 하지만 속성 필드 배열을 순회하면 dataList[0].filedList[0]을 이런 방식으로 사용할 수 없습니다. 이는 이미 Alert(filedList[0])를 통해 id 값 1을 얻었기 때문에 fileList[0]에서 값을 얻지 못했다는 의미는 아닙니다. 그렇다면 인수는 왜 실패하는 걸까요? Emp 객체에서 fileList[0]이라는 속성을 찾고 있기 때문입니다! 물론 Emp 객체에는 그러한 속성이 없으므로 획득이 실패합니다. 그러면 객체의 속성 값을 어떻게 얻을 수 있습니까?

해결책: "향상된 for 루프"를 사용하여 탐색합니다.

올바른 코드는 다음과 같습니다.


for(var i=0;i<dataList.length;i++)
{
  var dataLine="<tr>";   
  for(var filedName in dataList[i]){
    dataLine+="<td>"+dataList[i][filedName]+"</td>"; 
  } 
  dataLine+="</tr>";
  $("#"+tableName).append(dataLine);
}

해결책: dataList[i]가 객체이므로 매번 이 객체의 속성을 얻을 수 있습니다. name, dataList[i][filedName], 즉 object[속성 이름]을 통해 이 속성의 속성 값을 얻습니다.


rreee

위 내용은 자바스크립트가 객체의 속성값을 탐색하는 방법에 대한 자세한 코드 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.