整合營銷服務商

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

          免費咨詢熱線:

          前端入門-html 表單控件使用

          篇介紹了表單的使用,表單有很多控件,比如輸入框,密碼框、文本域,按鈕等。按類型可分如下:

          • 輸入類控件
          • 菜單類控件

          輸入類組件 —— input

          此類控件有很多種類型,使用<input type="類型">語法,常見類型如下:

          type 值

          含義

          text

          文字字段

          password

          密碼域,用戶看不到明文,以*代替

          radio

          單選按鈕

          checkbox

          多選按鈕

          button

          普通按鈕

          submit

          提交按鈕

          reset

          重置按鈕

          image

          圖像域,用圖像作為背景的提交按鈕

          hidden

          隱藏域,不可見的輸入框

          file

          文本域,用于上傳文件等非文本數據

          文本輸入框和密碼框

          除了顯示形式不一樣,其它屬性一樣,有以下屬性:

          • name —— 定義文字字段名稱,用于和其它控件區別,不能包含特殊字符,也不可使用html 標簽名稱
          • maxlength —— 定義文本框可輸入字符最大長度
          • size —— 定義文本框在頁面中顯示的長度
          • vaule —— 定義文本框中默認的值

          如下是文本輸入框和密碼框制作一個登錄表單

          html代碼:

          <!DOCTYPE html>
          <html>
          <body>
          <h1>用戶登錄</h1>
          <form action="/demo/html/action_page.php">
            <label for="fname">用戶名:</label><br>
            <input type="text" id="username" name="username" value=""><br>
            <label for="lname">密碼:</label><br>
            <input type="password" id="pwsd" name="pwsd" value=""><br><br>
            <input type="submit" value="提交">
          </form> 
          </body>
          </html>

          顯示效果:

          HTML5 輸入類型

          除了以上幾種類型,HTML5 還增加了多個新的輸入類型:

          • color
          • date
          • datetime
          • datetime-local
          • email
          • month
          • number
          • range
          • search
          • tel
          • time
          • url
          • week

          如下代碼:

          <!DOCTYPE html>
          <html>
          <body>
          <form action="/demo/demo_form.asp">
            數字類型(1 到 5 之間):
            <input type="number" name="quantity" min="1" max="5">
            IE9 及早期版本不支持 type="number"。<br>
            color 選擇顏色:
            <input type="color" name="color"><br>
             生日:
            <input type="date" name="bday"><br>
            年月:
            <input type="month" name="bdaymonth"><br>
            年周:
            <input type="week" name="week_year"><br>
            時間:
            <input type="time" name="usr_time"><br>
            一定范圍
             <input type="range" name="points" min="0" max="10"><br>
             E-mail:
            <input type="email" name="email">
            能夠在被提交時自動對電子郵件地址進行驗證<br>
            搜索:
            <input type="search" name="googlesearch"><br>
            電話:
            <input type="tel" name="usrtel">
            目前只有 Safari 8 支持 tel 類型。<br>
            url:
            <input type="url" name="url">
            提交時能夠自動驗證 url 字段<br>
            <input type="submit">
          </form>
          </body>
          </html>

          效果如下:

          單選和多選按鈕

          使用 type = “radio” 和 type =“checkbox” 定義是單選還是多選,除了name和value屬性外,單選和多選都有一個 checked屬性定義默認選擇的項,checked = “true”指選中那個選項,表單會將 checked = “true” 的選型值傳遞給后臺。

          如下實例:

          <!DOCTYPE html>
          <html>
          <body>
          <h4>單選和多選</h4>
          <form action="/demo/demo_form.asp">
          水果:
          <input type="radio" name="shuiguo" value="banner" checked> 香蕉
          <input type="radio" name="shuiguo" value="apple"> 蘋果
          <br><br>
          省份:
          <input type="checkbox" name="shengfen" value="shannxi" checked> 陜西
          <input type="checkbox" name="shengfen" value="sanxi"> 山西
          <input type="checkbox" name="shengfen" value="gdong"> 廣東
          <br><br>
          <input type="submit">
          </form> 
          </body>
          </html>

          顯示效果:

          單選和多選傳遞給后臺的數據是不一樣的,如下會看到地址欄中的數據,多選會發送多個值,后臺將會獲取一個數組形式的數據。

          /demo/demo_form.asp?shuiguo=banner&shengfen=shannxi&shengfen=sanxi

          普通按鈕、提交按鈕、重置按鈕

          普通按鈕:type = “button”,一般配合腳本使用,語法如下:

          <input type="button" name="名稱" value="按鈕值" onclick="腳本程序" />

          value 值就是按鈕在頁面顯示的文字,onclick屬性定義了腳本事件,這里指單擊按鈕時所進行的處理。

          如下示例:

          <!DOCTYPE html>
          <html>
          <body>
          <form>
           <input type="button" value="普通按鈕">
          <input type="button" value="打開窗口" onclick="window.open()">
          <input type="button" value="您好" onclick="alert('您好')">
            </form>
          </body>
          </html>
          

          單擊您好按鈕

          提交按鈕:type = “submit”,用于提交表單內容,是一種特殊按鈕。

          如剛才的登錄表單,提交后會返回結果:

          重置按鈕:type="reset",用于清除表單數據,也是一種特殊按鈕。

          輸入數據

          點擊重置按鈕后,表單數據清空

          重置清空數據

          HTML5 按鈕

          除了使用input定義按鈕,還可以使用 html5 新增的<button> 標簽定義按鈕,button 使用語法如下:

          <form action="/demo/html/action_page.php">
          <button type="button">普通按鈕</button>
          <button type="submit">提交按鈕</button>
          </form> 

          其它輸入類控件

          隱藏域 —— hidden
          文件域 —— file

          如下示例:

          <form action="/demo/html/action_page.php">
            <label for="fname">隱藏域:</label>
            <input type="hidden" id="hidden" name="hidden" value=""><br>
            <label for="lname">文件域:</label>
            <input type="file" id="file" name="file" value=""><br>
            <input type="submit" value="提交">
          </form> 

          顯示效果

          可以看到,隱藏域在頁面中不顯示,單擊文件域選擇文件按鈕可以選擇文件,比如word文件,電子表格文件等,會以非文本方式傳送到后臺的,常用來實現文件上傳功能。

          文本域 —— textarea

          除了input 類型的控件,還有文本域 textarea ,一種特殊的文本框,它與input 文本輸入框的區別就是可以輸入多行文字,input 文本輸入框是單行的無法輸入多行文字。

          如下示例:

          <p>textarea 元素定義多行輸入字段。</p>
          <form action="/demo/html/action_page.php">
            <textarea name="message" rows="10" cols="30">The cat was playing in the garden.</textarea>
            <br><br>
            <input type="submit">
          </form>

          效果如下:

          rows 屬性定義文本域的高度是幾行,cols 定義文本域寬度占幾列,比如上面定義了高10行寬30列的文本域。

          下拉菜單和多選列表

          下拉菜單作用和單選按鈕類似,只不過它更加節省空間,當要選擇的選型很多時,就不適合使用radio空間,所以當選項很多的時候,使用下拉菜單,語法如下:

          <select name="名稱">
          <option value="選項值1" selected>選項1</option>
          <option value="選項值2">選項3</option>
          更多option......
          </select>

          多選列表和多選按鈕類似,一樣為了節省空間,當數據選項比較多時,使用多選列表,語法如下:

          <select name="名稱" size="可看見的列表項數" multiple>
          <option value="選項值1" selected>選項1</option>
          <option value="選項值2">選項3</option>
          更多option......
          </select>

          多選比下拉菜單不同之處是多了一個multiple屬性,定義多選的,且表現形式也不一樣,不是下拉而是一個列表。

          如下代碼:

          <!DOCTYPE html>
          <html>
          <body>
          <form action="/demo/demo_form.asp">
          下拉菜單:<br>
          <select name="cars">
          <option value="volvo">Volvo</option>
          <option value="saab">Saab</option>
          <option value="fiat">Fiat</option>
          <option value="audi">Audi</option>
          </select>
          <br>
          多選列表:<br>
          <select name="cars" size="3" multiple>
          <option value="volvo">Volvo</option>
          <option value="saab">Saab</option>
          <option value="fiat">Fiat</option>
          <option value="audi">Audi</option>
          </select>
          <br><br>
          <input type="submit">
          </form>
          </body>
          </html>

          顯示效果:

          這里需要注意的是,多選列表多選時需要按住ctrl鍵同時鼠標單擊選擇才能多選,效果如下:

          到這里,已介紹了大部分的表單控件,現在你可以使用他們制作自己的表單,表單通常在動態網站中使用,這為以后制作動態網站打下基礎。

          還有許多屬性沒有講到,比如html5新增的一些屬性和功能,可自行參考 w3cshool 等網站學習,感謝關注,學習愉快!

          上篇 : 前端入門——html 表單

          下篇: 前端入門 —— 網頁中使用窗口框架

          TML 服務器控件是服務器可理解的 HTML 標簽。


          HTML 服務器控件

          ASP.NET 文件中的 HTML 元素,默認是作為文本進行處理的。要想讓這些元素可編程,需向 HTML 元素中添加 runat="server" 屬性。這個屬性表示,該元素將被作為服務器控件進行處理。

          注釋:所有 HTML 服務器控件必須位于帶有 runat="server" 屬性的 <form> 標簽內!

          注釋:ASP.NET 要求所有 HTML 元素必須正確關閉和正確嵌套。

          HTML 服務器控件描述
          HtmlAnchor控制 <a> HTML 元素
          HtmlButton控制 <button> HTML 元素
          HtmlForm控制 <form> HTML 元素
          HtmlGeneric控制其他未被具體的 HTML 服務器控件規定的 HTML 元素,比如 <body>、<div>、<span> 等。
          HtmlImage控制 <image> HTML 元素
          HtmlInputButton控制 <input type="button">、<input type="submit"> 和 <input type="reset"> HTML 元素
          HtmlInputCheckBox控制 <input type="checkbox"> HTML 元素
          HtmlInputFile控制 <input type="file"> HTML 元素
          HtmlInputHidden控制 <input type="hidden"> HTML 元素
          HtmlInputImage控制 <input type="image"> HTML 元素
          HtmlInputRadioButton控制 <input type="radio"> HTML 元素
          HtmlInputText控制 <input type="text"> 和 <input type="password"> HTML 元素
          HtmlSelect控制 <select> HTML 元素
          HtmlTable控制 <table> HTML 元素
          HtmlTableCell控制 <td> 和 <th> HTML 元素
          HtmlTableRow控制 <tr> HTML 元素
          HtmlTextArea控制 <textarea> HTML 元素

          PlainTextEdit簡介

          QPlainTextEdit小部件是一個用于編輯和顯示純文本控件,QPlainTextEdit控件與QTextEdit控件使用了相同的技術和概念,但是它為純文本處理提供了優化。QPlainTextEdit是一個支持純文本的高級查看器/編輯器,可以處理大型文檔并對用戶輸入做出快速響應。

          QPlainTextEdit支持文本段落,在默認情況下,一個換行符表示一個段落,文檔可以一個或者多個段落組成,且段落中的每個字符都可以有其自己的屬性,例如有自己的字體和顏色。

          QPlainTextEdit常用作文本顯示器或文本編輯器。

          QPlaintTextEdit常用方法:

          • setPlainText(): 設置多行文本框的內容;
          • insertPlainText(): 插入普通文本;
          • appendPlainText(): 添加普通文本;
          • appendHtml(): 添加HTML文本內容;
          • setReadOnly(): 設置成只讀模式;
          • isReadOnly(): 是否是只讀模式;
          • setLineWrapMode():設置換行模式,取值為(QPlainTextEdit.NoWrap:不自動換行(缺省值),QPlainTextEdit.WidgetWidth: 根據文本框的寬度自動換行.);
          • lineWrapMode(): 換行模式

          QPlaintTextEdit中的常用信號:

          • textChanged: 文本內容發生改變時觸發;
          • selectionChanged:選中內容發生改變時觸發;
          • cursorPositionChanged: 光標位置發生改變觸發;
          • copyAvailable:復制可用時觸發
          • redoAvailable: 重做可用觸發
          • undoAvailable: 撤銷可用觸發

          QPlainTextEdit是一個功能強大的文本編輯器控件,有興趣的童鞋可進一步研究。

          QPlainTextEdit類繼承關系:

          測試QPlainTextEdit

          測試程序實現簡單的文本編輯器,可以新建,打開一個文本文件,然后進行編輯并保存。使用Qt Designer生成ui文件. 然后在代碼中是有uic直接調用布局文件。創建文件qplaintextedit.py, 代碼如下:

          import sys,os
          from PyQt5 import QtCore, QtGui, QtWidgets, uic
          from PyQt5.QtWidgets import (QApplication, QWidget, QPlainTextEdit, QToolButton, QStyle, QMessageBox, QFileDialog)
           
          class DemoPlainTextEdit(QWidget):
              def __init__(self, parent=None):
                  super(DemoPlainTextEdit, self).__init__(parent)
                  
                  self.path = None
                  
                  uic.loadUi(os.path.dirname(__file__) + '/textedit.ui', self)
                  
                  self.btnNewFile.setIcon(QApplication.style().standardIcon(QStyle.SP_FileIcon))
                  self.btnNewFile.clicked.connect(self.onFileNew)
                  self.btnOpenFile.setIcon(QApplication.style().standardIcon(QStyle.SP_DialogOpenButton))
                  self.btnOpenFile.clicked.connect(self.onFileOpen)
                  self.btnSaveFile.setIcon(QApplication.style().standardIcon(QStyle.SP_DialogSaveButton))
                  self.btnSaveFile.clicked.connect(self.onSaveFile)
                  self.btnSaveFileAs.setIcon(QApplication.style().standardIcon(QStyle.SP_DialogSaveButton))
                  self.btnSaveFileAs.clicked.connect(self.onSaveFileAs)
                  
              def msgCritical(self, strInfo):
                  dlg = QMessageBox(self)
                  dlg.setIcon(QMessageBox.Critical)
                  dlg.setText(strInfo)
                  dlg.show()
              
              def onFileNew(self):
                  self.txtEdit.clear()
                  
              def onFileOpen(self):
                  path, _ = QFileDialog.getOpenFileName(self, '打開文件', '', '文本文件 (*.txt)')
                  
                  if path:
                      try:
                          with open(path, 'rU') as f:
                              text = f.read()
                      except Exception as e:
                          self.msgCritical(str(e))
                      else:
                          self.path = path
                          self.txtEdit.setPlainText(text)
                          
              def onSaveFile(self):
                  if self.path is None:
                      return self.onSaveFileAs()
                  self._saveToPath(self.path)
                  
              def onSaveFileAs(self):
                  path,_ = QFileDialog.getSaveFileName(self, '保存文件', '', '文本文件 (*.txt)')
                  if not path:
                      return
                  self._saveToPath(path)
                  
              def _saveToPath(self, path):
                  text = self.txtEdit.toPlainText()
                  try:
                      with open(path, 'w') as f:
                          f.write(text)
                  except Exception as e:
                      self.msgCritical(str(e))
                  else:
                      self.path = path
                         
          if __name__ == '__main__':
              app = QApplication(sys.argv)
              window = DemoPlainTextEdit()
              window.show()
              sys.exit(app.exec())

          運行結果如圖:

          測試QPlainTextEdit

          本文知識點

          • QPlainTextEdit的基本功能;
          • 使用uic在代碼中導入ui文件;
          • 使用QFileDialog打開文件對話框;
          • 文本文件的讀寫操作。

          喜歡本文內容就收藏,點贊,評論,關注和轉發。


          主站蜘蛛池模板: 乱码人妻一区二区三区| av一区二区三区人妻少妇| 精品一区二区三区在线观看l | 久久久久人妻一区精品果冻| 国产一区二区精品久久91| 在线视频精品一区| 激情啪啪精品一区二区| 东京热无码一区二区三区av| 精品少妇一区二区三区在线| 一区二区三区人妻无码| 免费无码VA一区二区三区| 亚洲AV噜噜一区二区三区| 日韩精品一区二区午夜成人版| 国模精品一区二区三区| 日韩精品无码一区二区三区 | 国产精品自在拍一区二区不卡| 日本一区午夜爱爱| 日产亚洲一区二区三区| 无码av中文一区二区三区桃花岛 | 亚洲色大成网站www永久一区| 亚洲第一区在线观看| 国产午夜三级一区二区三| 日本一区二区在线| 交换国产精品视频一区| 日韩一区二区三区电影在线观看| 无码一区二区三区免费| 亚洲一区二区三区在线观看精品中文| 高清一区二区三区日本久| 激情内射亚洲一区二区三区爱妻| 国产精品视频一区国模私拍 | 国产免费一区二区视频| 中文字幕AV一区二区三区人妻少妇| 国产在线观看一区二区三区四区 | 精品国产日韩亚洲一区| 国产精品久久一区二区三区| 色综合一区二区三区| 亚洲高清成人一区二区三区| 色噜噜狠狠一区二区| 中文字幕一区二区三区乱码| 日韩在线一区高清在线| 无码人妻一区二区三区在线水卜樱 |