ดาวไม่ได้ใช้งานดาวไม่ได้ใช้งานดาวไม่ได้ใช้งานดาวไม่ได้ใช้งานดาวไม่ได้ใช้งาน
 

การสร้างเว็บด้วย Django อย่างง่าย ด้วย Python Part 3  

 

ต่อจาก

การสร้างเว็บด้วย Django อย่างง่าย ด้วย Python Part 1

การสร้างเว็บด้วย Django อย่างง่าย ด้วย Python Part 2

 

การทำงานเกี่ยวกับฟอร์ม Python

 

1.สร้างโปรเจค Django  ชื่อ Studentinfo  ด้วยคำสั่ง 

...\scripts\mydjango>django-admin startproject helloapp <Enter>

 

2.เมื่อสร้างโปรเจคได้เเล้วให้เข้าไปในโฟล์เดอร์ที่สร้างโดยใช้คำสั่ง  CD studeninfo <Enter>

เมื่อเข้ามาในโฟล์เดอร์ Studeninfo เเล้ว ก็เริ่มสร้างเเอพกันเลย โดยชื่อแอพให้ตั้งชื่อว่า studentinfo โดยใช้คำสั่ง 

> python manage.py startapp studentinfo 

3.จากนั้นให้เราใส่ชื่อ App ใน settings.py ดังนี้  

 

4.เมื่อเราทำการใส่ชื่อ App ใน settings.py เเล้ว ขั้นต่อไปจะเป็นการ Migration ฐานข้อมูล โดยใช้คำสั่ง

> python manage.py migrate <Enter>

5.จากนั้นให้ทำการกำหนด Path ให้กับโปรเจคโดยใส่ path ของ app ใน studeninfo\studeninfo\urls.py

from django.contrib import admin
from django.urls import path
from django.conf.urls import url, include

urlpatterns = [
    path('admin/', admin.site.urls),
    path('',include('studentinfo.urls')),
]

 

6.เมื่อแก้ไขไฟล์ urls.py เสร็จเเล้ว ให้ Copy ไฟล์ตัวนี้ไปวางใน studentinfo หรือภายใน App ของเรา เเละทำการแก้ไข Url ภายในดังนี้ 

 

from django.urls import path
from django.conf.urls import url
from studentinfo import views

urlpatterns = [
    path('',views.HomePageView.as_view()),
    path('result/',views.index),
    
    
]

 

7. เมื่อทำการแก้ไขไฟล์ url ทั้ง 2 ที่เสร็จเรียบร้อยเเล้ว ให้เราทำการแก้ไขไฟล์ View.py ภายใน Studentinfo ตามตัวอย่างดังนี้ 

 

from django.shortcuts import render
from django.views.generic import TemplateView
from django.template import loader
from django.http import HttpResponse

# Create your views here.
class HomePageView(TemplateView):
    def get(self,request,**kwargs):
        return render(request, 'index.html', context=None)
def index(request):
    if request.method == 'POST':
        name = request.POST.get('name')
        email = request.POST.get('email')
        phone = request.POST.get('phone')

        context = {
            'name':name,
            'email':email,
            'phone':phone
        }
        template = loader.get_template('result.html')

        return HttpResponse(template.render(context,request))

    else :
            #if post request is not true
            #returning the form template
            template = loader.get_template('index.html')
            return HttpResponse(template.render())

 

8.สร้างโฟล์เดอร์ชื่อTemplateใน studentinfo หรือภายใน App ของผู้ใช้งาน จากนั้นสร้างไฟล์ Html ชื่อ index.html โดยโค้ดภายในจะมีดังนี้ 

 

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="utf-8">
        <title>Django Form</title>
    </head>
    <body>
        <h2>Django Form</h2>
        <form method="post" action="/result/">{% csrf_token %}
            <table>
                    <tr>
                            <td>Enter your name: </td>
                            <td><input type="text" name="name"/></td>
            
                    </tr>
                    <tr>
                        <td>Enter your email:</td>
                        <td><input type="email" name="email"/></td>
                    </tr>
                    <tr>
                        <td>Enter your phone:</td>
                        <td><input type="text" name="phone"/></td>
                    </tr>
                    <tr>
                        <td><button>Submit</button></td>
                        
                    </tr>
            </table>

        </form>
    </body>
</html>

 

