리액트 타입스크립트 시,군,구 구현.

임성은·2023년 3월 16일
5

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박스를 이용해서 구현했습니다.

profile
개발자의 길에 당차게 들어서다!!

2개의 댓글

comment-user-thumbnail
2023년 3월 17일

ㅋㅋㅋㅋㅋㅋㅋㅋㅋ 난 엑셀이 없다. 당찬글 잘 보고 갑니다ㅋㅋㅋㅋㅋㅋㅋㅋㅋ최고!!!

답글 달기
comment-user-thumbnail
2023년 5월 17일

성은님, 반가워요! 저도 메인프로젝트 때 시군구 api 찾다가 결국 저도 하드코딩으로 데이터 만들었어요 ㅋㅋㅋㅋㅋㅋㅋㅋ 내적 반가움 x 100 상승

답글 달기