原創(chuàng)|使用教程|編輯:status|2020-02-11 16:03:41.240|閱讀 668 次
概述:在本教程中,我們將使用React和Django構建一個CRUD應用程序用來做圖書管理。CRUD代表創(chuàng)建,讀取,更新和刪除,本篇將講到后端部分。
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
相關鏈接:
在上一篇我們講到了#如何在myeclipse中用React和Django創(chuàng)建一個CRUD應用程序#的前端搭建部分,本篇將繼續(xù)講解如何利用使用Django構建Books API。
一、使用Django構建Books API
	我們將使用Django創(chuàng)建books API,創(chuàng)建一個新的虛擬項目:
如果尚未安裝pipenv ,則需要在終端中運行以下命令來安裝它:pip install pipenv
使用集成終端,激活pipenv shell以創(chuàng)建Django項目:pipenv shell
	
 
 
	
完成后,運行以下命令來安裝Django和Django REST Framework:
	
pipenv install django pipenv install django-rest-framework接下來,我們創(chuàng)建一個Django項目并創(chuàng)建一個Django應用。
	
	
django-admin startproject booksApi cd booksApi/ django-admin startapp books這將在books-api文件夾中創(chuàng)建新文件夾。更新INSTALLLED_APPS在settings.py包括書籍和Django的REST的框架。
	
	
# books-api/booksApi/booksApi/settings.py
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'rest_framework',
    'books',
]
我們的數(shù)據(jù)庫模型將僅包含Book模型。將以下內容添加到models.py
	
	
# books-api/booksApi/books/model.py.
from django.db import models
# Create your models here.
class Book(models.Model):
    title = models.CharField(max_length=200)
    description = models.TextField()
    author = models.CharField(max_length=200)
    created_at = models.DateTimeField(auto_now_add=True)
    def __str__(self):
        return '%s by %s' % (self.title, self.author)
我們的圖書模型包含4個字段:標題,描述,作者和created_at。python manage.py makemigrations python manage.py migrate接下來,我們將創(chuàng)建一個序列化器。序列化程序用于將我們的數(shù)據(jù)轉換為JSON,當我們訪問端點時將返回這些數(shù)據(jù)。
	
	
# books-api/booksApi/books/serializers.py.
from rest_framework import serializers
from .models import Book
class BookSerializer(serializers.ModelSerializer):
  class Meta:
    model = Book
    fields = ('id', 'title', 'author', 'description', 'created_at')
接下來,我們更新views.py以添加我們的API視圖。
	
	
# books-api/booksApi/books/views.py.
from .models import Book
from .serializers import BookSerializer
from rest_framework import generics
class BookList(generics.ListCreateAPIView):
    queryset = Book.objects.all()
    serializer_class = BookSerializer
class BookDetail(generics.RetrieveUpdateDestroyAPIView):
    queryset = Book.objects.all()
    serializer_class = BookSerializer
最后,我們需要添加端點。在books-api / booksApi / books中創(chuàng)建urls.py
	
	
# books-api/booksApi/books/urls.py.
from django.urls import path
from rest_framework.urlpatterns import format_suffix_patterns
from books import views
urlpatterns = [
    path('books/', views.BookList.as_view()),
    path('books//', views.BookDetail.as_view()),
]
然后將books-api / booksApi / booksApi / urls.py更新為:
	
	
# books-api/booksApi/booksApi/urls.py.
"""booksApi URL Configuration
The `urlpatterns` list routes URLs to views. For more information please see:
    //docs.djangoproject.com/en/3.0/topics/http/urls/
Examples:
Function views
    1. Add an import:  from my_app import views
    2. Add a URL to urlpatterns:  path('', views.home, name='home')
Class-based views
    1. Add an import:  from other_app.views import Home
    2. Add a URL to urlpatterns:  path('', Home.as_view(), name='home')
Including another URLconf
    1. Import the include() function: from django.urls import include, path
    2. Add a URL to urlpatterns:  path('blog/', include('blog.urls'))
"""
from django.contrib import admin
from django.urls import path
urlpatterns = [
    path('admin/', admin.site.urls),
    path('api/', include('books.urls')),
]
通過在Terminal +中運行以下代碼段來啟動Django服務器:
	
	
python manage.py runserver可以在http:// localhost:8000 / api / books /上查看端點。在我們在React應用中使用API之前,我們需要解決一個可能會出現(xiàn)的問題-CORS。運行以下命令以安裝軟件包以幫助CORS:
	
	
pipenv install django-cors-headers完成此操作后,像我們之前所做的那樣,將以下內容添加到settings.py中的INSTALLED_APPS列表中。我們還需要添加一些新的中間件。
	
	
# books-api/booksApi/booksApi/settings.py
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'rest_framework',
    'books',
    'corsheaders',
]
MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
    'corsheaders.middleware.CorsMiddleware',
    'django.middleware.common.CommonMiddleware',
]
最后,添加以下行以允許所有來源訪問API:
	
	
# books-api/booksApi/booksApi/settings.py CORS_ORIGIN_ALLOW_ALL = True使用集成終端運行服務器:
	
	
python manage.py runserver
	 
 
二、通過React使用API
我們將使用訪存來使用books API。將以下內容添加到index.js:
	
class BookDashboard extends React.Component {
    state = {
        books: []
    }
    componentDidMount() {
        fetch('//localhost:8000/api/books/')
            .then(response => response.json())
            .then(data => {
                this.setState({books: data});
            });
    }
...
}
如上所示,我們刪除了books數(shù)組的初始內容,僅使用一個空數(shù)組對其進行了初始化。createNewBook = (book) => {
    fetch('//localhost:8000/api/books/', {
        method: 'POST',
        headers: {
                'Content-Type': 'application/json',
        },
        body: JSON.stringify(book),
    })
    .then(response => response.json())
    .then(book => {
        this.setState({books: this.state.books.concat([book])});
    });
}
createNewBook將POST請求與從表單獲取的書籍數(shù)據(jù)一起發(fā)送到書籍a(chǎn)pi。API以新創(chuàng)建的書作為響應,其中包含一些其他數(shù)據(jù),例如id和created_at。updateBook = (newBook) => {
    fetch(`//localhost:8000/api/books/${newBook.id}/`, {
        method: 'PUT',
        headers: {
                'Content-Type': 'application/json',
        },
        body: JSON.stringify(newBook),
    }).then(response => response.json())
    .then(newBook => {
        const newBooks = this.state.books.map(book => {
            if(book.id === newBook.id) {
                return Object.assign({}, newBook)
            } else {
                return book;
            }
        });
        this.setState({books: newBooks});
    });
如上所示,我們正在將放置請求發(fā)送到url /。這顯示了我們要更新的書。如果更新成功,我們將更新狀態(tài)。deleteBook = (bookId) => {
    fetch(`//localhost:8000/api/books/${bookId}/`, {
        method: 'DELETE',
        headers: {
            'Content-Type': 'application/json',
        },
    })
    .then(() => {
        this.setState({books: this.state.books.filter(book => book.id !== bookId)})
    });
}
刪除操作可能是最簡單的。我們將DELETE請求發(fā)送到與更新相同的URL,delete操作不返回任何數(shù)據(jù),因此我們可以更新狀態(tài)。
	
	 
 
	
本站文章除注明轉載外,均為本站原創(chuàng)或翻譯。歡迎任何形式的轉載,但請務必注明出處、不得修改原文相關鏈接,如果存在內容上的異議請郵件反饋至chenjj@ke049m.cn
文章轉載自: