select박스를 이용해서 시 군 구를 구별하는 기능이 필요했다..
api를 쓰려고 했는데 호출할때 내게 필요한 데이터를 뽑아내는 작업이 생각보다 까다로웠다.
(나중에 이 부분은 어떻게 해야 내가 제대로 다룰 수 있을지 재탐색이 필요하다!)
그래서 db만 받아서 어떻게든 해보지 뭐 해며 데이터를 받았는다 csv파일로 제공이 되었다.
난 엑셀이 없다.
,...
파일을 내 입맛대로 수정해서 하고 싶었는데,
필요한 데이터에 비해 부가적인것이 너무 많았던 것이 많아 수정을 못하는 상황이라면 이 데이터도
쓰고싶지 않았다.
제이쿼리로 하는 경우도 봤지만 리액트 제이쿼리 추천 안하는 글을 봤기때문에
이 방법도 쓰기 싫었다.
그래서!!!
{
name: "서울",
subArea: [
"강남구",
"강동구",
"강북구",
"강서구",
"관악구",
"광진구",
"구로구",
"금천구",
"노원구",
"도봉구",
"동대문구",
"동작구",
"마포구",
"서대문구",
"서초구",
"성동구",
"성북구",
"송파구",
"양천구",
"영등포구",
"용산구",
"은평구",
"종로구",
"중구",
"중랑구",
],
},
{
name: "경기",
subArea: [
"고양시",
"과천시",
"광명시",
"광주시",
"구리시",
"군포시",
"김포시",
"남양주시",
"동두천시",
"부천시",
"성남시",
"수원시",
"시흥시",
"안산시",
"안성시",
"안양시",
"양주시",
"오산시",
"용인시",
"의왕시",
"의정부시",
"이천시",
"파주시",
"평택시",
"포천시",
"하남시",
"화성시",
"가평군",
"양평군",
"여주군",
"연천군",
],
},
{
name: "인천",
subArea: [
"계양구",
"미추홀구",
"남동구",
"동구",
"부평구",
"서구",
"연수구",
"중구",
"강화군",
"옹진군",
],
},
{
name: "대전광역시",
subArea: ["대덕구", "동구", "서구", "유성구", "중구"],
},
{
name: "대구광역시",
subArea: ["남구", "달서구", "동구", "북구", "서구", "수성구", "중구", "달성군"],
},
{
name: "부산광역시",
subArea: [
"강서구",
"금정구",
"남구",
"동구",
"동래구",
"부산진구",
"북구",
"사상구",
"사하구",
"서구",
"수영구",
"연제구",
"영도구",
"중구",
"해운대구",
"기장군",
],
},
{
name: "울산광역시",
subArea: ["남구", "동구", "북구", "중구", "울주군"],
},
{
name: "광주광역시",
subArea: ["광산구", "남구", "동구", "북구", "서구"],
},
{
name: "강원도",
subArea: [
"강릉시",
"동해시",
"삼척시",
"속초시",
"원주시",
"춘천시",
"태백시",
"고성군",
"양구군",
"양양군",
"영월군",
"인제군",
"정선군",
"철원군",
"평창군",
"홍천군",
"화천군",
"횡성군",
],
},
{
name: "충청북도",
subArea: [
"제천시",
"청주시",
"충주시",
"괴산군",
"단양군",
"보은군",
"영동군",
"옥천군",
"음성군",
"증평군",
"진천군",
"청원군",
],
},
{
name: "충청남도",
subArea: [
"계룡시",
"공주시",
"논산시",
"보령시",
"서산시",
"아산시",
"천안시",
"금산군",
"당진군",
"부여군",
"서천군",
"연기군",
"예산군",
"청양군",
"태안군",
"홍성군",
],
},
{
name: "경상북도",
subArea: [
"경산시",
"경주시",
"구미시",
"김천시",
"문경시",
"상주시",
"안동시",
"영주시",
"영천시",
"포항시",
"고령군",
"군위군",
"봉화군",
"성주군",
"영덕군",
"영양군",
"예천군",
"울릉군",
"울진군",
"의성군",
"청도군",
"청송군",
"칠곡군",
],
},
{
name: "경상남도",
subArea: [
"거제시",
"김해시",
"마산시",
"밀양시",
"사천시",
"양산시",
"진주시",
"진해시",
"창원시",
"통영시",
"거창군",
"고성군",
"남해군",
"산청군",
"의령군",
"창녕군",
"하동군",
"함안군",
"함양군",
"합천군",
],
},
{
name: "전라북도",
subArea: [
"군산시",
"김제시",
"남원시",
"익산시",
"전주시",
"정읍시",
"고창군",
"무주군",
"부안군",
"순창군",
"완주군",
"임실군",
"장수군",
"진안군",
],
},
{
name: "전라남도",
subArea: [
"광양시",
"나주시",
"목포시",
"순천시",
"여수시",
"강진군",
"고흥군",
"곡성군",
"구례군",
"담양군",
"무안군",
"보성군",
"신안군",
"영광군",
"영암군",
"완도군",
"장성군",
"장흥군",
"진도군",
"함평군",
"해남군",
"화순군",
],
},
{
name: "제주도",
subArea: ["서귀포시", "제주시"],
},
{
name: "경상남도",
subArea: [
"거제시",
"김해시",
"마산시",
"밀양시",
"사천시",
"양산시",
"진주시",
"진해시",
"창원시",
"통영시",
"거창군",
"고성군",
"남해군",
"산청군",
"의령군",
"창녕군",
"하동군",
"함안군",
"함양군",
"합천군",
],
},
];
자 길고 오히려 더 비효율적일것 같다고 느낄수도 있지만,
사실 api에서 죽쓰면서 보낸 시간과 db찾는 시간보다 절약 된 것이 나의 경우입니다.
const subAreas = areas.find((area) => area.name === selectedArea)?.subArea || [];
return (
<Area>
<select value={selectedArea} onChange={handleAreaChange}>
<option value="">지역을 선택해주세요</option>
{areas.map((area) => (
<option key={area.name} value={area.name}>
{area.name}
</option>
))}
</select>
{
<select value={selectedSubArea} onChange={handleSubAreaChange}>
<option value="">시,군,구를 선택해주세요</option>
{subAreas.map((subArea) => (
<option key={subArea} value={subArea}>
{subArea}
</option>
))}
</select>
}
</Area>
);
그리고 select박스를 이용해서 구현했습니다.
ㅋㅋㅋㅋㅋㅋㅋㅋㅋ 난 엑셀이 없다. 당찬글 잘 보고 갑니다ㅋㅋㅋㅋㅋㅋㅋㅋㅋ최고!!!