-
카테고리
-
세부 분야
풀스택
-
해결 여부
미해결
(index):121 Uncaught ReferenceError: kakao is not defined at (index):121:10
22.05.03 23:46 작성 조회수 426
0
목적지를 입력하세요 부분에 경희대학교를 포함한 어떤것을 입력해도 zoom이 되기는 커녕 마커도 뜨지 않습니다. f12를 눌러 콘솔에 들어가보면 제목과 같은 오류가 뜨고 (index):121 을 눌러보면 let ps = new kakao.maps.Services.Places(); 에서 new kakao.maps.Services.Places(); 부분에 빨간줄이 그어 있는것을 확인할 수 있습니다. 몇번을 확인해도 코드에서 문제점을 찾지 못했습니다. 어떤 부분에 문제가 있는지 알려주시면 감사하겠습니다!! 혹시 카카오 api 키 발급 및 적용에서 잘못이 있을까여? REST Api를 사용했고 플랫폼에서 Web에 https://localhost:3000도 등록했습니다.
다음은 index.ejs 코드입니다
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no">
<title>myfirstmap</title>
<link rel="stylesheet" href="/stylesheets/style.css"/>
<script type="text/javascript" src="https://openapi.map.naver.com/openapi/v3/maps.js?ncpClientId=a6xx165w2v"></script>
<script src="https://code.jquery.com/jquery-3.6.0.min.js"
integrity="sha256-/xUj+3OJU5yExlq6GSYGSHk7tPXikynS7ogEvDej/m4="
crossorigin="anonymous"></script>
<script type="text/javascript" src="//dapi.kakao.com"/v2/maps/sdk.js?appkey=6ae93f30966074b8be538be3257f65ac&libraries=services"></script>
</head>
<body>
<div id="navbar">myfirstmap</div>
<div id="infoBox">
<div id="infoTitle">현재날짜</div>
<div id="infoContent">2022.05.03</div>
</div>
<div id="search">
<input id="search_input" placeholder="목적지를 입력해 주세요" />
<button id="search_button">검색</button>
</div>
<div id="current">현재 위치</div>
<div id="map" style="width:100%;height:100vh;"></div>
<script type="text/javascript" src="/data/data.js"></script>
<script>
var mapOptions = {
center: new naver.maps.LatLng(37.3595704, 127.105399),
zoom: 10
};
var map = new naver.maps.Map('map', mapOptions);
var markerList =[];
var infowindowList =[];
for (var i in data){
var target = data[i];
var latlng = new naver.maps.LatLng(target.lat, target.lng);
marker = new naver.maps.Marker({
map : map,
position : latlng,
icon : {
content : "<div class='marker'></div>",
anchor: new naver.maps.Point(12, 12)
},
});
var content = `<div class='infowindow_wrap'>
<div class='infowindow_title'>${target.title}</div>
<div class='infowindow_content'>${target.content}</div>
<div class='infowindow_date'>${target.date}</div>
</div>`
var infowindow = new naver.maps.InfoWindow({
content : content,
backgroundColor : "#00ff0000",
borderColor : "#00ff0000",
anchorSize : new naver.maps.Size(0, 0)
})
markerList.push(marker);
infowindowList.push(infowindow);
}
for (var i = 0, ii = markerList.length; i < ii; i++){
naver.maps.Event.addListener(map, "click", ClickMap(i));
naver.maps.Event.addListener(markerList[i], "click", getClickHandler(i));
}
function ClickMap(i){
return function(){
var infowindow = infowindowList[i];
infowindow.close()
}
}
function getClickHandler(i){
return function(){
var marker = markerList[i];
var infowindow = infowindowList[i];
if(infowindow.getMap()){
infowindow.close();
} else{
infowindow.open(map, marker)
}
}
}
let currentUse = true;
$('#current').click(() => {
if('geolocation' in navigator){
navigator.geolocation.getCurrentPosition(function(position){
const lat = position.coords.latitude;
const lng = position.coords.longitude;
const latlng = new naver.maps.LatLng(lat, lng);
if (currentUse){
marker = new naver.maps.Marker({
map : map,
position : latlng,
icon : {
content : '<img class="pulse" draggable="false" unselectable="on" src="http://myfirstmap.s3.ap-northeast-2.amazonaws.com/circle.png">',
anchor: new naver.maps.Point(11, 11),
}
});
currentUse = false;
}
map.setZoom(14, false);
map.panTo(latlng);
});
}else {
alert("위치정보 사용 불가능");
}
});
let ps = new kakao.maps.services.Places();
let search_arr = []
$("#search_input").on("keydown" ,function(e){
if (e.keyCode === 13) {
let content = $(this).val();
ps.keywordSearch(content, placeSearchCB);
}
})
$("#search_button").on("click", function (e){
let content = $("#search_input").val();
ps.keywordSearch(content, placeSearchCB);
})
function placeSearchCB(data, status, pagination) {
if (status === kakao.maps.services.Status.OK){
let target = data[0];
const lat = target.y;
const lng = target.x;
const latlng = new naver.maps.LatLng(lat, lng);
marker = new naver.maps.Marker({
position: latlng,
map: map
})
if (search_arr.length == 0){
search_arr.push(marker)
}else{
search_arr.push(marker)
let pre_marker = search_arr.splice(0,1);
pre_marker[0].setMap(null);
}
map.setZoom(14, false);
map.panTo(latlng);
}else{
alert("검색결과가 없습니다.")
}
}
</script>
</body>
</html>
답변을 작성해보세요.
답변 0