中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Django使用AJAX調用自己寫的API接口的方法

發布時間:2020-10-04 19:20:33 來源:腳本之家 閱讀:343 作者:派派森森 欄目:開發技術

在這個例子中,我們將使用Django編寫餓了么高校外賣商家查詢API接口,并且使用AJAX技術來實現API接口的使用,包括使用ajax get方法加載更多數據,使用ajax方法來更新、修改、新增、刪除數據。利用API可以做到前后端分離,為開發web應用提供了便利。

 安裝rest framework

首先使用Pycharm新建一個Django項目,并且使用virtualenv或者pipenv虛擬環境

Django使用AJAX調用自己寫的API接口的方法

創建成功會自動安裝Django2.1和所需依賴,restframework框架需要自己手動安裝

//激活虛擬環境安裝以下
(venv)$ pip install djangorestframework
(venv)$ pip install django-filter 
(venv)$ pip install pytest
(venv)$ pip install pytest-django 
//由于筆者使用Postgresql數據庫,所以還需要安裝以下
(venv)$ pip install psycopg2
//使用mysql數據庫安裝如下
(venv)$ pip install pymysql

準備數據來提供服務

數據來源:餓了么爬蟲

數據內容:全國所有大學附近的外賣商家Top20

數據需要導入數據庫

Django使用AJAX調用自己寫的API接口的方法

Django編寫rest api接口

項目結構

Django使用AJAX調用自己寫的API接口的方法

settings.py.

// 安裝的app如下
INSTALLED_APPS = [
 #...
 'rest_framework',
 'django_filters',
 'api.apps.ApiConfig',
 'front.apps.FrontConfig',
]
//restframework 配置如下
REST_FRAMEWORK = {
//這里配置了分頁處理,每頁最多20個項目
'DEFAULT_PAGINATION_CLASS':'api.custompagination.LimitOffsetPaginationWithUpperBound',
 'PAGE_SIZE': 20,
 'DEFAULT_FILTER_BACKENDS': (
 //這里配置了排序、過濾、搜索器
 'django_filters.rest_framework.DjangoFilterBackend',
 'rest_framework.filters.OrderingFilter',
 'rest_framework.filters.SearchFilter',
 ),
 //這里配置了用戶認證,管理員才可以更改內容,未登錄不能更改
 'DEFAULT_AUTHENTICATION_CLASSES':(
 'rest_framework.authentication.BasicAuthentication',
 'rest_framework.authentication.SessionAuthentication',
 ),
 //這里配置了訪問次數限制,過多會返回429錯誤 too many requests
 'DEFAULT_THROTTLE_CLASSES': (
 'rest_framework.throttling.AnonRateThrottle',
 'rest_framework.throttling.UserRateThrottle',
 ),
 //這里配置了訪問次數,anon代表匿名用戶,user代表已登錄用戶,entries是我自己設置的作用域,300/hour代表最多300次每小時
 'DEFAULT_THROTTLE_RATES': {
 'anon': '300/hour',
 'user': '100/hour',
 'entries': '200/hour',
 },
 'DEFAULT_VERSIONING_CLASS':'rest_framework.versioning.NamespaceVersioning',
}

models.py.

from django.db import models
class Entry(models.Model):
 city = models.CharField(max_length=50)
 school = models.CharField(max_length=100)
 link = models.CharField(max_length=100,null=True,default='null')
 name = models.CharField(max_length=200)
 lat = models.CharField(max_length=20,null=True,default='0.0')
 lng = models.CharField(max_length=20,null=True,default='0.0')
 address = models.CharField(max_length=200,null=True,default='null')
 distance = models.CharField(max_length=20,null=True,default='0')
 time = models.CharField(max_length=20,null=True,default='0:00')
 contact = models.CharField(max_length=200,null=True,default='null')
 score = models.CharField(max_length=10,null=True,default='0')
 comments = models.CharField(max_length=20,null=True,default='0')
 sell = models.CharField(max_length=20,null=True,default='0')
 image = models.CharField(max_length=200,null=True,default='null')
 owner = models.ForeignKey('auth.User',related_name='entries',on_delete=models.CASCADE)
 # class Meta:
 # ordering = ('name',)
 def __str__(self):
 return self.name

serializers.py.

from rest_framework import serializers
from api.models import Entry
//這里繼承自超鏈接模型序列器,用于把數據轉換為json格式,并且顯示鏈接
class EntrySerializer(serializers.HyperlinkedModelSerializer):
 owner = serializers.ReadOnlyField(source='owner.username')
 class Meta:
 model = Entry
 fields = ('url','pk','name','city','school','link','lat','lng','address','distance','time','contact',
 'score','comments','sell','image','owner')

views.py.

