流程
首先將 frontend
資料夾直接移動至 backend
資料夾內,因為最終是用後端的 Django 來 serve 前端的 React,所以目前整個專案的檔案結構應該會變成如下所示:
data:image/s3,"s3://crabby-images/1611c/1611c36e93bed18800b1860e6b9c2ec126151663" alt="move_frontend_to_backend"
前端 bundle
首先要讓前端程式不再處於開發模式,而是將其打包(bundle)成靜態檔,直接讓後端的 Django 讀取
1 2 3
| ❯ cd frontend ... ❯ npm run build
|
基本上成功後就能看到以下回傳:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| > frontend@0.1.0 build > react-scripts build
Creating an optimized production build... Compiled successfully.
File sizes after gzip:
130.92 kB build/static/js/main.1f4e7b1a.js 29.17 kB build/static/css/main.fb08168c.css
The project was built assuming it is hosted at /. You can control this with the homepage field in your package.json.
The build folder is ready to be deployed. You may serve it with a static server: ...
|
並且在 frontend
資料夾下會多出一個 build
資料夾,接下來就不需要在像之前一樣在 frontend
資料夾下執行 npm run start
,而是直接在 backend
資料夾下執行 python manage.py runserver
,Django 就會自動 serve 前端的 React 檔案
data:image/s3,"s3://crabby-images/45ad4/45ad4c49c855675df79e31e0f25aeb9962687042" alt="after_build_dirs"
修改 settings
回到 settings.py
,並在 TEMPLATES
的 DIRS
新增 os.path.join(BASE_DIR,"frontend/build")
,告訴 Django 去哪裡找我們前端的 Template 檔案
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
| ... TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [ os.path.join(BASE_DIR,"frontend/build"), ], 'APP_DIRS': True, 'OPTIONS': { 'context_processors': [ 'django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages', ], }, }, ]
|
回到 urls.py
中加入以下程式碼,告訴 Django 原本專案的根路由 ''
要載入 React 的 index.html
接下來此路由 path('', TemplateView.as_view(template_name='index.html'))
就能載入 React 的 index.html
1 2 3 4 5 6 7 8 9 10 11 12
| from django.views.generic import TemplateView
urlpatterns = [ path('admin/', admin.site.urls), path('', TemplateView.as_view(template_name='index.html')),
path('api/products/', include('api.urls.product_urls')), path('api/users/', include('api.urls.user_urls')), path('api/orders/', include('api.urls.order_urls')),
]
|
原本的 localhost:8000
是 Django 的後端頁面:
data:image/s3,"s3://crabby-images/30b3a/30b3a4cecbef39d043e5d78e28d1a86bea2b5163" alt="origin_port8000"
然後回到 settings.py
中加入以下程式碼,告訴 Django 去哪裡找我們的靜態檔案
1 2 3 4 5 6 7
|
STATICFILES_DIRS = [ BASE_DIR / 'static', BASE_DIR / 'frontend/build/static' ]
|
那接下來若有修改前端的程式碼,就是需要重新 build 一次,然後重新執行 python manage.py runserver
,就能看到修改後的結果,現在同樣到localhost:8000
就能直接看到寫好的前端頁面了
data:image/s3,"s3://crabby-images/079ca/079ca9cd2e086b0d3c7d596f101833e67fd8d357" alt="after_port8000"
若您覺得這篇文章對您有幫助,歡迎分享出去讓更多人看到⊂◉‿◉つ~
留言版