2017-09-01 23 views
0

我正在使用google maps api創建地圖。 JavaScript和knockout.js用於編碼。 每當我試圖asynchonously通過增加異步加載谷歌地圖API的腳本:來自google地圖api的異步請求 - 無法處理綁定錯誤

<script src async ="https://maps.googleapis.com/maps/api/js?v3.exp"></script> 

OR 

    <script async src="https://maps.googleapis.com/maps/api/js? 
    key=YOUR_API_KEY&callback=googleSuccess" onerror="googleError()"> 
    </script> 

我得到這個錯誤enter image description here

錯誤說:未捕獲的ReferenceError:無法處理綁定「值:函數(){回報pointFilter}「 消息:pointFilter沒有定義 但我已經定義了pointFilter可觀察。

如果我從請求中刪除異步,然後頁面正常運行。 我如何刪除此錯誤或有任何其他方式來執行此操作。 這些是我的文件index.html和main.js
由於字數限制,我無法包含完整的代碼。

的index.html

<!DOCTYPE html> 
    <!--[if lt IE 7]>  <html class="no-js lt-ie9 lt-ie8 lt-ie7"> <! 
    [endif]--> 
    <!--[if IE 7]>   <html class="no-js lt-ie9 lt-ie8"> <![endif]--> 
    <!--[if IE 8]>   <html class="no-js lt-ie9"> <![endif]--> 
    <!--[if gt IE 8]><!--> <html class="no-js"> <!--<![endif]--> 
    <head> 
    <meta charset="utf-8"> 
    <meta http-equiv="X-UA-Compatible" content="IE=edge"> 
    <title>New Delhi</title> 
    <meta name="viewport" content="width=device-width, initial-scale=1"> 
    <!-- CSS links--> 
    <link rel="stylesheet" href="css/main.css"> 
    <!-- JS links --> 
    <script src="js/vendor/modernizr-2.6.2-respond-1.1.0.min.js"></script> 
    <link rel="shortcut icon" href="favicon.ico" /> 
    <script> 
     window.jQuery || document.write('<script src="js/vendor/jquery- 
    1.11.2.min.js">\x3C/script>') 
    </script> 
    <!-- google maps api call--> 
    <script src async ="https://maps.googleapis.com/maps/api/js?v3.exp"> 
    </script> 
    <script src="js/vendor/knockout-3.2.0.js"></script> 
    <script src="js/main.js"></script> 

    </head> 
    <body> 
    <!--the map element will be used here and fill 100% of the screen--> 
    <div id="map"></div> 
    <!--this holds our entire listbox and search it will be added to map 
    controls--> 
    <div id="searchui"> 
     <!--is the checkbox options above the filter/search box--> 
     <div id="searchOptions" > 
      <label class="optionCheck"><input type="checkbox" 
    id="refitFilterCheck" data-bind="checked: refitFilterCheck"><span>refit 
    map on filter?</span></label> 
      <label class="optionCheck"><input type="checkbox" 
    id="refitResizeCheck" data-bind="checked: refitResizeCheck"><span>refit 
    map on window resize?</span></label> 
      <label class="optionCheck"><input type="checkbox" 
    id="searchCategoryCheck" data-bind="checked: searchCategoryCheck"> 
    <span>search name only?</span></label> 
     </div> 
     <!--this is the filter/search box--> 
     <input id="searchbox" type="search" placeholder="Search Here" data- 
    bind="value: pointFilter, valueUpdate: 'keyup'" autocomplete="off"> 
     <!--this is the points list--> 
     <ul id="pointList" data-bind="visible: listVisible, template: {name: 
    'pointsTemplate',foreach: shownList}"> 
     </ul> 
     <!--this is the list controls such as next page and collaps--> 
     <div id="listControls"> 
      <div id="pageControls" data-bind="display: listVisible"> 
       <div id="prevPage" data-bind="click: 
     changePage.bind($data,-1)"> 
        <strong data-bind="text: prevPageText"></strong> 
       </div> 
       <div id="pageNumText" data-bind="html: pageText"></div> 
       <div id="nextPage" data-bind="click: 
     changePage.bind($data,1)"> 
        <strong data-bind="text: nextPageText"></strong> 
       </div> 
      </div> 
      <div id="listRollup" data-bind="click: toggleList"> 
       <img id="rollupImg" data-bind="attr:{src: rollupIconPath, 
     alt: rollupText}" /> 
      </div> 
     </div> 


    </div> 

    <!--this is a knockout template used for point list items--> 
    <script type="text/html" id="pointsTemplate"> 
     <li data-bind="event: {mouseover: $parent.mouseHere, mouseleave: 
     $parent.mouseGone}, click:$parent.selectPoint, css: 
    $parent.getStyle($data)"> 
     <strong data-bind="text: name"></strong> 
     </li> 
    </script> 

    </body> 
    </html> 

main.js

var TheMap = function(){ 

this.Zoom = 10; 
this.mapOptions = { 
    zoom: this.Zoom, 
    panControl: false, 
    disableDefaultUI: true, 
    center: new google.maps.LatLng(28.6562,77.2410), 
    mapTypeId: google.maps.MapTypeId.ROADMAP 
    }; 

this.map = 
    new google.maps.Map(document.getElementById('map'), this.mapOptions); 
    }; 

    var viewModel = function(){ 
/* scope alias */ 
var self = this; 
/* clear session storage any time we load */ 
sessionStorage.clear(); 
/* how many items to show in filtered list max? */ 
/* sets based on window height to always fit a clean amount (min 1) */ 
self.maxListNum = 
    ko.observable(Math.max(1,Math.ceil(($(window).height() -150)/30))); 
//is the list visible right now? 1 = on, 0 = false; 
self.listVisible = ko.observable(1); 
/* which point is the first one on our list page right now? 
* actual page is calculated from this. Storing point instead 
* of page so that point can remain consistent when list resizes 
*/ 
    self.listPoint = ko.observable(1); 

/* make sure the google map api loaded before we do any work */ 
    if (typeof google !== 'object' || typeof google.maps !== 'object'){ 
    console.log("error loading google maps api"); 
    $('#searchbox').val("Error Loading Google Maps Api"); 
    $('#searchbox').css({'background-color' : 'rgba(255,0,0,0.3)'}); 
    //return early since we have no maps. No point in doing much else. 
    return; 
    } 

pointFilter聲明:

 self.pointFilter = ko.observable(''); 

/* calculated array containing just the filtered results from points()*/ 
self.shownPoints = ko.computed(function() { 
    return ko.utils.arrayFilter(self.points(), function(point) { 
      return (self.pointFilter() === '*' || 
       point.name.toLowerCase().indexOf(self.pointFilter(). 
        toLowerCase()) !== -1); 
    }); 
    }, self); 
+0

請將錯誤消息添加到您的問題,以便其他用戶可能會發現它時,他們谷歌。你得到的錯誤是「pointFilter」沒有定義。它不包含在你的視圖模型中。請更新代碼的相關部分。 –

+0

我編輯了我的問題,並添加了我聲明「pointFilter」的部分。 –

+0

你有沒有綁定的地方說:「value:function(){return pointFilter}」?在你發佈的頁面部分,你只有「value:pointFilter」... –

回答

0

你可能有你的API密鑰的問題。您可以使用google創建api密鑰,並使用剛剛創建的密鑰替換代碼YOU_API_KEY

但是,如果你已經有一個鍵,你的回調函數可能有錯誤。我不能幫你解決這個問題,因爲你不顯示你的回調函數。如果你有一個API鍵,請顯示回調函數。

如果您有任何疑問,請告訴我。