整合營銷服務商

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

          免費咨詢熱線:

          前端入門-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 表單

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

          evExpress WinForm擁有180+組件和UI庫,能為Windows Forms平臺創建具有影響力的業務解決方案。DevExpress WinForm能完美構建流暢、美觀且易于使用的應用程序,無論是Office風格的界面,還是分析處理大批量的業務數據,它都能輕松勝任!

          注意:目前基于HTML & CSS的控件正在積極研發中,可以作為技術預覽提供,如果需要使用請下載最新版組件體驗哦~

          DevExpress WinForms Subscription官方最新版免費下載試用,歷史版本下載,在線文檔和幫助文件下載-慧都網

          一組控件和組件允許開發人員構建HTML格式的UI,并使用CSS樣式自定義UI元素的外觀設置、大小、填充和布局選項,不再需要處理自定義繪制事件或更改大量屬性來修改控件以匹配UI規范,可以使用HTML和CSS標記的知識為桌面應用程序構建布局。

          在上文中,我們為大家介紹了HTML-CSS標記的,本文將為大家介紹DevExpress中的HTML-CSS感知控件,有興趣的小伙伴可以下載相關組件體驗。

          HTML-CSS-aware控件

          HtmlContentControl

          HtmlContentControl可以從HTML-CSS標記構建UI的界面。

          HtmlContentPopup

          HtmlContentPopup是HtmlContentControl的彈出窗口版本,該組件從HTML-CSS代碼生成UI,并將其顯示為彈出或模態窗口。

          GridControl的ItemsView

          新的ItemsView沒有默認的數據表示,它僅從開發者用屬性或動態地用事件指定的HTML-CSS模板中呈現它的項(數據記錄)。

          GridControl的TileView

          TileView從模板生成它的項(tiles),開發者可以在常規模板和基于HTML-CSS的模板之間進行選擇。

          GridControl的WinExplorerView

          WinExplorerView支持HTML-CSS模板來構建卡片的布局,開發者可以為每種顯示樣式(超大、大、中、列表、貼片等等)指定HTML-CSS模板,或者動態地使用一個事件。

          GanttControl

          GanttControl允許開發者使用HTML-CSS標記來渲染許多元素:

          • 任務、摘要和里程碑
          • 定期和匯總任務進度
          • 常規、摘要和里程碑任務基線
          • 文本標簽
          • 交互工具提示
          • 分割的任務

          Scheduler Control

          您可以在SchedulerControl中使用基于HTML-CSS的模板來呈現約會。

          DirectX Form

          標準Visual Studio表單的替代品,為其子控件啟用DirectX硬件加速,并支持基于HTML-CSS的模板。

          Alert Controls

          AlertControl的模板允許呈現現代應用程序通知。

          列表框控件和組合框編輯器

          開發人員可以使用基于HTML-CSS的模板來呈現以下控件中的項:

          • ListBoxControl, CheckedListBoxControl和 ImageListBoxControl
          • ComboBoxEdit

          Accordion Control

          AccordionControl允許開發人員使用HTML-CSS模板來渲染它的UI元素:

          • 項目和組
          • 頁腳的元素
          • 處于最小化狀態的元素等

          戰wxPython系列-044

          本文介紹如何在Python的GUI工具中嵌入HTML頁面。

          wxPython的wx.html和wx.html2模塊支持解析和顯示HTML文件內容。wx.html.HtmlWindow對象是一個通用的HTML瀏覽器,但不是一個全功能的瀏覽器,所以支持的功能有限。wx.html.HtmlWindow只支持HTML標準的一個子集,不支持Javascript或者CSS。如果要支持全特性的HTML渲染組件,請使用wx.html2.WebView。

          一、wx.html.HtmlWindow簡介

          wx.html.HtmlWindow控件的目的是顯示基于HTML標準字跡的富內容頁面(本地文件或者通過HTTP下載的網頁文件),一定創建了該窗口控件,可以通過調用SetPage和LoadPage來設置它的內容。

          wx.html.HtmlWindow支持的窗口樣式

          • wx.html.HW_SCROLLBAR_NEVER:不顯示滾動條。
          • wx.html.HW_SCROLLBAR_AUTO:在需要的時候顯示滾動條。
          • wx.html.HW_NO_SELECTION:用戶不可以選擇其中的文本(默認可以)。

          wx.html.HtmlWindow發出的事件

          • EVT_HTML_CELL_CLICKED:單擊wx.html.HtmlCell時產生。
          • EVT_HTML_CELL_HOVER:鼠標經過一個wx.html.HtmlCell時產生。
          • EVT_HTML_LINK_CLICKED:單擊了包含超鏈接的wx.html.HtmlCell時產生。

          wx.html.HtmlWindow常用方法

          • AppendToPage(self, source):將HTML片段附加到當前顯示的文本并刷新窗口。
          • GetOpenedAnchor(self):返回當前打開頁面中的錨點。如果沒有打開任何頁,或者所顯示的頁不是通過調用LoadPage生成的,則返回空字符串。
          • GetOpenedPage(self):返回所打開頁面的完整位置。如果沒有打開任何頁,或者所顯示的頁不是通過調用LoadPage生成的,則返回空字符串。
          • GetOpenedPageTitle(self):返回所打開頁面的標題,如果當前頁面不包含< title >標記,則返回“”。
          • HistoryBack(self):移動回上一頁。只有使用LoadPage顯示的頁面才存儲在歷史列表中。
          • HistoryCanBack(self):如果有可能在歷史頁面向后操作,即返回True。
          • HistoryCanForward(self):如果有可能在歷史中向前操作,即返回True。
          • HistoryClear(self):清除歷史頁面。
          • HistoryForward(self):移動到下一頁。只有使用LoadPage顯示的頁面才存儲在歷史列表中。
          • LoadFile(self, filename):從文件加載HTML頁面并顯示它。
          • LoadPage(self, location):與SetPage不同,這個函數首先從給定的location加載HTML頁面,然后顯示它。
          • OnCellClicked(self, cell, x, y, event):在wx.html.HtmlWindow內單擊鼠標按鈕時調用此方法。默認行為是發出wx.html.HtmlCellEvent,如果事件沒有被處理或跳過,如果單元格包含超文本鏈接,則調用OnLinkClicked。
          • OnCellMouseHover(self, cell, x, y):當鼠標移動到HTML單元格上時調用此方法。默認行為是發出wx.html.HtmlCellEvent。
          • OnLinkClicked(self, link):當用戶單擊超文本鏈接時調用。默認行為是觸發wx.html.HtmlLinkEvent,如果沒有處理或跳過該事件,則調用LoadPage,不做任何其他事情。
          • OnOpeningURL(self, type, url):在URL被打開時調用(當用戶單擊鏈接或加載圖像時)。只有OnOpeningURL返回HTML_OPEN時,URL才會被打開。此方法由wx.html.HtmlParser.OpenURL調用。

          圖1:wx.html.HtmlWindow類繼承關系

          二、wx.html.HtmlWindow演示

          Htmlwin.py文件

          #html窗口(wx.html.HtmlWindow)
          
          import wx
          import wx.html
          
          class SampleHtmlWindow(wx.Frame):
          
              def __init__(self, *args, **kw):
                  super(SampleHtmlWindow, self).__init__(*args, **kw)
          
                  self.InitUi()
          
              def InitUi(self):
                  self.SetTitle("實戰wxPython: HtmlWindow演示")
                  self.SetSize(400, 300)
          
                  panel = wx.Panel(self)
                  vbox = wx.BoxSizer(wx.VERTICAL)
                  hbox = wx.BoxSizer(wx.HORIZONTAL)
          
                  htmlwin = wx.html.HtmlWindow(panel, wx.ID_ANY, style = wx.NO_BORDER)
                  htmlwin.SetStandardFonts()
                  htmlwin.LoadPage("page.html")
                  """
                  htmlwin.SetPage('''
                      <html>
                          <body bgcolor="#fdd22f">
                              <h1>這是標題</h1>
                              <b style="color:blue">實戰wxPython</b>
                              <p>通過RGB值設置背景顏色</p>
                              <br/>
                              <p> 
                                  這是一個段落
                              </p>
                              <i>這是斜體文本</i>
                          </body>
                      </html>
                  ''')
                  """
          
                  vbox.Add((-1, 10), 0)
                  vbox.Add(htmlwin, 1, wx.EXPAND | wx.ALL, 9)
          
                  bitmap = wx.StaticBitmap(panel, wx.ID_ANY, wx.Bitmap("newt.png"))
                  hbox.Add(bitmap, 0, wx.LEFT | wx.BOTTOM | wx.TOP, 10)
          
                  btnOk = wx.Button(panel, wx.ID_ANY, "確定")
                  self.Bind(wx.EVT_BUTTON, self.OnClose, id=btnOk.GetId())
          
                  hbox.Add((100, -1), 1, wx.LEFT)
                  hbox.Add(btnOk, flag = wx.TOP | wx.BOTTOM | wx.RIGHT, border = 10)
          
                  vbox.Add(hbox, 0, wx.EXPAND)
          
                  panel.SetSizer(vbox)
          
                  self.Centre()
          
              def OnClose(self, e):
                  self.Close()
          
          def main():
              app = wx.App()
              sample = SampleHtmlWindow(None)
              sample.Show()
              app.MainLoop()
          
          if __name__ == "__main__":
              main()

          page.html文件

          <!DOCTYPE html>
          <head>
              <meta charset="UTF-8">
          </head>
          <html>
              <table cellspacing="5" border="0" width="250">
                  <tr width="200" align="left">
                      <td bgcolor="#e7e7e7">  Maximum</td>
                      <td bgcolor="#aaaaaa">  <b>9000</b></td>
                  </tr>
                  <tr align="left">
                      <td bgcolor="#e7e7e7">  Mean</td>
                      <td bgcolor="#aaaaaa">  <b>6076</b></td>
                  </tr>
                  <tr align="left">
                      <td bgcolor="#e7e7e7">  Minimum</td>
                      <td bgcolor="#aaaaaa">  <b>3800</b></td>
                  </tr>
                  <tr align="left">
                      <td bgcolor="#e7e7e7">  Median</td>
                      <td bgcolor="#aaaaaa">  <b>6000</b></td>
                  </tr>
                  <tr align="left">
                      <td bgcolor="#e7e7e7">  Standard Deviation</td>
                      <td bgcolor="#aaaaaa">  <b>6076</b></td>
                  </tr>
              </table>
          </html>

          上面的示例演示了如何使用wx.html.HtmlWindow來加載一個html文件并顯示它。

          htmlwin = wx.html.HtmlWindow(panel, wx.ID_ANY, style = wx.NO_BORDER)
          htmlwin.SetStandardFonts()
          htmlwin.LoadPage("page.html")

          創建wx.html.HtmlWindow對象,然后使用LoadPage方法加載文件。

          圖2:wx.html.HtmWindow演示

          三、本文知識點

          • 了解wx.html.HtmlWindow控件。
          • 使用wx.html.HtmlWindow加載并顯示HTML文件。

          前一篇:wxPython - 高級控件之表格Grid

          請關注,評論,收藏,點贊,和轉發。


          主站蜘蛛池模板: 亚洲美女高清一区二区三区| 国产激情з∠视频一区二区| 少妇激情AV一区二区三区| 国产午夜精品一区二区| 夜夜添无码一区二区三区| 97久久精品无码一区二区天美| 国产伦精品一区二区三区精品| 国产在线精品一区二区三区不卡 | 国产一区二区三区91| 精产国品一区二区三产区| 日本一区二区不卡在线| 亚洲另类无码一区二区三区| 红杏亚洲影院一区二区三区| 韩国福利一区二区美女视频| 国产成人精品一区二区三区免费| 一区二区三区国模大胆| 亚洲av永久无码一区二区三区| 亚洲一区精品无码| 一区二区在线视频免费观看| 午夜DV内射一区区| 四虎在线观看一区二区| 成人精品一区二区激情| 国产主播一区二区三区| 清纯唯美经典一区二区| 久久国产精品免费一区二区三区| 天堂Aⅴ无码一区二区三区| 亚洲国产精品一区二区成人片国内| 亚洲一区影音先锋色资源| 2020天堂中文字幕一区在线观| 久久久久人妻精品一区| 精品无码一区二区三区爱欲 | 一区二区免费国产在线观看| 一区二区三区高清视频在线观看 | 亚洲国产成人一区二区精品区| 亚洲av无码一区二区三区网站 | 国产伦精品一区三区视频| 好吊妞视频一区二区| 精品福利一区二区三区精品国产第一国产综合精品| 亚洲av无码一区二区三区天堂| 精品视频一区在线观看| 亚洲一区二区三区无码中文字幕|