일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- gsap 기초
- 타입스크립트
- 트윈맥스 기초
- React-Native 공부
- reactnative 웹뷰 페이지 로딩
- React Native navigation
- react native safeArea
- RN navitate push
- gsap
- JS
- SafeArea 커스텀
- js 특정 위치로 이동
- rn webview page loading
- React-Native IOS
- styled component
- input 숫자입력
- 프론트앤드
- react
- styled component is not working
- react이론
- 웹뷰 페이지 로딩
- scrollIntoView scrollTo
- styled component 작동안함
- 퍼블리셔
- slick slider 간격
- 임고미
- styled component 작동 안될때
- React Native SafeArea Custom
- safari wiondow.open
- 리액트
Archives
- Today
- Total
개발공부 임고미
[Javascript] Daum 우편번호 서비스 사용하기 본문
728x90
300x250
통합 로딩방식을 이용한 서비스 사용방법
1. html하단에 아래와 같은 script를 로드합니다.
//html
<script src="https://t1.daumcdn.net/mapjsapi/bundle/postcode/prod/postcode.v2.js"></script>
2. 어떻게 보여줄 것인지 선택하기
- iframe방식과 팝을을 이용하는 방법
팝업이 더 편리하기는 하나, 아래와 같은 경고문을 발견하였다.
몇몇 Webview기반 브라우저의 window.open 미대응으로 인하여, Webview기반 서비스에 적용시 embed()를 이용한 레이어모드를 추천합니다.
그러므로, iframe을 이용하여 레이어를 띄우기로 결정
3. 예제코드 확인하고 가져오기
postcode.map.daum.net/guide#sample
<script>
// 우편번호 찾기 화면을 넣을 element
var element_layer = document.getElementById('layer');
function closeDaumPostcode() {
// iframe을 넣은 element를 안보이게 한다.
element_layer.style.display = 'none';
}
function sample2_execDaumPostcode() {
new daum.Postcode({
oncomplete: function(data) {
// 검색결과 항목을 클릭했을때 실행할 코드를 작성하는 부분.
// 각 주소의 노출 규칙에 따라 주소를 조합한다.
// 내려오는 변수가 값이 없는 경우엔 공백('')값을 가지므로, 이를 참고하여 분기 한다.
var addr = ''; // 주소 변수
var extraAddr = ''; // 참고항목 변수
//사용자가 선택한 주소 타입에 따라 해당 주소 값을 가져온다.
if (data.userSelectedType === 'R') { // 사용자가 도로명 주소를 선택했을 경우
addr = data.roadAddress;
} else { // 사용자가 지번 주소를 선택했을 경우(J)
addr = data.jibunAddress;
}
// 사용자가 선택한 주소가 도로명 타입일때 참고항목을 조합한다.
if(data.userSelectedType === 'R'){
// 법정동명이 있을 경우 추가한다. (법정리는 제외)
// 법정동의 경우 마지막 문자가 "동/로/가"로 끝난다.
if(data.bname !== '' && /[동|로|가]$/g.test(data.bname)){
extraAddr += data.bname;
}
// 건물명이 있고, 공동주택일 경우 추가한다.
if(data.buildingName !== '' && data.apartment === 'Y'){
extraAddr += (extraAddr !== '' ? ', ' + data.buildingName : data.buildingName);
}
// 표시할 참고항목이 있을 경우, 괄호까지 추가한 최종 문자열을 만든다.
if(extraAddr !== ''){
extraAddr = ' (' + extraAddr + ')';
}
// 조합된 참고항목을 해당 필드에 넣는다.
document.getElementById("sample2_extraAddress").value = extraAddr;
} else {
document.getElementById("sample2_extraAddress").value = '';
}
// 우편번호와 주소 정보를 해당 필드에 넣는다.
document.getElementById('sample2_postcode').value = data.zonecode;
document.getElementById("sample2_address").value = addr;
// 커서를 상세주소 필드로 이동한다.
document.getElementById("sample2_detailAddress").focus();
// iframe을 넣은 element를 안보이게 한다.
// (autoClose:false 기능을 이용한다면, 아래 코드를 제거해야 화면에서 사라지지 않는다.)
element_layer.style.display = 'none';
},
width : '100%',
height : '100%',
maxSuggestItems : 5
}).embed(element_layer);
// iframe을 넣은 element를 보이게 한다.
element_layer.style.display = 'block';
// iframe을 넣은 element의 위치를 화면의 가운데로 이동시킨다.
initLayerPosition();
}
// 브라우저의 크기 변경에 따라 레이어를 가운데로 이동시키고자 하실때에는
// resize이벤트나, orientationchange이벤트를 이용하여 값이 변경될때마다 아래 함수를 실행 시켜 주시거나,
// 직접 element_layer의 top,left값을 수정해 주시면 됩니다.
function initLayerPosition(){
var width = 300; //우편번호서비스가 들어갈 element의 width
var height = 400; //우편번호서비스가 들어갈 element의 height
var borderWidth = 5; //샘플에서 사용하는 border의 두께
// 위에서 선언한 값들을 실제 element에 넣는다.
element_layer.style.width = width + 'px';
element_layer.style.height = height + 'px';
element_layer.style.border = borderWidth + 'px solid';
// 실행되는 순간의 화면 너비와 높이 값을 가져와서 중앙에 뜰 수 있도록 위치를 계산한다.
element_layer.style.left = (((window.innerWidth || document.documentElement.clientWidth) - width)/2 - borderWidth) + 'px';
element_layer.style.top = (((window.innerHeight || document.documentElement.clientHeight) - height)/2 - borderWidth) + 'px';
}
출력결과
4. 완성!
단, iframe으로 가져오고난 뒤 style이 제대로 적용되어있지 않으므로 스타일을 수정해줘야합니다.
참고 !
사용하고 있는 api가 https 인데 로든한 daum지도가 (위에 적어놓은 src) http를 사용하면
보안 콘텐츠관련 하단 경고가 나타날 수 있다.
이를 해결 하기위해선 ?
<script src=“https://ssl.daumcdn.net/dmaps/map_js_init/postcode.v2.js”></script>
로 수정해준다!
728x90
300x250
'퍼블리싱 > html css js' 카테고리의 다른 글
[Java script] 플러그인 사용안하고 정규식 체크(Validate) (0) | 2020.09.10 |
---|---|
[Java script] 객체 빈값 확인하기 (0) | 2020.09.10 |
[Javascript] flatpickr를 이용해 간단한 달력만들기 (0) | 2020.09.08 |
[Javascript] 웹브라우저 뒤로가기버튼 제어하기 (0) | 2020.09.04 |
[리액트]less , font 적용하기 (0) | 2020.09.02 |
Comments