2차원배열 개념으로 json 이용하기(연관배열) > javascript
javascript

2차원배열 개념으로 json 이용하기(연관배열)

조회 2,814회 댓글 0건
  • 현재 페이지 주소 복사
  • 페이스북으로 공유
  • X 로  공유
  • 트위터로  공유
  • 네이버 블로그로 공유
  • 네이버 카페 공유하기
  • 네이버 라인 공유하기
  • 네이버 밴드 공유하기
  • 링크드인으로 공유하기

예전에 딕셔너리도 이렇게 처리하는것을 본것 같은 기억이 있는데요.

php에서의 배열은 간단한데 여기건 별도로 만들어진 배열을 넣는 방식으로 처리 합니다.

json 이라고 했지만 아래가 json은 아니죠. 그렇게 만들면 되서 json 이라고 하였습니다. json 다른 언어에서도 사용하여 요즘은 언어 독립형이 된듯 합니다.



let aGlbInfo      = {};

// 초기화 후 기존것을 읽어서 넣어 준 다음 추가 한다
function set_obj_data ( idx1, idx2, idxVal )
{
  let aTemp       = {};
  for(var key in aGlbInfo[idx1]) {
    var val         = aGlbInfo[idx1][key];
    aTemp[key]      = val;
  }
  aTemp[idx2]     = idxVal;

  aGlbInfo[idx1]  = aTemp;
}
set_obj_data('test1', '22', 'val1');
set_obj_data('test1', '33', 'val3');
set_obj_data('test2', '33', 'val4');
console.log(aGlbInfo);

// 삭제
// delete aGlbInfo.test1[22];
// console.log(aGlbInfo);
 


테스트 할때 여러번 console.log로 찍으면서 삭제를 하면 순차적으로 처리 되지 않는다는것을 볼 수 있는데요.

실제 사용은 그렇게 하지 않게 때문에 문제 되는 경우는 없을텐데 순차적으로 삭제하고 추가하고 하는 경우가 있다면 알고 있으면 좋습니다.


위부분에서 중요한 부분은 넣기 전에 기존의 것을 읽어와서 정리한 다음 2차원 배열 부분에 추가 한다는 것입니다.


-- 아래추가 -- 참고 --

//
$(document).ready(function()
{
  // 공간을 정하지 않고 필요한 만큼 사용하기 위한것
  let oTest2    = {};
  let oTest     = {};

  // 오류가 발생 한다
  // oTest['idname']['pageNum'] = 5;

  // undefined 를 출력 한다
  // console.log( typeof oTest['idname'] )

  // 에러 발생 - 즉, 오류가 나지 않게 하려면 순차적으로 확인을 해야 한다
  // console.log( typeof oTest['idname']['pageNum'] )

  oTest2['pageNum'] = 2;
  console.log(oTest2);

  // 이전것을 덮어 씌운다
  oTest2    = {
    name: 'test22',
    age : 23,
    posX: 23
  }
  console.log(oTest2);

  oTest['idname']   = oTest2;
  console.log(oTest);
  console.log( oTest['idname']['pageNum'] );

  // 있으면 오류 없이 값 변경도 잘 된다
  oTest['idname']['pageNum'] = 5;
  console.log( oTest['idname']['pageNum'] );

  // 모두 출력하여 확인 하기
  for(var key in oTest['idname'] ) {
    console.log('key: ', key);
  }

});



* 연관배열 형태는 아래를 참고하세요.

https://www.pabburi.co.kr/content/javascript/json-2%EC%B0%A8%EC%9B%90-%EB%B0%B0%EC%97%B4-%ED%98%95%ED%83%9C%EB%A1%9C-%EC%82%AC%EC%9A%A9%EC%97%B0%EA%B4%80%EB%B0%B0%EC%97%B4-%ED%8B%B1%EC%85%94%EB%84%88%EB%A6%AC/ 

  • 현재 페이지 주소 복사
  • 페이스북으로 공유
  • X 로  공유
  • 트위터로  공유
  • 네이버 블로그로 공유
  • 네이버 카페 공유하기
  • 네이버 라인 공유하기
  • 네이버 밴드 공유하기
  • 링크드인으로 공유하기
