bbs項目解讀

来源:https://www.cnblogs.com/suncolor/archive/2022/08/16/16593446.html
-Advertisement-
Play Games

1.註冊功能 具體的效果圖如下: 註冊功能涉及到的邏輯步驟: 1.搭建前端html頁面 2.向後端提交用戶輸入數據 3.對用戶輸入的數據格式進行校驗 4.頁面輸入數據格式錯誤,及時向用戶進行提示/正確則保存到資料庫 所以,提到校驗和提交數據,這就需要我們用到forms組件!! 回顧一下forms組件 ...


1.註冊功能

具體的效果圖如下:

image

註冊功能涉及到的邏輯步驟:

1.搭建前端html頁面
2.向後端提交用戶輸入數據
3.對用戶輸入的數據格式進行校驗
4.頁面輸入數據格式錯誤,及時向用戶進行提示/正確則保存到資料庫

所以,提到校驗和提交數據,這就需要我們用到forms組件!!

回顧一下forms組件的功能:
1.生成頁面可用的html標簽
2.對用戶提交的數據進行校驗
3.保留上次內容並提示用戶

但是!!我們在做項目的時候,不可避免的可能需要用到很多forms組件!之前我們都是寫在views.py裡面的,但是這樣太過冗餘,為了接耦合,我們可以新建一個文件夾裡面專門放forms組件!!
image

	myforms文件夾
		regform.py
		loginform.py
		userform.py
		orderform.py

接下來我們詳細解讀一下forms組件部分、視圖函數部分和前端html部分的代碼~~

forms組件部分
from django import forms  # forms組件使用的時候需要先導入
from app01 import models   # 當校驗提交的用戶名是否和資料庫中的用戶名一樣時需要導入模型層

class MyForms2(forms.Form):  # 定義一個forms組件類,該類繼承forms.Form
    # forms.CharField為input框,在內部可以通過widget指定input框的類型和樣式attrs={}
    # min_length最小位數,max_length最大位數,label欄位名,不寫是預設的類中定義的欄位首字母大寫的形式
    # error_messages為頁面輸入數據格式不正確時提示的信息
    username = forms.CharField(min_length=3,max_length=8,label='用戶名',
                                widget=forms.TextInput(attrs={'class':'form-control'}),
                               error_messages={
                                   'required':'用戶名不能為空',
                                   'min_length':'用戶名最少3位',
                                   'max_length':'用戶名最多8位'
                               }
                               )
    password = forms.CharField(label='密碼',min_length=3,max_length=8,
                               widget=forms.PasswordInput(attrs={'class':'form-control'}),
                               error_messages={
                                   'required': '密碼不能為空',
                                   'min_length': '密碼最少3位',
                                   'max_length': '密碼最多8位'
                               }
                               )
    confirm_password = forms.CharField(label='確認密碼',min_length=3,max_length=8,
                                       widget=forms.PasswordInput(attrs={'class': 'form-control'}),
                                       error_messages={
                                           'required': '密碼不能為空',
                                           'min_length': '密碼最少3位',
                                           'max_length': '密碼最多8位'
                                       }
                                       )
    email = forms.EmailField(label='郵箱',
                             widget=forms.EmailInput(attrs={'class': 'form-control'}),
                            error_messages={
                                'invalid':'郵箱格式不正確',
                                'required':'郵箱不能為空',
                            }
                             )

    # 鉤子函數,校驗的第二道關卡,自定義校驗規則,然後返回到前端提示
    def clean_username(self): #類裡面定義的欄位對象會自動創建一個(clear_欄位對象名)的函數
        # 獲取用戶名,self.cleaned_data返回的是一個字典{},.get拿到key對應的值
        username = self.cleaned_data.get('username')
        # 判斷資料庫中是否存在當前用戶名
        is_exist = models.UserInfo.objects.filter(username=username)
        if is_exist:
            # 有則,報錯
            self.add_error('username','用戶名已經存在')
        # 將鉤子函數鉤去出來數據再放回去
        return username

    def clean(self):
        password = self.cleaned_data.get('password')
        confirm_password = self.cleaned_data.get('confirm_password')
        if password != confirm_password:
            self.add_error('confirm_password','兩次密碼不一致')
        # 將鉤子函數鉤出來數據再放回去,全拿出來就需要全放回去
        return self.cleaned_data

視圖函數部分
from django.shortcuts import render
from app02.myform2 import MyForms2
from django.http import HttpResponse
from app01 import models

def register2(request):
    # 產生一個空對象,將forms組件的欄位傳進來,再傳到html頁面
    form_obj = MyForms2()
    # form表單提交post觸發
    if request.method == 'POST':
        # 獲取form表單裡面的普通鍵值對
        form_obj = MyForms2(request.POST)
        # 獲取form表單的文件數據
        file = request.FILES.get('file')
        # 判斷數據是否合法
        if form_obj.is_valid():
            # 移除確認密碼,為**打散傳到資料庫做鋪墊
            form_obj.cleaned_data.pop('confirm_password')
            # 用戶提交了文件則觸發
            if file:
                # 往{}這樣的字典里添加了一個avatar的key和值
                form_obj.cleaned_data['avatar'] = file
            # 把字典打散了添加到資料庫
            models.UserInfo.objects.create_user(**form_obj.cleaned_data)
            # 數據合法之後,返回到另一個頁面
            return HttpResponse('ok')
    return render(request,'register2.html',locals())
