2017-05-31 47 views
0

我正在創建一個webworks應用程序,因此我的代碼未放置在服務器上。從本地文件系統訪問時,youtube數據api不起作用,但它適用於我的應用程序。我需要一種解決方法,或者使用純js製作本地專用Web服務器,而不需要命令行工具。從文件運行YouTube數據api:///

       html 

<!DOCTYPE HTML> 
<html> 

    <head> 
    <title>add song</title> 
    <link type="text/css" href="../css/AS_Style.css" rel="stylesheet"> 
    </head> 

    <body> 

    <div id="main"> 
     <p id="response">a</p> 

     <form action="#"> 
     <p><input type="text" id="search" placeholder="Type something..." autocomplete="off" class="form-control" /></p> 
     <p><input type="submit" value="Search" class="form-control btn btn-primary w100"></p> 
     </form> 

     <div id="results"></div> 
    </div> 



    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script> 
    <script src="../js/AS.js"></script> 
    <script src="https://apis.google.com/js/api.js"></script> 
    <script> 
     function init() { 
     gapi.client.init({ 
      'apiKey':'key here', 
     }); 
     search(); 
     } 
     gapi.load('client',init); 
    </script> 

    </body> 

</html> 






           JavaScript 

function tplawesome(e,t){res=e;for(var n=0;n<t.length;n++){res=res.replace(/\{\{(.*?)\}\}/g,function(e,r){return t[n][r]})}return res} 


function search() { 
    $("form").on("submit", function(e) { 
     e.preventDefault(); 
     // prepare the request 
     var request = gapi.client.youtube.search.list({ 
      part: "snippet", 
      type: "video", 
      q: encodeURIComponent($("#search").val()).replace(/%20/g, "+"), 
      maxResults: 3, 
      order: "viewCount", 
     }); 
     // execute the request 
     request.execute(function(response) { 
      var results = response.result; 
      $("#results").html(""); 
      $.each(results.items, function(index, item) { 
      $.get("item.html", function(data) { 
       $("#results").append(tplawesome(data, [{"title":item.snippet.title, "videoid":item.id.videoId}])); 
      }); 
      }); 
      resetVideoHeight(); 
     }); 
    }); 

    $(window).on("resize", resetVideoHeight); 
}; 

function resetVideoHeight() { 
    $(".video").css("height", $("#results").width() * 9/16); 
} 

回答

0

你可以顯示你用來調用Youtube API的代碼嗎?您可以使用純JavaScript獲得API數據:

var xhr = new XMLHttpRequest(); xhr.open("GET", " https://www.googleapis.com/youtube/v3/channels?part=contentDetails&id=CHANNEL_ID&maxResults=1&fields=items&order=date&key=API_KEY ", false); xhr.send(); document.write(xhr.responseText);

你嘗試通過JavaScript觸發一個shell腳本,使得shell腳本運行API代碼?

顯然,這個工作:https://stackoverflow.com/a/21484756/7922428

0

的Youtube API不工作沒有連接到互聯網,這時候你的本地測試,通過本地服務器來完成。

這裏是我的建議: