2012-02-15 113 views
0

在我的網站我想添加事件到谷歌日曆使用javascript api.I改變了我的郵件。但我有錯誤的火蟲。Javascript谷歌日曆API不工作

這是我的代碼:

<html> 
<head> 
<script type="text/javascript" src="http://www.google.com/jsapi"> 
google.load("gdata", "1"); 
google.setOnLoadCallback(getMyFeed); 
</script> 
</head> 
<body> 
<script type="text/javascript"> 
var myService; 
var feedUrl = "http://www.google.com/calendar/feeds/[email protected]/private/full"; 
function logMeIn() { 
    scope = "http://www.google.com/calendar/feeds/"; 
    var token = google.accounts.user.login(scope); 
} 
function setupMyService() { 
    myService = new google.gdata.calendar.CalendarService('exampleCo-exampleApp-1'); 
    logMeIn(); 
} 
function getMyFeed() { 
    setupMyService(); 

myService.getEventsFeed(feedUrl, handleMyFeed, handleError); 
} 

function handleMyFeed(myResultsFeedRoot) { 
    alert("This feed's title is: " + myResultsFeedRoot.feed.getTitle().getText()); 
} 

function handleError(e) { 
    alert("There was an error!"); 
    alert(e.cause ? e.cause.statusText : e.message); 
} 

// Create the calendar service object 
var calendarService = new google.gdata.calendar.CalendarService('GoogleInc-jsguide-1.0'); 

// The default "private/full" feed is used to insert event to the 
// primary calendar of the authenticated user 
var feedUri = 'https://www.google.com/calendar/feeds/default/private/full'; 

// Create an instance of CalendarEventEntry representing the new event 
var entry = new google.gdata.calendar.CalendarEventEntry(); 

// Set the title of the event 
entry.setTitle(google.gdata.Text.create('JS-Client: insert event')); 

// Create a When object that will be attached to the event 
var when = new google.gdata.When(); 

// Set the start and end time of the When object 
var startTime = google.gdata.DateTime.fromIso8601("2008-02-10T09:00:00.000-08:00"); 
var endTime = google.gdata.DateTime.fromIso8601("2008-02-10T10:00:00.000-08:00"); 
when.setStartTime(startTime); 
when.setEndTime(endTime); 

// Add the When object to the event 
entry.addTime(when); 

// The callback method that will be called after a successful insertion from insertEntry() 
var callback = function(result) { 
    PRINT('event created!'); 
} 

// Error handler will be invoked if there is an error from insertEntry() 
var handleError = function(error) { 
    PRINT(error); 
} 

// Submit the request using the calendar service object 
calendarService.insertEntry(feedUri, entry, callback, handleError, google.gdata.calendar.CalendarEventEntry); 
</script> 
<form> 
<input type="button" value="Start" onClick="getMyFeed()" /> 
</form> 
</body> 
</html> 

當我點擊該按鈕STRAT我得到一個錯誤:

google.gdata is undefined 

...Service = new google.gdata.calendar.CalendarService('exampleCo-exampleApp-1'... 

什麼是我的代碼的問題?

回答

-1

在存在之前,您正在致電google.gdata。讀取你的代碼,看起來你正在動態加載gdata庫。它看起來像getMyFeed將被加載調用。因此,在執行getMyFeed之前,不要嘗試訪問google.gdata

我還建議將您的內聯腳本移動到您的頭部,尤其是在其他script標記之上。

+0

可以重新編寫代碼嗎? – 2012-02-16 03:37:02

1

用window.onload事件包裝所有的javascript代碼, 我認爲它會幫助你逃避「google.gdata is undefined」錯誤。