from rest_framework import generics
from rest_framework.response import Response
from rest_framework.reverse import reverse
from api.models import Entry
from api.serializers import EntrySerializer
from rest_framework import permissions
from rest_framework.permissions import IsAuthenticated
from rest_framework.throttling import ScopedRateThrottle
from api import custompermission
//這里是獲取所有數據,可實現HTTP get、Post、Option操作
class EntryList(generics.ListCreateAPIView):
 //限流自定義作用域
 throttle_scope = 'entries'
 throttle_classes = (ScopedRateThrottle,)
 queryset = Entry.objects.all()
 serializer_class = EntrySerializer
 name = 'entry-list'
 filter_fields = ('city','school','name')
 search_fields = ('school','city')
 ordering_fields = ('city')

 //管理員才能post操作創建新的數據
 permission_classes = (
 permissions.IsAuthenticatedOrReadOnly,
 custompermission.IsCurrentUserOwnerOrReadOnly,
 )
 def perform_create(self, serializer):
 serializer.save(owner=self.request.user)

//這里是獲取具體某一項的數據,可實現HTTP GET、PUT、PATCH、Option操作
class EntryDetail(generics.RetrieveUpdateDestroyAPIView):
 throttle_scope = 'entries'
 throttle_classes = (ScopedRateThrottle,)
 queryset = Entry.objects.all()
 serializer_class = EntrySerializer
 name = 'entry-detail'
 permission_classes = (
 permissions.IsAuthenticatedOrReadOnly,
 custompermission.IsCurrentUserOwnerOrReadOnly,
 )
//api根目錄
class ApiRoot(generics.GenericAPIView):
 name = 'api-root'
 def get(self, request, *args, **kwargs):
 return Response({
 'entries': reverse(EntryList.name, request=request),
 })

urls.py.

from django.urls import path
from api import views
urlpatterns = [
 path('entries/', views.EntryList.as_view(), name=views.EntryList.name),
 path('entry-detail/<int:pk>', views.EntryDetail.as_view(), name=views.EntryDetail.name),
 path('', views.ApiRoot.as_view(), name=views.ApiRoot.name)
]

ele/urls.py.

from django.urls import path,include
urlpatterns = [
 path('v1/',include('api.urls')),
 path('v1/api-auth/',include('rest_framework.urls')),
 path('',include('front.urls'))
] 

以下為啟動界面

Django使用AJAX調用自己寫的API接口的方法

Django使用AJAX調用自己寫的API接口的方法

到此為止非常簡單的api就寫完了,接下來就是自動化測試是否達到預期效果。 如圖,測試通過!

Django使用AJAX調用自己寫的API接口的方法

在程序中調用剛剛寫好的api

創建一個新的app并且添加到settings.py里面

(venv)$ python manage.py startapp front

做好的效果如下:點擊加載更多會觸發ajax

Django使用AJAX調用自己寫的API接口的方法

Django使用AJAX調用自己寫的API接口的方法

由于篇幅有限,這里貼出js代碼 使用ajax get請求剛剛寫好的api接口并且添加到表格中

myjs.js.

$('#load-more').click(function () {
 $.ajax({
 method:'GET',
 url:api_url,
 dataType:'json',
 success:function (data) {
 api_url = data['next'];
 if (api_url == null){
 $('#load-more').val('已加載全部');
 $('#load-more').attr('disabled',true);
 //api_url這里就是剛剛寫好的api接口
 api_url = 'v1/entries/';
 }
 var results = data['results'];
 for (i=0;i<results.length;i++){
 $('#ele-table-body').append(
 ' <tr>\n' +
 ' <th scope="col">'+results[i]['pk']+'</th>\n' +
 ' <th scope="col">'+results[i]['city']+'</th>\n' +
 ' <th scope="col"><a href="/detail/' + results[i]['pk'] +'" rel="external nofollow" >' + results[i]['name'] + '</a></th>\n' +
 ' <th scope="col">'+results[i]['school']+'</th>\n' +
 ' <th scope="col">'+results[i]['score']+'</th>\n' +
 ' </tr>'
 )
 }
 }
 })
 });

可以修改具體的一條數據,使用ajax patch方法提交數據。 注:PUT方法是修改所有數據,而PATCH方法是修改局部數據

Django使用AJAX調用自己寫的API接口的方法

myjs.js.

 $('#edit-confirm-btn').click(function () {
 var name = $('#name').val();
 var distance = $('#distance').val();
 var adderss = $('#address').val();
 var time = $('#time').val();
 var score = $('#score').val();
 var comments = $('#comments').val();
 var sell = $('#sell').val();
 var pk = $('#pk').val();
 $.ajax({
 type:'PATCH',
 url:'/detail/' + pk,
 data:{
 "name": name,
 "distance": distance,
 "address": adderss,
 "time": time,
 "score": score,
 "comments": comments,
 "sell": sell,
 },
 success:function (data) {
 if (data.status == 'ok'){
 console.log('success');
 location.reload();
 }
 }
 })
 })

本文通過一個小例子介紹了如何使用Django調用自己寫的api

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

东海县| 定远县| 阿坝县| 巴彦县| 赫章县| 碌曲县| 九台市| 淮北市| 通州区| 新宾| 富民县| 安阳县| 临泉县| 东乡| 彭山县| 仙居县| 乡城县| 富锦市| 梧州市| 江阴市| 成武县| 宣汉县| 武川县| 凤庆县| 榕江县| 迁西县| 兖州市| 花莲县| 屏东市| 红桥区| 宁夏| 柏乡县| 石柱| 定州市| 安西县| 晴隆县| 遵义县| 云南省| 乌审旗| 玉溪市| 渑池县|