This article is about how to serve static files in Django 2.0. Static files means javascript libraries like jquery, css files or images.
Jquery is an essential part of modern web development. When we use the templating system of django we need to do some steps to include jquery to it.
Sometimes you may try to access the static files by some methods it may not work properly and ends up in a 404 error.
I am explaining the process with an example application. This example includes a button. When click in it it will show an image.
This tutorial assumes that you have created a virual enviorment and django 2 project with mysite and app with myapp were created.
To read about how to create a virtual enviornment and install django go this link:- Install Python 3 and Set Up a Local Programming Environment
Open mysite/mysite/settings.py. Paste following line in the INSTALLED_APPS section
Then check following line is included in the INSTALLED_APPS section
Then check this line is exist in the same settings.py file
Then create a folder named static in myapp folder.
Create a folder named myapp inside it.
Download jquery and an image in this folder.
Then in the myapp folder create a folder named templates
Create another folder named myapp in it
Then create a file named index.html in it
Then paste the following code in it
Don't forget to add the line {% load static %} in the top of the page.
In this code {% static 'myapp/flower.jpg' %} flower.jpg can replace with the image you downloaded in the static folder.
Also in {% static 'myapp/jquery-3.3.1.min.js' %} jquery-3.3.1.min.js can replace with your jquery version.
Open the file myapp/views.py
Paste the following code in it
Create a file named urls.py in myapp folder
Then paste the following code in it
Next open Open mysite/mysite/urls.py.
Add an include keyword in the line
from django.urls import path
Now it will look like
Add this line in the urlpatterns section
Then run the command in mysite folder
Note that you must restart the development server in order to access static files.
Now open the url http://127.0.0.1:8000/myapp in any browser.It will show a button saying Show Image. Click it will show the image.
Watch the video tutorial (Click the gear icon and select video quality to 1080p HD, then click the full screen button for good quality)
Go to this link to subscribe to my YouTube channel to stay updated:- https://www.youtube.com/channel/UCxTp2yDew9m48Ch_hArOoYw
You can download the example app from here: https://dl.dropboxusercontent.com/s/zjssc3xgpzmxqnd/mysite.zip
Jquery is an essential part of modern web development. When we use the templating system of django we need to do some steps to include jquery to it.
Sometimes you may try to access the static files by some methods it may not work properly and ends up in a 404 error.
I am explaining the process with an example application. This example includes a button. When click in it it will show an image.
This tutorial assumes that you have created a virual enviorment and django 2 project with mysite and app with myapp were created.
To read about how to create a virtual enviornment and install django go this link:- Install Python 3 and Set Up a Local Programming Environment
Open mysite/mysite/settings.py. Paste following line in the INSTALLED_APPS section
'myapp.apps.MyappConfig'
Then check following line is included in the INSTALLED_APPS section
'django.contrib.staticfiles'
Then check this line is exist in the same settings.py file
STATIC_URL = '/static/'
Then create a folder named static in myapp folder.
Create a folder named myapp inside it.
Download jquery and an image in this folder.
Then in the myapp folder create a folder named templates
Create another folder named myapp in it
Then create a file named index.html in it
Then paste the following code in it
{% load static %}
<!DOCTYPE html>
<html>
<body>
<img width="400px" height="300px" style="display:none;" id="img" src="{% static 'myapp/flower.jpg' %}"/>
<br/>
<input type="button" value="Show Image" id="btn"/>
<script src="{% static 'myapp/jquery-3.3.1.min.js' %}"></script>
<script>
$(document).ready(function(){
$('#btn').click(function(){
$('#img').show();
});
});
</script>
</body>
</html>
<!DOCTYPE html>
<html>
<body>
<img width="400px" height="300px" style="display:none;" id="img" src="{% static 'myapp/flower.jpg' %}"/>
<br/>
<input type="button" value="Show Image" id="btn"/>
<script src="{% static 'myapp/jquery-3.3.1.min.js' %}"></script>
<script>
$(document).ready(function(){
$('#btn').click(function(){
$('#img').show();
});
});
</script>
</body>
</html>
Don't forget to add the line {% load static %} in the top of the page.
In this code {% static 'myapp/flower.jpg' %} flower.jpg can replace with the image you downloaded in the static folder.
Also in {% static 'myapp/jquery-3.3.1.min.js' %} jquery-3.3.1.min.js can replace with your jquery version.
Open the file myapp/views.py
Paste the following code in it
def index(request):
return render(request, 'myapp/index.html')
return render(request, 'myapp/index.html')
Create a file named urls.py in myapp folder
Then paste the following code in it
from django.urls import path
from . import views
urlpatterns = [
path('', views.index, name='index')
]
from . import views
urlpatterns = [
path('', views.index, name='index')
]
Next open Open mysite/mysite/urls.py.
Add an include keyword in the line
from django.urls import path
Now it will look like
from django.urls import path,include
Add this line in the urlpatterns section
path('myapp/', include('myapp.urls'))
Then run the command in mysite folder
python manage.py runserver
Note that you must restart the development server in order to access static files.
Now open the url http://127.0.0.1:8000/myapp in any browser.It will show a button saying Show Image. Click it will show the image.
Watch the video tutorial (Click the gear icon and select video quality to 1080p HD, then click the full screen button for good quality)
Go to this link to subscribe to my YouTube channel to stay updated:- https://www.youtube.com/channel/UCxTp2yDew9m48Ch_hArOoYw
You can download the example app from here: https://dl.dropboxusercontent.com/s/zjssc3xgpzmxqnd/mysite.zip
You sent me over from https://www.agiliq.com/blog/2013/03/serving-static-files-in-django/ but you did NOTHING to explain STATIC_URL, combined with your typos gets a big fat ZERO.
ReplyDeleteHA HA HA
DeleteThank you for sharing wonderful information with us to get some idea about it.
ReplyDeleteDjango Online Courses
Django Training in Hyderabad
Python Django Online Training
Python Django Training in Hyderabad