9.เมื่อสร้างไฟล์ index เสร็จเรียบร้อยเเล้ว ให้คัดลอกโค้ด ไฟล์ index มา จากนั้นสร้างไฟล์ใหม่ชื่อ result.html 

 

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="utf-8">
        <title>ทดสอบรับข้อมูลจากฟอร์ม</title>
    </head>
    <body>
        <h2>Django Form</h2>
        <form method="post" action="/result/">
            <table>
                    <tr>
                            <td>Enter your name: </td>
                            <td><strong>{{ name }}</strong></td>
            
                    </tr>
                    <tr>
                        <td>Enter your email:</td>
                        <td><strong>{{ email }}</strong></td>
                    </tr>
                    <tr>
                        <td>Enter your phone:</td>
                        <td><strong>{{ phone }}</strong></td>
                    </tr>
                    <td><a href="/">ย้อนกลับ</a></td>
            </table>

        </form>
    </body>
</html>

 

10.ทดลองรันเซิร์ฟเวอร์ จะเเสดงผลดังนี้ 

 

 

เมื่อทำการกรอกข้อมูลจะได้เเสดงผลข้อมูลตามที่เราได้กรอกไป ดังนี้ 

 

 

เมื่อทำการกด Submit จะได้ผลลัพธ์ดังนี้ 

 

 

สรุปเมื่อการทำงาน เมื่อผู้ใช้งานทำการกรอกข้อมูล เช่น ชื่อ E-mail หรือเบอร์โทรศัพท์เข้าไป หน้าเว็บจะทำการเก็บข้อมูลเอาไว้ เเล้วนำไปแสดงผลที่หน้า result โดยการใช้คำสั่ง post ถ้าหากไม่มีการป้อนข้อมูล หรือข้อมูลไม่ครบระบบจะเเสดงหน้าผลลัพธ์เดิมออกมา จากการใช้ฟอร์มดังกล่าว ผู้ใช้งานสามารถนำฟอร์มดังกล่าวไปพัฒนาต่อหรือใช้ในการเก็บข้อมูลลงฐานข้อมูลได้

 

ช่องทางการศึกษาเพิ่มเติมข่าวที่น่าสนใจเกี่ยวกับ : Python

บทเรียนเกี่ยวกับ Python (166) 

ถาม - ตอบเกี่ยวกับเรื่อง Python (606)

ความรู้เกี่ยวกับ Python (261)

VDO สอนเขียน Python (51)

