forked from Gongdongjang/consumer_server
-
Notifications
You must be signed in to change notification settings - Fork 0
/
postSearch.html
126 lines (96 loc) ยท 5.4 KB
/
postSearch.html
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
<!DOCTYPE html>
<html>
<head>
</head>
<body>
<!-- HELLO DAUM! -->
<!-- iOS์์๋ position:fixed ๋ฒ๊ทธ๊ฐ ์์, ์ ์ฉํ๋ ์ฌ์ดํธ์ ๋ง๊ฒ position:absolute ๋ฑ์ ์ด์ฉํ์ฌ top,left๊ฐ ์กฐ์ ํ์ -->
<div id="layer" style="display:block;position:fixed;overflow:hidden;z-index:1;-webkit-overflow-scrolling:touch;">
</div>
<script src="https://t1.daumcdn.net/mapjsapi/bundle/postcode/prod/postcode.v2.js"></script>
<!-- <script src="http://dmaps.daum.net/map_js_init/postcode.v2.js"></script> -->
<script>
window.addEventListener("message", onReceivedPostMessage, false);
function onReceivedPostMessage(event){
//..ex deconstruct event into action & params
var action = event.data.action;
var params = event.data.params;
console.log("onReceivedPostMessage "+event);
}
function onReceivedActivityMessageViaJavascriptInterface(json){
//..ex deconstruct data into action & params
var data = JSON.parse(json);
var action = data.action;
var params = data.params;
console.log("onReceivedActivityMessageViaJavascriptInterface "+event);
}
// ์ฐํธ๋ฒํธ ์ฐพ๊ธฐ ํ๋ฉด์ ๋ฃ์ element
var element_layer = document.getElementById('layer');
function sample2_execDaumPostcode() {
new daum.Postcode({
oncomplete: function(data) {
// ๊ฒ์๊ฒฐ๊ณผ ํญ๋ชฉ์ ํด๋ฆญํ์๋ ์คํํ ์ฝ๋๋ฅผ ์์ฑํ๋ ๋ถ๋ถ.
// ๊ฐ ์ฃผ์์ ๋
ธ์ถ ๊ท์น์ ๋ฐ๋ผ ์ฃผ์๋ฅผ ์กฐํฉํ๋ค.
// ๋ด๋ ค์ค๋ ๋ณ์๊ฐ ๊ฐ์ด ์๋ ๊ฒฝ์ฐ์ ๊ณต๋ฐฑ('')๊ฐ์ ๊ฐ์ง๋ฏ๋ก, ์ด๋ฅผ ์ฐธ๊ณ ํ์ฌ ๋ถ๊ธฐ ํ๋ค.
var fullAddr = data.address; // ์ต์ข
์ฃผ์ ๋ณ์
var extraAddr = ''; // ์กฐํฉํ ์ฃผ์ ๋ณ์
// ๊ธฐ๋ณธ ์ฃผ์๊ฐ ๋๋ก๋ช
ํ์
์ผ๋ ์กฐํฉํ๋ค.
if(data.addressType === 'R'){
//๋ฒ์ ๋๋ช
์ด ์์ ๊ฒฝ์ฐ ์ถ๊ฐํ๋ค.
if(data.bname !== ''){
extraAddr += data.bname;
}
// ๊ฑด๋ฌผ๋ช
์ด ์์ ๊ฒฝ์ฐ ์ถ๊ฐํ๋ค.
if(data.buildingName !== ''){
extraAddr += (extraAddr !== '' ? ', ' + data.buildingName : data.buildingName);
}
// ์กฐํฉํ์ฃผ์์ ์ ๋ฌด์ ๋ฐ๋ผ ์์ชฝ์ ๊ดํธ๋ฅผ ์ถ๊ฐํ์ฌ ์ต์ข
์ฃผ์๋ฅผ ๋ง๋ ๋ค.
fullAddr += (extraAddr !== '' ? ' ('+ extraAddr +')' : '');
}
var fullRoadAddr = data.roadAddress; // ๋๋ก๋ช
์ฃผ์ ๋ณ์
var extraRoadAddr = ''; // ๋๋ก๋ช
์กฐํฉํ ์ฃผ์ ๋ณ์
// ๋ฒ์ ๋๋ช
์ด ์์ ๊ฒฝ์ฐ ์ถ๊ฐํ๋ค. (๋ฒ์ ๋ฆฌ๋ ์ ์ธ)
// ๋ฒ์ ๋์ ๊ฒฝ์ฐ ๋ง์ง๋ง ๋ฌธ์๊ฐ "๋/๋ก/๊ฐ"๋ก ๋๋๋ค.
if(data.bname !== '' && /[๋|๋ก|๊ฐ]$/g.test(data.bname)){
extraRoadAddr += data.bname;
}
// ๊ฑด๋ฌผ๋ช
์ด ์๊ณ , ๊ณต๋์ฃผํ์ผ ๊ฒฝ์ฐ ์ถ๊ฐํ๋ค.
if(data.buildingName !== '' && data.apartment === 'Y'){
extraRoadAddr += (extraRoadAddr !== '' ? ', ' + data.buildingName : data.buildingName);
}
// ๋๋ก๋ช
, ์ง๋ฒ ์กฐํฉํ ์ฃผ์๊ฐ ์์ ๊ฒฝ์ฐ, ๊ดํธ๊น์ง ์ถ๊ฐํ ์ต์ข
๋ฌธ์์ด์ ๋ง๋ ๋ค.
if(extraRoadAddr !== ''){
extraRoadAddr = ' (' + extraRoadAddr + ')';
}
// ๋๋ก๋ช
, ์ง๋ฒ ์ฃผ์์ ์ ๋ฌด์ ๋ฐ๋ผ ํด๋น ์กฐํฉํ ์ฃผ์๋ฅผ ์ถ๊ฐํ๋ค.
if(fullRoadAddr !== ''){
fullRoadAddr += extraRoadAddr;
}
window.Android.processDATA(fullRoadAddr); // data.zonecode + ", " +
},
width : '100%',
height : '100%'
}).embed(element_layer);
// iframe์ ๋ฃ์ element๋ฅผ ๋ณด์ด๊ฒ ํ๋ค.
element_layer.style.display = 'block';
// iframe์ ๋ฃ์ element์ ์์น๋ฅผ ํ๋ฉด์ ๊ฐ์ด๋ฐ๋ก ์ด๋์ํจ๋ค.
initLayerPosition();
}
// ๋ธ๋ผ์ฐ์ ์ ํฌ๊ธฐ ๋ณ๊ฒฝ์ ๋ฐ๋ผ ๋ ์ด์ด๋ฅผ ๊ฐ์ด๋ฐ๋ก ์ด๋์ํค๊ณ ์ ํ์ค๋์๋
// resize์ด๋ฒคํธ๋, orientationchange์ด๋ฒคํธ๋ฅผ ์ด์ฉํ์ฌ ๊ฐ์ด ๋ณ๊ฒฝ๋ ๋๋ง๋ค ์๋ ํจ์๋ฅผ ์คํ ์์ผ ์ฃผ์๊ฑฐ๋,
// ์ง์ element_layer์ top,left๊ฐ์ ์์ ํด ์ฃผ์๋ฉด ๋ฉ๋๋ค.
function initLayerPosition(){
var width = (window.innerWidth || document.documentElement.clientWidth); //์ฐํธ๋ฒํธ์๋น์ค๊ฐ ๋ค์ด๊ฐ element์ width
var height = (window.innerHeight || document.documentElement.clientHeight); //์ฐํธ๋ฒํธ์๋น์ค๊ฐ ๋ค์ด๊ฐ 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';
}
</script>
</body>
</html>