有几种方法可以与“外部”API 进行通信。没有必要使用ajax。Ajax 仅用于在模板中进行后台调用,触发您想到的任何事件。
但是,假设您想与 facebook GraphAPI 进行通信以检索配置文件
http://graph.facebook.com/bill.clinton
标准结果被序列化为 JSON,它很容易实现到 AJAX 或任何 JavaScript 库中,因此名称为 JavaScript Object Notation。
所以 AJAX 的一个例子可能是:
function callFacebook() {
$.ajax({
type: "GET",
data: ({}),
dataType: 'json',
url: "http://graph.facebook.com/bill.clinton",
success: function(data){
alert("Hi I am former "+data.name);
}
});
}
callFacebook();
将此包含在您的 javascript 文件中或脚本标记之间的模板中,您应该会收到一条很好的警报消息:
嗨,我是前总统比尔克林顿
现在你可以把这个警报变成更有意义的东西,并将它放在一个 h1 标签中(不知道为什么这是有意义的)
$("body").html("<h1>"+data.name+"</h1>");
但有时您可能希望在应用程序的服务器端检索数据并对其进行处理。
所以创建一个 django urlpattern 和视图,例如:
from urllib2 import urlopen
from django.http import HttpResponse
from django.utils import simplejson
def call_bill(request):
url = "http://graph.facebook.com/bill.clinton"
json = urlopen(url).read()
# do whatever you want
return HttpResponse(simplejson.dumps(json), mimetype="application/json")
# add this to your url patterns
url("^call_bill_clinton/$", call_bill)
现在访问您的网址
作为逻辑结果,也完全有可能通过某些用户操作触发异步事件。例如,前面提到的 ajax 示例中的 URL 参数也可以是 django url,如“/call_bill_clinton/”。
<!-- add a button to call the function -->
<button onclick="callFacebook();">Call Bill</button>
function callFacebook() {
$.ajax({
type: "GET",
data: ({}),
dataType: 'json',
url: "/call_bill_clinton/",
success: function(data){
alert("Hi I am former "+data.name+" and I came from Django");
}
});
)
// remove the auto call
此外,ajax 调用可以让你做和 http 请求一样的诡计,你可以使用各种请求方法结合很酷的 javascript 事件,比如 beforeSend 事件
beforeSend: function() {
$('#loading').show();
},
#loading 可能类似于:
<div id="loading" style="display:none;">
<img src="{% static "images/loading.gif" %}" />
</div>