VDO สอนใช้ PostgreSQL (16) 

 

 

 

 

 

 

 

 

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
ตัวช่วยในคำนวณอัตราดอกเบี้ยสำหรับนักลงทุน
โดย prmindphp อ 24 ธ.ค. 2019 6:52 pm บอร์ด MindPHP News & Feedback
0
30
อ 24 ธ.ค. 2019 6:52 pm โดย prmindphp
วิธีการดึงกลุ่มของ phpbb มาสร้างเป็น listbox พร้อมเปลี่ยนชื่อกลุ่มตามภาษาที่กำหนด
โดย Ittichai_chupol อ 24 ธ.ค. 2019 6:35 pm บอร์ด PHP Knowledge
0
28
อ 24 ธ.ค. 2019 6:35 pm โดย Ittichai_chupol
R - ขั้นตอนการตรวจ สอบปัญหา ที่อาจจะเกิดขึ้น ตาม Systems Diagram
โดย mindphp อ 24 ธ.ค. 2019 12:12 pm บอร์ด MlineCRM Line + MD-CRM
0
2
อ 24 ธ.ค. 2019 12:12 pm โดย mindphp
ปฏิทินประจําปี 2563 มาในรูปแบบไซเบอร์ สำหรับคนสมัยใหม่ที่มีหัวคิดก้าวไกลเท่าทันเทคโนโลยี
โดย noppadonsk อ 24 ธ.ค. 2019 10:35 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
1
138
ส 04 ม.ค. 2020 4:38 am โดย mindphp
R - เพิ่ม Exception ตอน push ข้อมความ ไปที่ Line หรือ รับข้อความจาก Line ไม่ได้
โดย mindphp อ 24 ธ.ค. 2019 7:06 am บอร์ด MD-CRM - Tester
0
4
อ 24 ธ.ค. 2019 7:06 am โดย mindphp
B - เวลาใน Logs ไม่ตรง
โดย mindphp อ 24 ธ.ค. 2019 5:57 am บอร์ด MlineCRM Line + MD-CRM
0
3
อ 24 ธ.ค. 2019 5:57 am โดย mindphp
วางแผนเงินออมได้ง่ายๆ ด้วยโปรแกรมคำนวณหามูลค่าเงินในอนาคต
โดย prmindphp จ 23 ธ.ค. 2019 7:28 pm บอร์ด MindPHP News & Feedback
0
53
จ 23 ธ.ค. 2019 7:28 pm โดย prmindphp
ปฏิทินประจําปี 2563 ธีมแคมป์ กางเต้นท์ เดินป่า สายลุยๆไม่ควรพลาด
โดย noppadonsk จ 23 ธ.ค. 2019 5:10 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
1
661
พ 01 ม.ค. 2020 3:24 pm โดย mindphp
วิธีการปรับเปลี่ยนค่าการแสดงผลในหน้าแสดงบอร์ด ใน phpbb
โดย Ittichai_chupol ส 21 ธ.ค. 2019 5:48 pm บอร์ด PHP Knowledge
0
60
ส 21 ธ.ค. 2019 5:48 pm โดย Ittichai_chupol
จะทำอย่างไรจะแสดงข้อมูลในจำนวนตารางที่คงที่ได้ครับ
โดย jamepiyawat ส 21 ธ.ค. 2019 1:51 pm บอร์ด Programming - PHP
1
85
ส 21 ธ.ค. 2019 2:07 pm โดย thatsawan
วิธีการส่งค่า จาก Event หนึ่งไปยัง Event หนึ่ง ใน phpbb
โดย Ittichai_chupol ศ 20 ธ.ค. 2019 6:59 pm บอร์ด PHP Knowledge
0
60
ศ 20 ธ.ค. 2019 6:59 pm โดย Ittichai_chupol
โปรแกรมคำนวณหาจำนวนเงินผ่อนชำระ ตัวช่วยในการคำนวณเงินผ่อนเพื่อใช้ประกอบการตัดสินใจ
โดย prmindphp ศ 20 ธ.ค. 2019 5:58 pm บอร์ด MindPHP News & Feedback
0
59
ศ 20 ธ.ค. 2019 5:58 pm โดย prmindphp
ปฏิทินประจำปี 2563 ดอกไม้มงคลพืชสวยงาม -โหลดมาใช้กันเลยฟรี
โดย noppadonsk ศ 20 ธ.ค. 2019 1:55 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
1
3774
อ 24 ธ.ค. 2019 8:17 pm โดย mindphp
excel แบบวันที่เวลา ลงdatabase
โดย Anonymous ศ 20 ธ.ค. 2019 1:54 pm บอร์ด Programming - PHP
1
69
ศ 20 ธ.ค. 2019 2:03 pm โดย mindphp
ขอcode แปลงหน่วยนิ้ว เป็นเซ็นติเมตร ภาษา Java
โดย Anonymous ศ 20 ธ.ค. 2019 9:39 am บอร์ด Programming - PHP
0
1707
ศ 20 ธ.ค. 2019 9:39 am โดย บุคคลทั่วไป
โปรแกรมคำนวณสินเชื่อบ้าน เครื่องมือที่จะช่วยให้คุณคำนวณสินเชื่อบ้านได้ง่ายและรวดเร็ว
โดย prmindphp พฤ 19 ธ.ค. 2019 6:59 pm บอร์ด MindPHP News & Feedback
0
1717
พฤ 19 ธ.ค. 2019 6:59 pm โดย prmindphp
วิธีการแการแก้ไขข้อมูลโพสต์ ในระหว่างขั้นตอนการกดโพสต์ ของ phpbb
โดย Ittichai_chupol พฤ 19 ธ.ค. 2019 5:11 pm บอร์ด PHP Knowledge
0
530
พฤ 19 ธ.ค. 2019 5:11 pm โดย Ittichai_chupol
วิธีการใช้งานปรับลบข้อมูลลายเซ็นของ phpbb โดยใช้ Event ใน phpbb
โดย Ittichai_chupol พฤ 19 ธ.ค. 2019 2:57 pm บอร์ด PHP Knowledge
0
971
พฤ 19 ธ.ค. 2019 2:57 pm โดย Ittichai_chupol
ปฏิทินประจําปี 2563 ภูติผีปีศาจ - แจกฟรี
โดย noppadonsk พฤ 19 ธ.ค. 2019 2:16 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
1
1173
ส 04 ม.ค. 2020 4:38 am โดย mindphp
วิธีการใช้ JQuery เก็บ cookie เพื่อลดขั้นตอนการเปลี่ยนภาษาของแต่ละ user ใน phpbb
โดย Ittichai_chupol พฤ 19 ธ.ค. 2019 11:24 am บอร์ด Jquery & Ajax Knowledge
0
981
พฤ 19 ธ.ค. 2019 11:24 am โดย Ittichai_chupol