http://sir.co.kr/bbs/board.php?bo_table=pg_qa&wr_id=4055
이 글을 보고 간단히 만들어 봤습니다.
index.html
<!DOCTYPE html>
<html xmlns='http://www.w3.org/1999/xhtml'>
<head>
<title>Real-time Address</title>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<link href="stylesheet.css" media="screen" rel="stylesheet" type="text/css" />
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.min.js" type="text/javascript"></script>
<script src="application.js" type="text/javascript"></script>
</head>
<body>
<div id="content">
<select>
<option value="">광역시/도</option>
</select>
<select>
<option value="">시/도/군</option>
</select>
<select>
<option value="">읍/면/동</option>
</select>
</div>
</body>
</html>
stylesheet.css
body {
font-size: 12px;
background: #FFF;
color: #333;
margin: 0;
}
#content {
margin: 30px;
padding: 20px;
background: #7CF;
}
application.js
$(function() {
var uniqueId = 0;
function ajaxYqlWithJson(options) {
var callbackName = 'my_yql_callback_' + ++uniqueId;
window[callbackName] = options.callback;
var yql = 'SELECT * FROM json WHERE url="' + encodeURIComponent(options.url) + '"';
$.ajax({
url: 'http://query.yahooapis.com/v1/public/yql?q=' + yql +
'&format=json&callback=' + callbackName,
dataType: 'script',
complete: function() {
delete window[callbackName];
}
});
}
function createSelectCallback(index) {
return function(data) {
var select = $('select').eq(index);
$(data.query.results.result.subRegion).each(function(i, region) {
$('<option></option>').attr('value', region.code).text(region.name)
.appendTo(select);
});
};
}
function clearSelect(select) {
select.html(select.children().first());
}
function ajaxGetRegions(options) {
var level = options.level;
var code = options.code;
if (code && level <= 8) {
ajaxYqlWithJson({
url: 'http://map.naver.com/common2/getBRegionByCodeAndLevel.nhn' +
'?level=' + level + '&code=' + code,
callback: options.callback
});
}
}
$('select').each(function(index, select) {
$(select).change(function() {
for (var i = index + 1; i < $('select').length; i++) {
clearSelect($('select').eq(i));
}
ajaxGetRegions({
level: 2 + 3 * (index + 1),
code: $(this).val(),
callback: createSelectCallback(index + 1)
})
});
});
ajaxYqlWithJson({
url: 'http://map.naver.com/common2/getBRegionByCodeAndLevel.nhn?level=2',
callback: createSelectCallback(0)
});
});
이 글을 보고 간단히 만들어 봤습니다.
index.html
<!DOCTYPE html>
<html xmlns='http://www.w3.org/1999/xhtml'>
<head>
<title>Real-time Address</title>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<link href="stylesheet.css" media="screen" rel="stylesheet" type="text/css" />
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.min.js" type="text/javascript"></script>
<script src="application.js" type="text/javascript"></script>
</head>
<body>
<div id="content">
<select>
<option value="">광역시/도</option>
</select>
<select>
<option value="">시/도/군</option>
</select>
<select>
<option value="">읍/면/동</option>
</select>
</div>
</body>
</html>
stylesheet.css
body {
font-size: 12px;
background: #FFF;
color: #333;
margin: 0;
}
#content {
margin: 30px;
padding: 20px;
background: #7CF;
}
application.js
$(function() {
var uniqueId = 0;
function ajaxYqlWithJson(options) {
var callbackName = 'my_yql_callback_' + ++uniqueId;
window[callbackName] = options.callback;
var yql = 'SELECT * FROM json WHERE url="' + encodeURIComponent(options.url) + '"';
$.ajax({
url: 'http://query.yahooapis.com/v1/public/yql?q=' + yql +
'&format=json&callback=' + callbackName,
dataType: 'script',
complete: function() {
delete window[callbackName];
}
});
}
function createSelectCallback(index) {
return function(data) {
var select = $('select').eq(index);
$(data.query.results.result.subRegion).each(function(i, region) {
$('<option></option>').attr('value', region.code).text(region.name)
.appendTo(select);
});
};
}
function clearSelect(select) {
select.html(select.children().first());
}
function ajaxGetRegions(options) {
var level = options.level;
var code = options.code;
if (code && level <= 8) {
ajaxYqlWithJson({
url: 'http://map.naver.com/common2/getBRegionByCodeAndLevel.nhn' +
'?level=' + level + '&code=' + code,
callback: options.callback
});
}
}
$('select').each(function(index, select) {
$(select).change(function() {
for (var i = index + 1; i < $('select').length; i++) {
clearSelect($('select').eq(i));
}
ajaxGetRegions({
level: 2 + 3 * (index + 1),
code: $(this).val(),
callback: createSelectCallback(index + 1)
})
});
});
ajaxYqlWithJson({
url: 'http://map.naver.com/common2/getBRegionByCodeAndLevel.nhn?level=2',
callback: createSelectCallback(0)
});
});
댓글 6개
14년 전
서버 없이 돌아가는 코드를 만들기 위해 네이버 지도가 사용하는 API를 몰래 썼습니다.
실제로 서비스하실 땐 저 부분을 바꿔줘야겠죠? 그러면 YQL을 쓸 이유도 없구요.
실제로 서비스하실 땐 저 부분을 바꿔줘야겠죠? 그러면 YQL을 쓸 이유도 없구요.
14년 전
내공이 상당하신 분 같네요^^
좋은 팁 자주 올려주시면 감사하겠습니다~
좋은 팁 자주 올려주시면 감사하겠습니다~
14년 전
짧은 코드안에 jquery의 많은 부분이 심플하게 구성되어 있네요.
jquery 공부하는 입장에서도 좋은 소스같습니다.
감사합니다.
jquery 공부하는 입장에서도 좋은 소스같습니다.
감사합니다.
행복한남자
14년 전
감사합니다...^^
14년 전
서버에 올려놨습니다. 어떤 건지 결과물부터 보고 싶은 분은... http://j.mp/vRyafl
13년 전
와우~~ 대단하시네요 ....
멋지네요...
멋지네요...
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 7630 | 10년 전 | 633 | ||
| 7629 |
|
10년 전 | 2339 | |
| 7628 | 10년 전 | 768 | ||
| 7627 |
|
10년 전 | 997 | |
| 7626 |
|
10년 전 | 1756 | |
| 7625 | 10년 전 | 656 | ||
| 7624 | 10년 전 | 681 | ||
| 7623 |
|
10년 전 | 3002 | |
| 7622 | 10년 전 | 684 | ||
| 7621 |
leeleeleelee
|
10년 전 | 565 | |
| 7620 | 10년 전 | 524 | ||
| 7619 | 10년 전 | 449 | ||
| 7618 | 10년 전 | 994 | ||
| 7617 | 10년 전 | 712 | ||
| 7616 | 10년 전 | 606 | ||
| 7615 | 10년 전 | 701 | ||
| 7614 | 10년 전 | 1207 | ||
| 7613 |
|
10년 전 | 2047 | |
| 7612 | 10년 전 | 1116 | ||
| 7611 | 10년 전 | 1380 | ||
| 7610 |
|
10년 전 | 1872 | |
| 7609 |
|
10년 전 | 1288 | |
| 7608 |
mwdkim
|
10년 전 | 1092 | |
| 7607 |
|
10년 전 | 1020 | |
| 7606 |
mwdkim
|
10년 전 | 3897 | |
| 7605 | 10년 전 | 664 | ||
| 7604 | 10년 전 | 1002 | ||
| 7603 | 10년 전 | 1626 | ||
| 7602 |
|
10년 전 | 1041 | |
| 7601 |
AniNest
|
10년 전 | 2758 | |
| 7600 |
port443
|
10년 전 | 990 | |
| 7599 | 10년 전 | 915 | ||
| 7598 | 10년 전 | 988 | ||
| 7597 | 10년 전 | 4550 | ||
| 7596 |
SeungYeon
|
10년 전 | 865 | |
| 7595 |
untitled
|
10년 전 | 2386 | |
| 7594 |
프로그래머7
|
10년 전 | 1700 | |
| 7593 |
untitled
|
10년 전 | 2337 | |
| 7592 |
untitled
|
10년 전 | 1908 | |
| 7591 |
untitled
|
10년 전 | 2647 | |
| 7590 |
아리마2001
|
10년 전 | 820 | |
| 7589 | 10년 전 | 1078 | ||
| 7588 |
|
10년 전 | 2894 | |
| 7587 | 10년 전 | 1272 | ||
| 7586 | 10년 전 | 631 | ||
| 7585 | 10년 전 | 1655 | ||
| 7584 | 10년 전 | 1388 | ||
| 7583 |
leeleeleelee
|
10년 전 | 1123 | |
| 7582 |
|
10년 전 | 1070 | |
| 7581 | 10년 전 | 1302 | ||
| 7580 | 10년 전 | 942 | ||
| 7579 |
|
10년 전 | 579 | |
| 7578 | 10년 전 | 1387 | ||
| 7577 |
|
10년 전 | 1850 | |
| 7576 | 10년 전 | 1365 | ||
| 7575 |
멋진남자임
|
10년 전 | 1445 | |
| 7574 | 10년 전 | 2084 | ||
| 7573 | 10년 전 | 3212 | ||
| 7572 | 10년 전 | 745 | ||
| 7571 |
|
10년 전 | 770 | |
| 7570 |
|
10년 전 | 1286 | |
| 7569 | 10년 전 | 1519 | ||
| 7568 |
this1mg
|
10년 전 | 1021 | |
| 7567 |
|
10년 전 | 729 | |
| 7566 | 10년 전 | 888 | ||
| 7565 |
Angel하늘
|
10년 전 | 961 | |
| 7564 |
seoldi
|
10년 전 | 1195 | |
| 7563 |
|
10년 전 | 1345 | |
| 7562 |
멋진남자임
|
10년 전 | 2042 | |
| 7561 | 10년 전 | 679 | ||
| 7560 |
leeleeleelee
|
10년 전 | 877 | |
| 7559 | 10년 전 | 5008 | ||
| 7558 |
RinaP
|
10년 전 | 753 | |
| 7557 |
|
10년 전 | 1217 | |
| 7556 | 10년 전 | 1168 | ||
| 7555 |
hyohyojj1234
|
10년 전 | 1633 | |
| 7554 | 10년 전 | 1068 | ||
| 7553 |
senseme
|
10년 전 | 1321 | |
| 7552 |
ehdltdoit
|
10년 전 | 1413 | |
| 7551 |
|
10년 전 | 1794 | |
| 7550 |
leeleeleelee
|
10년 전 | 1558 | |
| 7549 | 10년 전 | 2393 | ||
| 7548 | 10년 전 | 1812 | ||
| 7547 |
멋진남자임
|
10년 전 | 1921 | |
| 7546 | 10년 전 | 964 | ||
| 7545 |
ILMare1003
|
10년 전 | 1254 | |
| 7544 |
|
10년 전 | 1210 | |
| 7543 | 10년 전 | 860 | ||
| 7542 | 10년 전 | 635 | ||
| 7541 |
울라라라우
|
10년 전 | 846 | |
| 7540 | 10년 전 | 1578 | ||
| 7539 | 10년 전 | 897 | ||
| 7538 |
|
10년 전 | 1807 | |
| 7537 | 10년 전 | 3587 | ||
| 7536 |
Gaumi
|
10년 전 | 1379 | |
| 7535 |
프로그램은어려워
|
10년 전 | 1241 | |
| 7534 |
senseme
|
10년 전 | 1191 | |
| 7533 | 10년 전 | 1165 | ||
| 7532 | 10년 전 | 833 | ||
| 7531 | 10년 전 | 2025 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기