整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          Django-form表單


          表單是搜集用戶數據信息的各種表單元素的集合,其作用是實現網頁上的數據交互,比如用戶在網站輸入數據信息,然后提交到網站服務器端進行處理(如數據錄入用戶登錄注冊等)。
          網頁表單是Web開發的一項基本功能,Django的表單功能由 Form 類實現,主要外為兩種:diango.forms.Form django.forms.Modellorm,前者是一個基礎的表單功能,后者是在前者的基礎上結合模型所生成的數據表單。

          接下來帶各位了解一下表單

          傳統的表單生成方式是在模板文件中編寫 HTML 代碼實現,在 HTML 語言中,表單由 <form> 標簽實現。表單生成方式如下:

          <!DOCTYPE html>
          <html>
          <body>
          # 表單
          <form action="" method="post">
          First name:<br>
          <input type="text" name="fname" value="Mickey">
          <br>
          Last name:<br>
          <input type="text" name="lname" value="Mouse">
          <br><br>
          <input type="submit" value="Submit">
          </form>
          # 表單
          </body>
          </html>

          一個完整的表單主要由 4 部分組成:提交地址請求方式元素控件提交按鈕,分別說明如下:

          • 提交地址(form 標簽的 action 屬性)用于設置用戶提交的表單數據應由哪個路由接收和處理。當用戶向服務器提交數據時,若屬性 action 為空,則提交的數據應由當前的路由來接收和處理,否則網頁會跳轉到屬性 action 所指向的路由地址。
          • 請求方式用于設置表單的提交方式,通常是 GET 請求或POST 請求(剩余6種請求本人之前講過,這里不再敘述),由 form 標簽的屬性 method 決定。
          • 元素控件是供用戶輸入數據信息的輸入框,由 HTML 的 <input> 控件實現,控件屬性 type 用于設置輸入框的類型,常用的輸入框類型有文本框,下拉框和復選框等。
          • 提交按鈕供用戶提交數據到服務器,該按鈕也是由 HTML的 <input> 控件實現的。但該按鈕具有一定的特殊性,因此不歸納到元素控件的范圍內。

            在模板文件中,通過 HTML 語言編寫表單是一種較為簡單的實現方式,如果表單元素較多或一個網頁里使用多個表單,就會在無形之中增加模板的代碼量,對日后的維護和更新造成極大的不便,為了簡化表單的實現過程和提高表單的靈活性,Django也提供了定善的表單功能。Django將表單交由視圖類FormView使用,從而在瀏覽器上生成網頁表單。

          希望對各位有幫助。

          累點滴,匯成江海。咱們從最最基礎的PHP知識開始學習,一步一個腳印的開啟PHP的學習旅途吧。

          請點擊右上角“關注”按鈕關注我們喲:跟著木辛老師學習PHP編程知識,變身快樂的編程達人吧~

          同學們好呀!木辛老師又來了。

          咱們在開始PHP的學習之前,需要先準備一個可以提供PHP服務的Web服務器。我們就復用木辛老師專欄中的一個教程,使用Homestead本地開發環境進行學習唄。

          傳送門:《Laravel第一課:搭建Laravel開發環境》

          也可以關注木辛老師的Laravel專欄喲:

          大家配置好本地開發環境以后,還需要稍微設置一下,針對這個項目,在Homestead配置文件中作如下設置,

          添加指向當前項目根目錄的配置:

          sites:
           - map: learning_php.test to: /Code/zyoo/learning_php
           to: /Code/zyoo/learning_php
          

          另外還需要在本機hosts文件中添加一個域名指向:

          sudo vim /etc/hosts
          

          并添加如下記錄:

          192.168.10.10 learning_php.test
          

          最后,添加一個測試文件:

          php代碼

          然后,打開瀏覽器,訪問域名查看頁面結果

          執行效果

          大家可以看到,我們已經可以成功的訪問到測試用的PHP文件了。

          好了,萬事俱備,只需要學習了。那么,咱們開始吧~

          創建示例應用:木辛老師的圖書館

          幾乎絕大部分服務器端的腳本語言最初設計的應用場景之一就是處理HTML表單。木辛老師要翻出家底,將自己最心愛的在線圖書商城,用來作為學習PHP基礎知識的場景吧。

          創建訂購圖書用的訂單表單

          通過這個表單頁面,我們可以知道顧客訂購的商品,訂單的金額以及其他一些附屬信息。HTML代碼請看下方:

          <html>
           <head>
           <title>木辛老師的PHP基礎入門教程</title>
           </head>
           <body>
           <form action="processorder.php" method="POST">
           <table style="border: 0px;">
           <tr style="background: #cccccc">
           <td style="width: 150px;text-align:center;">圖書名稱</td>
           <td style="width: 50px;text-align:center;">數量</td>
           </tr>
           <tr>
           <td>PHP入門指南</td>
           <td><input type="text" name=“book_name_01" size="3" maxlength="3"/></td>
           </tr>
           <tr>
           <td>PHP和MySQL開發</td>
           <td><input type="text" name="book_name_02" size="3" maxlength="3"/></td>
           </tr>
           <tr>
           <td>Laravel入門</td>
           <td><input type="text" name="book_name_03" size="3" maxlength="3"/></td>
           </tr>
           <tr>
           <td colspan="2" style="text-align: center;">
           <input type="submit" value="提交訂單"/>
           </td>
           </tr>
           </table>
           </form>
           </body>
          </html>
          

          咱么直接通過瀏覽器訪問這個HTML頁面,看看效果:

          頁面顯示

          哈,簡單的頁面,我們已經開啟Web開發神秘旅程了。繼續加油!

          大家可能注意到了一個細節:在html代碼的form表單部分,action屬性我們指向了一個php腳本:

          <form action="processorder.php" method="POST”>
          

          具體的PHP腳本的學習我們很快就能看到。這里只是稍微提一下,這個action屬性值就是用戶點擊“提交訂單”按鈕時將要請求的URL。

          用戶在表單中輸入的數據,會以POST的方式,發送給URL指向的PHP文件進行處理。

          表單處理

          那如何處理這個表單呢?又如何讓PHP代碼起作用的?

          要處理這個表單,我們需要創建一個php文件,它的名字需要和form中action屬性的值保持一致。

          那么,我們就創建一個名字叫做processorder.php的文件吧。

          代碼可以先這么寫,看看是否能起作用哈:

          <html>
           <head>
           <title>訂單處理結果</title>
           </head>
           <body>
           <h1> 木辛老師的在線圖書館</h1>
           <h2> 訂單處理結果通知</h2>
           <?php echo '<p>訂單已處理完成</p>'; // 這里是PHP的代碼 ?>
           </body>
          </html>
          

          保持文件,并刷新頁面。這個時候我們點擊“提交訂單”按鈕,效果如下:

          php執行結果

          大家可以看到,紅框部分就是通過PHP代碼輸出的結果。這樣,我們就實現了通過Web方式執行了PHP代碼的需求,這么一看PHP還是非常簡單的吧。

          我們順便在看看這個頁面的源代碼吧,看一下PHP代碼如何在HTML頁面中完成任務的吧:

          源代碼

          通過頁面源碼,我們發現剛才寫的PHP代碼已經不見了,取而代之的是

          <p>訂單已處理完成</p>
          

          這是怎么回事呢?

          這是因為PHP解釋器在腳本運行的時候,將該腳本的輸出替代了腳本自身的代碼,通過這種方式,就可以生成可以在任何瀏覽器上運行的HTML頁面了。也就是說,瀏覽器是不需要學會PHP的。

          通過這段代碼,我們可以學習一些PHP的基礎知識:

          1. PHP標記
          2. PHP語句
          3. 如何空格
          4. 添加注釋

          PHP標記

          第一種情況:在HTML中混寫PHP和HTML代碼,需要為php添加標記。PHP代碼會以“<?php”作為開始,以“?>”作為結束。這些符號就叫做PHP標記,它們主要用來告訴服務器PHP代碼的開始和截止,在這兩個起止符號之間的任何代碼,服務器都會以PHP語法來解析。

          另一種情況:之后,我們寫純PHP的時候,每個文件也需要添加PHP標記。不過呢,結束標記可以省略,這也是很大一部分PHPer默認遵守的規則。

          PHP語句

          在PHP的開始和截止標記之間,就是PHP語句了,通過這些內容可以告訴PHP解釋器應該進行如何的操作,在我們這個例子里,通過:

          echo '<p>訂單已處理完成</p>’;
          

          使用echo語句完成了一個非常簡單的操作,僅是將echo后邊的字符串原樣打印到瀏覽器中。這里需要特別注意的一點就是每個PHP語句后邊都需要添加英文的分號作為語句的結束符,否則會出現錯誤,但是在這個html頁面中,因為只有一句代碼,忽略掉分號也是不會報錯的。

          但是還是強烈建議大家養成習慣:每句PHP代碼結束都要以分號結尾喲!

          空格

          一般情況下,為了讓代碼更加清晰和整潔,在編碼的過程中會添加一些空格,這些空格包括:回車換行、空格、制表符等都被認為是空格。

          當然了,瀏覽器并不會在意你是否輸入了空格,同樣的PHP服務器端解析器也會忽略這些,這些空格僅是給編寫代碼的人看的。

          但是,木辛老師還是再次強烈建議,在代碼的適當位置添加空格或者空行,這樣做可以很有效的提升代碼的可閱讀性,方便后期的維護工作。

          注釋

          最后在講講注釋,理論上在編程中出現頻率非常高的一個知識點。

          為什么說理論上呢,因為這么重要的一個要點,在實際開發中很容易被廣大開發者忽略呢!

          由于種種原因吧,開發者很不習慣在開發過程中寫非常詳盡的注釋,而且有時候在Git提交時也是草草的一筆帶過。這樣做的后果就是,若干時間后,當你再次拿到這段代碼,可能會花費更多的時間梳理它。

          所以,善于寫注釋,也是提高生產效率的一種有效手段。

          PHP解釋器同樣會在執行的時候忽略掉注釋,也就是說就好比像空格一樣,PHP解析器會跳過注釋,它只負責執行PHP代碼!

          PHP腳本中的注釋比較豐富,有很多類似C語言的風格,比如:

          多行注釋:

          /* 這是
           一個
           多行
           注釋
          /*
          

          可以看出來,多行注釋以 /*開始,以*/結束。同樣的和C語言是一樣的,多行注釋是不能嵌套的。

          當然了,除了多行注釋之外,也支持單行注釋:

          echo '<p>訂單已處理完成</p>'; // 這里是PHP的代碼
          

          或者這種:

          echo '<p>訂單已處理完成</p>’; #這里是PHP的代碼
          

          不論采取哪種風格的注釋,在注釋符號之后的所有內容,PHP解釋器都會認識不需要處理的,這一點一定要注意呀!

          好了,今天的課程咱就先講到這里。

          小朋友們不要忘記關注我們喲 ,下期課程更精彩,請大家一起期待吧~

          快樂編程,快樂成長,拜拜!

          面的代碼創建了一個空的 FormData 對象:

          var formData = new FormData(); // Currently empty


          FormData.append()

          FormData 接口的 append() 方法會添加一個新值到 FormData 對象內的一個已存在的鍵中, 如果鍵不存在則會添加該鍵。


          你可以通過 FormData.append 往對象里加入鍵值對:

          formData.append('username', 'Chris');
          formData.append('userpic', myFileInput.files[0], 'chris.jpg');

          跟常規表單數據一樣,你可以使用同一個名稱添加多個值 。例如 (為了與PHP命名習慣一致在名稱中添加了[]):

          formData.append('userpic[]', myFileInput1.files[0], 'chris1.jpg');
          formData.append('userpic[]', myFileInput2.files[0], 'chris2.jpg');

          實例: 如何清空FormData對象的數據?


          主站蜘蛛池模板: 亚洲午夜一区二区电影院| 视频一区二区在线观看| 老熟妇仑乱视频一区二区| 亚洲av无码一区二区三区网站 | 一区二区三区午夜视频| 成人区人妻精品一区二区三区| 国产精品一区电影| 亚洲一区中文字幕在线电影网| 一区二区三区波多野结衣| 蜜臀Av午夜一区二区三区| 日本一道高清一区二区三区| 任你躁国产自任一区二区三区| 国产午夜精品一区二区三区极品 | 色噜噜一区二区三区| 色欲AV蜜臀一区二区三区| 一区二区在线视频免费观看| 波多野结衣一区二区| 亚洲av成人一区二区三区| 国产精品va无码一区二区| 无码精品人妻一区二区三区影院 | V一区无码内射国产| 日韩在线视频不卡一区二区三区| 成人无码AV一区二区| 四虎一区二区成人免费影院网址| 黑巨人与欧美精品一区| 精品国产一区二区三区2021| 久久精品一区二区国产| 亚洲av片一区二区三区| 欧美日韩国产免费一区二区三区| 亚洲国产综合无码一区| 一区二区在线免费视频| 青娱乐国产官网极品一区 | 国产精品盗摄一区二区在线| 亚洲一区二区三区高清不卡 | 97精品国产一区二区三区| 日韩精品无码一区二区三区免费| 制服中文字幕一区二区| 射精专区一区二区朝鲜| 91福利一区二区| 国产拳头交一区二区| 日本在线视频一区|