html部分
向後端提交數據可以用form表單也可以用ajax提交

法1:form表單提交

<div class="container">  <!--bootstrap佈局-->
    <div class="row">
        <div class="col-md-8 col-md-offset-2">
{#            這裡我們採用了form表單向後端提交數據,form預設是提交的urlencoded的編碼格式,#}
{#            urlencoded的格式form表單隻會將普通鍵值對封裝到request.POST中,添加enctype="multipart/form-data",#}
{#            可以獲取普通鍵值對和文件。#}
            <form action="" novalidate method="post" enctype="multipart/form-data">
            {% csrf_token %}
                <h1 class="text-center">註冊</h1>
                {% for form in form_obj %}
                    <div class="form-group">
                        <label for="">{{ form.label }}</label>
                        {{ form }}
{#                       這裡是只有當以form表單提交的時候才會展示報錯信息,如果以ajax就不該以這樣的方式添加報錯信息#}
                    <span style="color: red">{{ form.errors.0 }}</span>
                    </div>
                {% endfor %}
                <div>
{#                    插入的圖片可以指定寬度width,以此來規定圖片的大小#}
                    <label for="myimg">頭像<img src="/static/img/default.png" alt="" width="80" id="myimg2" ></label>
{#                    添加display:none 來隱藏file文本框#}
                <input type="file" name="file" id="myimg" style="display: none">
                </div>
            <input type="submit" value="提交" class="btn-primary btn form-control">
            </form>
        </div>
    </div>
</div>
</body>
<script>
    // change 文本域變化事件,當myimg的文本域變化是觸發
    // 這一步是將提交的頭像動態的展示在前端頁面上
    $('#myimg').change(function (){
        {#引出一個文件閱讀器對象#}
        {#1.先生成一個文件閱讀器對象#}
    let fileDataObj = new FileReader();
    {#2.獲取用戶上傳的頭像#}
    let fileobj = $(this)[0].files[0];
    {#3.將文件對象交給閱讀器對象進行讀取#}
    fileDataObj.readAsDataURL(fileobj);
    {#4.利用文件閱讀器將圖片展示到前端頁面,就是修改img的src屬性#}
    {#這裡需要等文件閱讀器載入完畢在執行修改src屬性的操作#}
    fileDataObj.onload=function (){
        $('#myimg2').attr('src',fileDataObj.result) // fileDataObj.result是文件閱讀器對象讀取完畢文件的結果
    }
    })
</script>

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1 HTML定義 HTML(英文Hyper Text Markup Language的縮寫)中文譯為“超文本標簽語言”,主要是通過HTML標簽對網頁中的文本、圖片、聲音等內容進行描述。 <strong> 加粗字體 </strong> 2 HTML的骨架格式 <HTML> <head> <title> ...
  • 在React中上下文是一種通信方案。 上下文的特點 在組件樹中,是一種自上而下的單向數據流通信方案,數據只能從父組件註入,在子組件中訪問。 組件關係只要滿足“父組件-後代組件”這種關係時,都可以使用上下文通信。 在父組件中provide提供數據,在後代組件中註入並使用,這種通信不具有響應式,有點像v ...
  • 使用three.js(webgl)搭建智慧樓宇、設備檢測、數字孿生、物聯網3D、物業3D監控、物業基礎設施可視化運維、3D定位、三維室內定位、3d建築,3d消防,消防演習模擬,3d庫房,webGL,threejs,3d機房,bim管理系統 ...
  • HTTP 起源 HTTP 是由蒂姆·伯納斯-李(TimBerners—Lee)於1989年在歐洲核子研究組織(CERN)所發起 其中最著名的是 1999 年 6 月公佈的 RFC 2616,定義了 HTTP 協議中現今廣泛使用的一個版本——HTTP 1.1 HTTP 是什麼 全稱:超文本傳輸協議(H ...
  • 本文將探討一下,在多行文本情形下的一些有意思的文字動效。 多行文本,相對於單行文本,場景會複雜一些,但是在實際業務中,多行文本也是非常之多的,但是其效果處理比起單行文本會更困難。 單行與多行文本的漸隱 首先,我們來看這樣一個例子,我們要實現這樣一個單行文本的漸隱: 使用 mask,可以輕鬆實現這樣的 ...
  • 結構型模式所描述的是如何將類和對象結合在一起來形成一個更大的結構,它描述兩種不同的事物:類和對象,根據這一點,可分為類結構型和對象結構型模式。類結構型模式關心類的組合,由多個類可以組合成一個更大的系統,在類結構型模式中一般只存在繼承關係和實現關係;對象結構型模式關心類與對象的組合,通過關聯關係使得在... ...
  • 創建型模式是處理對象創建的設計模式,試圖根據實際情況使用合適的方式創建對象。基本的對象創建方式可能會導致設計上的問題,或增加設計的複雜度。創建型模式通過以某種方式控制對象的創建來解決問題。創建型模式由兩個主導思想構成。一是將系統使用的具體類封裝起來,二是隱藏這些具體類的實例創建和結合的方式。 ...
  • 目錄 一.簡介 二.效果演示 三.源碼下載 四.猜你喜歡 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 基礎 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 轉場 零基礎 O ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...