Skip to content

Latest commit

 

History

History
168 lines (126 loc) · 5.8 KB

README.md

File metadata and controls

168 lines (126 loc) · 5.8 KB

🗓️ 서울특별시 교육 공공서비스예약

화면 캡처 2024-08-20 092015

✍🏻 요약

서울특별시 교육 공공서비스예약 정보 API를 활용하여 현재 진행되고 있는 교육 공공서비스를 안내하고 지도 상에서 서비스를 진행하는 장소를 볼 수 있는 서비스입니다.

🔗 활용 API URL

⚙️ 기술 스택

  • JavaScript, HTML, CSS, swiper

✍🏻 주요 기능

1. 교육 공공서비스 예약의 서비스명, 지역명으로 검색기능 제공

서비스명은 input box로, 지역명은 select box로 나눠서 검색할 수 있습니다. 화면 캡처 2024-09-24 164256

2. 카테고리별 분류 기능 제공

swiper 라이브러리를 사용하여 카테고리를 슬라이더로 보여줍니다.

버튼을 클릭하면 해당 카테고리에 해당하는 교육 공공 서비스가 나타납니다.


화면 캡처 2024-09-24 164341

3. 각 데이터의 서비스 상태, 이미지, 서비스명, 서비스 대상, 서비스 날짜, 장소, URL 등 상세 정보 제공

화면 캡처 2024-09-24 164430

4. 지도로 해당 서비스 장소 확인 가능

화면 캡처 2024-09-24 164516

5. 반응형

상세정보는 모달을 통해 확인할 수 있습니다.

화면 캡처 2024-09-24 164548 화면 캡처 2024-09-24 165915

✍🏻 주요 코드 정리

과도한 API 요청을 막기 위해 클릭 후 일정 시간동안은 API 요청 전송을 지연하게끔 debounce를 사용했습니다.

function debounce(func, wait) {
  let timeout;
  return function (...args) {
    //이전에 설정된 타이머 초기화
    clearTimeout(timeout);
    timeout = setTimeout(() => func.apply(this, args), wait);
  };
}

fetch로 API 요청을 받아올 때, try-catch문을 사용하여 에러 처리를 하였습니다.

const url = `http://openAPI.seoul.go.kr:8088/${API_KEY}/json/ListPublicReservationEducation/`;

const searchParams = {
  pageBegin: (page - 1) * pageSize + 1,
  pageEnd: page * pageSize,
  minclass: "", // category
  svcname: "",
  target: "", // not use
  area: "",
};

let serviceDetailList = {};
let serviceLinkList = {};
let serviceXList = {};
let serviceYList = {};

let selectItem = "";
let searchValue = "";

const fetchList = async () => {
  //""이 falsy한 값이라 "%20"
  const newUrl =
    url +
    Object.values(searchParams)
      .map((param) => param || "%20")
      .join("/");

  console.log(newUrl);

  try {
    let serviceList = [];
    const res = await fetch(newUrl);
    const data = await res.json();

    totalResults = data.ListPublicReservationEducation.list_total_count;
    serviceList = data.ListPublicReservationEducation.row;

    console.log(data.ListPublicReservationEducation.row);

    serviceList.forEach((service) => {
      serviceDetailList[service.SVCID] = service.DTLCONT;
      serviceLinkList[service.SVCID] = service.SVCURL;
      serviceXList[service.SVCID] = service.X;
      serviceYList[service.SVCID] = service.Y;
    });
    renderList(serviceList);
    document.querySelector(".pagination").classList.remove("hidden");
    pagination();
  } catch (e) {
    console.error(e);
    //리스트가 없는 경우 처리?
    document.getElementById("listCon").innerHTML = `
      <div class='error'><p>검색결과가 없습니다.</p></div>
      `;
    document.querySelector(".pagination").classList.add("hidden");
  }
};

✍🏻 트러블 슈팅

  • 08/16 : Uncaught SyntaxError: Cannot use import statement outside a module

    원인
    HTML에서 JavaScript를 로드할 때, <script> 태그에 type="module" 속성이 없으면 JavaScript가 일반 스크립트로 간주됩니다.
    이 경우, import와 export 문을 사용할 수 없습니다.
    
    해결 방법
    <script type="module" src="./common.js" defer></script>
    type="module"을 적어줍니다.
    
  • 08/18 : Uncaught ReferenceError: movePage is not defined;

    원인
    이 문제는 주로 JavaScript 모듈(import/export)을 사용하는 경우 발생합니다.
    모듈 시스템에서는 JavaScript 코드를 기본적으로 모듈 범위로 보호하여, 각 모듈에서 정의된 변수나 함수는 다른 스크립트나 전역 범위에서 접근할 수 없습니다.
    
    해결 방법
    movePage 함수를 HTML에서 사용할 수 있도록 하기 위해, 함수가 전역 범위에 노출되도록 해야 합니다.
    
    //movePage 함수를 window 객체에 추가
    window.movePage = movePage;
    
    함수를 window 객체에 할당하면 전역 범위에서 접근할 수 있게 됩니다.
    
  • 08/19 : kakao.js:121 Uncaught TypeError: a.Lf is not a function

    원인
    map = new kakao.maps.Map(mapContainer, mapOption);
    이 코드를 함수 안에 넣어서 컨트롤이 map에 접근 못하는 오류입니다.
    
    해결 방법
    전역 변수로 설정하면 해결할 수 있습니다.