전체 99건 1 페이지
  • profile_image 보통 마우스의 휠은 세로 스크롤을 작동시키는데 사용하는데요.이번에 테스트로 만든 페이지의 가로의 양이 상당해서 아래쪽에 가로스크롤을 마우스로 움직이는데 상당히 거슬려서 만들어 보게 된것입니다. ▶ JavaScript에서 wheel 이벤트 감지  - event.deltaY 값(세로 스크롤)을 감지하여 가로 스크롤(scrollLeft)을 이동  - event.preventDefault();로 기본 세로 스크롤 방지    <!DOCTYPE html>    <html>    <head>    &nb…
  • profile_image 자바와 자바스크립트는 직접적인 관계는 없습니다. 다만 문법이 C계열인 정도 인데 의미는 없습니다.의미가 없다는 의미는 자바스크립트 할줄 하는 개발자가 자바를 다르지 못하고 반대도 그렇다고 봐야 합니다.* 이런 생각도 가능!!  - 스크립트(SCRIPT) 비교적(프로그램에 비해) 간단한 형태를 말함  - JAVA + SCRIPT = 자바로 만들어진 스크립트?그런데 같은 줄 아는 사람이 있는 경우는 왜? 그런가사람이 모르는 것을 접할 때 기본적으로 생각하는 방향에 따라 생각 하는 것일 뿐입니다.즉, 사람들이 Java와 JavaScript를 같은 것으로 오해하는 이유는 주로 인지적 작용과 언어적 연상에서 기…
  • profile_image 중복된 처리를 제외하고자 할때 일정 부분 쿠키로 가지고 있다가 비교해서 동일한 것은 처리 하지 않기 위한것입니다.이것을 쿠키를 이용하는 방법이 있고 요즘은 로컬스토리지를 이용하는 방법도 있겠습니다. 특정 게시물의 번호나. 방문자의 로그를 저장하여 처리 하는 경우는 중복 처리 방지를 위한 간단한 방식 입니다.게시물의 경우 중복제외 처리를 하지 않으면 들쑥 날쑥 하지만 최고 30% 넘게 차이나는 경우도 있었습니다.  <!DOCTYPE html>  <html>  <head>      <title>Click Eve…
  • profile_image 블로그에 있는 datepicker는  안되는것이 많아서 사용할 일이 있어서 완성한것 올립니다.jquery는 버전이 다르면 안될 수 있으니 버전을 맞우는것이 중요하며 아래 순서도 중요합니다.jquery를 이용하기 때문에 jquery-ui가 아래에 있어야 한다는 것입니다. 그리고 jquery-ui 압축 파일을 받으면 아래와 같이 CDN 이용하지 않고 사이트에 올려 놓고 사용할 수 있으며 압축 파일 안에 아래 cdn 링크 걸린 모든 파일과 더불어 필요한 다른 파일들도 같이 모두 들어 있습니다. 같이 사용되는 jquery 도 별도 디렉토리에 있습니다.△ 아래 달력 datepicker(데이트티커)minDate …
  • profile_image Node Express는 Node.js와 Express.js를 결합하여 웹 애플리케이션 개발에 사용되는 프레임워크입니다. 이를 통해 비동기적인 서버 측 코드 작성과 HTTP 요청 및 응답 처리 등 다양한 웹 개발 작업을 보다 쉽게 처리할 수 있습니다.  1) 간단하게 띄울 프로그램을 하나 준비 서버가 잘 작동하는지 확인을 할 수 있는 간단한 프로그램을 준비 하도록 합니다.자신이 하는것이 디비커넥션이 들어가게 되면 이 부분도 간단하게 CRUD 프로그램 하나 준비 하면 됩니다.  const express = require('express');  const app    …
  • profile_image -g 옵션을 주어 글로벌로 설치한것이 아닌데 현재 디렉토리에 node_modules이 없고 다른곳에 설치 된경우는 아래처럼 초기화하면 package.json 파일이 생성 되고 현재 디렉토리에 node_modules 디렉토리가 생기면서 설치 됩니다. 아래와 같이 초기화 후 설치 하면 됩니다.  npm init -y  npm install express 그리고 초기화 했는데 안되는 경우는 시스템 로그인할때 홈 디렉토리나 또는 기본적으로 있어야할 스크립트 등이 없는 경우는 아닌지 살펴 보면 됩니다.예를 들면 bash shell의 경우 로그인 하면서 실행 되는 스크립트 들이 있습니다. 파일명…
  • profile_image 실제 파일은 있는데 없는다는 메시지가 나올 경우는 PATH 설정 값을 확인해 봐야 합니다.만약 whereis env 했는데 있다면 로그인할 때 실행되는 파일에 PATH 설정을 추가해 주면 됩니다./usr/local/nodejs/bin/npm install yarn/usr/bin/env: node: 그런 파일이나 디렉터리가 없습니다위와 같은 오류가 발생 하는 경우는 경로를 추가해 주면 된다.vim /etc/bashrcexport PATH=$PATH:/usr/local/nodejs/bin이 경우는 nodejs를 압축파일을 받아서 별도의 디렉토리에 압축을 풀고 심복릴 링크 처리한 경우 입니다.

상업적 이용 금지. 컨텐츠는 개인 용도로만 사용이 가능 합니다.