整合營銷服務商

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

          免費咨詢熱線:

          資深 Web 開發的經驗之談:為什么你開發的網頁不應該大于 14KB?

          然我們生活在一個寬帶無處不在、4/5G 幾乎全覆蓋的時代,但網站加載緩慢還是常態,就算我們打開一個以文本為中心的新聞網站,都可能需要至少 30 秒才能開始閱讀。畢竟在內容膨脹時代,一張照片就能輕易超過 1MB 大小,許多網站為了顯示幾段文本,還會單獨加載至少 10MB 的 JS 和自定義字體。

          對此,對優化和極簡主義充滿熱情的資深 Web 開發 Nathaniel 告訴我們,你應該讓你的網頁盡力控制在 14KB 以內,而且即使對于以富媒體為中心的網站,這條 14KB 的規則可能仍然值得遵循。如果 14KB 不足以用于最終布局,則需要優先考慮“首屏”字節,可以用發送給訪問者的前 14KB 數據來渲染一些有用的東西,減少用戶還沒有開始閱讀就流失掉的機會。


          網頁越小,加載速度就越快——這一點都不奇怪。


          但令人感到驚訝的是,14KB 網頁的加載速度比 15KB 要快得多——可能快 612 毫秒——而 15KB 和 16KB 網頁之間的加載速度差異微乎其微。


          這是 TCP 慢啟動算法導致的。本文將介紹這個算法、它的原理以及為什么你應該關注它。但首先我們需要快速過一遍一些基礎知識。


          TCP 是什么


          傳輸控制協議(Transmission Control Protocol,TCP)是一種使用 IP 協議可靠地發送數據包的方法——有時被稱為 TCP/IP。


          當瀏覽器向你的網站(或圖像或樣式表)發出請求時,它會使用 HTTP 請求。HTTP 建立在 TCP 之上,一個 HTTP 請求通常由許多 TCP 數據包組成。IP 只是一個將數據包從互聯網上的一個位置發送到另一個位置的系統。IP 沒有檢查數據包是否成功到達目的地的方法。


          對于網站來說,確保所有的數據到達請求端是非常關鍵的,否則我們可能會因為丟失數據包無法獲得完整的網頁。但在網絡的其他應用場景中,這一點并不那么重要——比如流媒體直播視頻。


          TCP 是 IP 的擴展,瀏覽器和網站服務器通過它告訴對方哪些數據包已經成功到達。


          服務器發送一些數據包,然后等待瀏覽器已經收到數據包的響應(這叫確認或 ACK),然后它繼續發送更多的數據包——或者如果它沒有收到 ACK,將再次發送相同的數據包。


          什么是 TCP 慢啟動


          TCP 慢啟動是一種算法,服務器用它來確定一次可以發送多少數據包。


          當瀏覽器第一次連接到服務器時,服務器無法知道它們之間的帶寬是多少。帶寬是指在單位時間內網絡可以傳輸的數據量。通常以比特/秒(b/s)為單位。我們可以用管道來作類比——把帶寬想象成每秒從管道流出多少水。


          服務器不知道網絡連接可以處理多少數據——所以它先發送少量且安全的數據——通常是 10 個 TCP 數據包。如果這些數據包成功地到達網站訪問者,他們的計算機返回確認(ACK),表示數據包已經被收到了。然后,服務器發送更多的數據包,但這一次它將數據包的數量增加了一倍。


          這個過程會不斷重復,直到數據包丟失,服務器沒有收到 ACK。(此時,服務器會繼續發送數據包,但速度較慢)。


          這就是 TCP 慢啟動的要點——在現實當中,雖然算法各不相同,但這是它的基本原理。


          那么 14KB 這個數字是怎么來的


          大多數 Web 服務器的 TCP 慢啟動算法都是從發送 10 個 TCP 數據包開始的。


          TCP 數據包最大長度為 1500 字節。這個最大值不是由 TCP 規范設置的,它來自于以太網標準。


          每個 TCP 數據包的標頭占了 40 個字節,其中 16 個字節用于 IP,另外 24 個字節用于 TCP。


          這樣每個 TCP 數據包還剩下 1460 個字節。10 x 1460 = 14600 字節,或大約 14KB!


          因此,如果你能把網站的網頁——或網頁的關鍵部分——壓縮到 14KB,就可以為訪問者節省大量的時間——他們和網站服務器之間的往返時間。


          一個數據往返能有多糟糕?但人們非常沒有耐心——一個數據往返可能會出奇地長,具體多長取決于延遲……延遲是指數據包從源傳輸到目的地所花費的時間。如果帶寬是每秒鐘可以通過管道的水的數量,那么延遲就是一滴水進入管道后從另一端流出所花費的時間。


          下面是一個關于延遲有多糟糕的例子。


          衛星網絡


          衛星網絡是由環繞地球軌道的衛星提供的,在人煙稀少的地區、石油鉆井平臺、游輪以及飛機上,人們可以使用這種網絡。


          為了說明這種糟糕的延遲,我們想象一群在石油鉆井平臺工作的兄弟把骰子忘在了家里,他們需要通過 missingdice.com(少于 14KB)來玩《龍與地下城》游戲。


          首先,他們中的一個用手機發出一個網頁請求……


          手機將請求發送到鉆井平臺的 WiFi 路由器,路由器將數據發送給平臺上的衛星天線,我們假設這可能需要 1 毫秒時間。


          然后,衛星天線將數據發送到地球軌道上方的衛星。


          通常,這是通過在地球表面上方 35786 公里處運行的軌道衛星實現的。光速為 299792458 米/秒,所以信息從地球發送到衛星需要 120 毫秒。然后,衛星將信息傳回地面接收站,這又需要 120 毫秒。


          然后,地面站必須將請求發送到位于地球任意位置的服務器(當光通過光纖電纜傳輸時,速度會降至每秒 200000000 米)。如果地面站和服務器之間的距離等于紐約到倫敦之間的距離,那么大約需要 28 毫秒,如果地面站和服務器之間的距離等于紐約到悉尼之間的距離,則需要 80 毫秒——所以我們姑且定一個 60 毫秒的數字(這個數字便于計算)。


          然后,服務器需要處理請求,這可能需要 10 毫秒,然后服務器再次將它發送出去。


          回到地面站,進入太空,回到衛星天線,然后回到無線路由器,再到手機上。


          手機 -> WiFi 路由器 ->衛星天線 ->衛星 -> 地面站 -> 服務器 -> 地面站 -> 衛星 -> 衛星天線 -> WiFi 路由器 -> 手機


          如果我們算一下,就是 10 + ( 1 + 120 + 120 + 60 ) x 2 = 612 毫秒。


          這是每次往返額外的 612 毫秒——也許這看起來不是很長時間,但你的網站可能只是為了獲取第一個資源就需要許多個往返。


          另外,HTTPS 在完成第一個往返之前需要額外的兩次往返——這使延遲達到了 1836 毫秒!


          對于生活在陸地上的人,延遲又是怎樣的


          衛星網絡似乎是一個極端的例子——我選擇它作為例子是因為它能夠充分說明了網絡延遲這個問題——但對于生活在陸地上的人來說,延遲可能比這更糟糕,原因有很多。


          • 2G 網絡的延遲通常在 300 毫秒到 1000 毫秒之間;
          • 3G 網絡的延遲可以在 100 毫秒到 500 毫秒之間;
          • 嘈雜的移動網絡——比如在一個異常擁擠的地方,比如音樂節;
          • 處理大流量的服務器;
          • 其他一些不好的東西。


          不穩定的網絡連接也會導致數據包丟失——導致需要另一個往返來獲取丟失的數據包。


          了解了 14KB 法則,接下來可以做些什么


          當然,你應該讓你的網頁盡可能的小——你愛你的訪客,你希望他們開心。將每個頁面的大小控制在 14KB 以內是一個不錯的主意。


          這 14KB 可以是壓縮數據——所以實際上可以對應大約 50KB 的未壓縮數據——這已經非常慷慨了。要知道,阿波羅 11 的制導計算機只有 72KB 內存。


          去掉自動播放的視頻、彈出窗口、Cookie、Cookie 橫幅、社交網絡按鈕、跟蹤腳本、JavaScript 和 CSS 框架,以及所有其他人們不喜歡的垃圾——你可能就能實現 14KB 法則。


          假設你已經盡力將所有內容控制在 14KB 以內,但仍然做不到——但 14KB 法則仍然很有用。


          你可以用發送給訪問者的前 14KB 數據來渲染一些有用的東西——例如一些關鍵的 CSS、JS 和解釋如何使用你的應用程序的前幾段文本。


          需要注意的是,14KB 法則包含了 HTTP 標頭——這些是未壓縮的(即使是 HTTP/2 的第一個響應),也包含圖片,所以你應該只加載在頁面上方的內容,并保持它們最小,或者使用占位符,讓訪問者知道他們在等待一些更好的內容。


          關于這個法則的一些注意事項


          14KB 法則更像是一種經驗之談,而不是計算的基本法則。


          • 一些服務器已經將 TCP 慢啟動初始窗口從 10 個數據包增加到 30 個;
          • 有時服務器知道它可以從更大數量的數據包開始傳輸,因為它使用 TLS 握手來建立一個更大的窗口;
          • 服務器可以緩存路由可管理的數據包數量,并在下一次連接時發送更多的數據包;
          • 還有其他需要注意的地方——這里有一篇文章更深入地探討關于為什么 14KB 法則并不總是這么回事(https://www.tunetheweb.com/blog/critical-resources-and-the-first-14kb/)。


          HTTP/2 和 14KB 法則


          有一種觀點認為,在使用 HTTP/2 時,14KB 法則不再適用。我已經讀了所有我能讀到的關于這個問題的東西,但我還沒有看到任何證據表明使用 HTTP/2 的服務器已經停止使用 TCP 慢啟動(從 10 個數據包開始)。


          HTTP/3 和 QUIC


          與 HTTP/2 類似,有一種觀點認為 HTTP/3 和 QUIC 將廢除 14KB 法則——事實并非如此。實際上,QUIC 仍然建議使用 14KB 法則。


          原文鏈接:

          https://endtimes.dev/why-your-website-should-be-under-14kb-in-size/

          ss的長度單位分為兩種,一種為絕對長度,一種為相對長度。日常設計與開發中或多或少都會接觸到。前端畢竟是根據設計稿寫頁面,UI設計師也是按照規范去設計頁面。

          絕對長度

          px

          即像素pixel,它是最基礎也是最常用的一個長度單位

          cm

          厘米, 1cm=37.8px

          mm

          毫米,1mm=3.78px

          in

          即英尺inch, 1in=2.54cm=96px

          pt

          即點point,1pt=1/72in=1.33px

          pc

          即派卡,1pc=12pt=16px,派卡是印刷行業的長度單位

          相對長度

          em

          一個字符大小,字符大小在瀏覽器中默認為16px

          EM特點

          -1. em的值并不是固定的;

          -2. em會繼承父級元素的字體大小。

          所以我們在寫CSS的時候,需要注意兩點:

          -1. body選擇器中聲明Font-size=62.5%;

          -2. 將你的原來的px數值除以10,然后換上em作為單位;

          -3. 重新計算那些被放大的字體的em數值。避免字體大小的重復聲明。

          避免1.2 * 1.2= 1.44的現象,比如說你在#content中聲明了字體大小為1.2em,那么在聲明p的字體大小時就只能是1em,而不是1.2em, 因為此em非彼em,它因繼承#content的字體高而變為了1em=12px。

          rem

          rem是CSS3新增的一個相對單位(root em,根em), 相對于根元素HTML的字體大小。這個單位與em有什么區別呢?區別在于使用rem為元素設定字體大小時,仍然是相對大小,但相對的只是HTML根元素。這個單位可謂集相對大小和絕對大小的優點于一身,通過它既可以做到只修改根元素就成比例地調整所有字體大小,又可以避免字體大小逐層復合的連鎖反應。

          例如,根元素的字體大小 16px,10rem 將等同于 160px,即 10 x 16 = 160。

          簡單點說就是根em.

          百分比%

          百分比是一個相對長度單位,相對于包含塊(containing block)的高寬或字體大小

          關于包含塊(containing block)的概念,不能簡單地理解成是父元素。

          如果是靜態定位和相對定位,包含塊一般就是其父元素。

          如果是絕對定位的元素,包含塊應該是離它最近的 position為非static屬性的祖先元素。

          如果是固定定位的元素,它的包含塊是視口(viewport)

          vh

          視口高度,默認為視口高度的1%

          vw

          視口寬度,默認為視口寬度的1%

          <div class="left">left</div>

          <div class="right">right</div>

          <style>

          * {

          padding: 0;

          margin: 0

          }

          .left {

          float: left;

          width: 50vw;

          height: 20vh;

          background-color: orange;

          text-align: center;

          line-height: 20vh;

          font-size: 3rem

          }

          .right {

          float: right;

          width: 50vw;

          height: 20vh;

          background-color: red;

          text-align: center;

          line-height: 20vh;

          font-size: 3rem

          }

          </style>

          vmin

          布局視口高度和寬度之中值較小的那個的 1/100

          vmax

          布局視口高度和寬度之中值較大的那個的 1/100

          比如:瀏覽器高度950px,寬度為1920px, 1 vh = 950px/100 = 9.5 px,1vw = 1920px/100 =19.2 px。

          vmax相對于視口的寬度或高度中較大的那個。其中最大的那個被均分為100單位的vmax。

          vmin相對于視口的寬度或高度中較小的那個。其中最小的那個被均分為100單位的vmin。

          fr

          grid布局中利用的一個長度單位。在gird布局中,我們經常會利用fr來進行計算

           <div class="grid">
           <div class="column">1</div>
           <div class="column">2</div>
           <div class="column">3</div>
           <div class="column">4</div>
           <div class="column">5</div>
           <div class="column">6</div>
           </div>
          	 <style type="text/css">
           * {
           margin: 0px;
           padding: 0px;
           }
           .grid {
           height:300px;
           width: 1000px;
           background: #f1f1f1;
           margin: 20px auto;
           overflow: auto;
           display: grid;
           grid-template-columns: 100px repeat(5, 1fr);
           grid-column-gap: 10px;
           }
           .column {
           background: orange;
           }
           </style>
          

          當然也有小程序中的rpx,相對屏幕自適應

          rpx(responsive pixel): 可以根據屏幕寬度進行自適應。規定屏幕寬為750rpx。如在 iPhone6 上,屏幕寬度為375px,共有750個物理像素,則750rpx = 375px = 750物理像素,1rpx = 0.5px = 1物理像素。

          、Html概述

          Html是Hyper Text Mark-up Language 的首字母簡寫,意思是超文本標記語言,超文本指的是超鏈接,標記指的是標簽,是一種用來制作網頁的語言,這種語言由一個個的標簽組成,用這種語言制作的文件保存的是一個文本文件,文件的擴展名為html或者htm,一個html文件就是一個網頁,html文件用編輯器打開顯示的是文本,可以用文本的方式編輯它,如果用瀏覽器打開,瀏覽器會按照標簽描述內容文件渲染成網頁,顯示的網頁可以從一個網頁鏈接跳轉到另一個網頁。
          

          二、Html標簽語法

          Html中標簽分為 :成對標簽和自閉合標簽【空標簽】

          1、成對標簽

          成對出現,有開始標簽必須有結束標簽,內容包裹在兩個標簽中,而且開始標簽名和結束標簽名一致,并且結束標簽必須以斜杠/開頭

          語法:

          <font>內容</font>
          

          2、自閉合標簽

          只有一個標簽,用斜杠結束,斜杠也可以省略

          語法:

          <br/>
          

          注意事項:

          • 成對標簽中,結束標簽必須以斜杠開頭
          • 成對標簽與成對標簽可以嵌套不能交叉
          • 標簽名不區分大小寫,但是我們都必須小寫

          三、Html基本架構

          <!DOCTYPE html>
          <html lang="en">
          <head>
              <title></title>
          </head>
          <body>
              
          </body>
          </html>
          

          1、!DOCTYPE

          !DOCTYPE html是文檔聲明,定義文檔類型為html,并且告訴不同的瀏覽器用標準方式進行解析html語言,如果不寫的話,會產生怪異模式,所謂怪異模式,就是瀏覽器會用自己的方式進行解析,不同的瀏覽器有各自的解析方式,從而會出現無效果、不兼容等問題。

          注意,html中有兩種聲明類型,一種叫做xhtml,即html,另一種叫做html5,html5是xhtml的升級版,所以我們建議使用html5的聲明方式

          xhtml聲明方式:

          <htmlxmlns="http://www.w3.org/1999/xhtml">

          html5聲明方式:

          <!DOCTYPE html>

          2、html

          html是html文檔的整體,也就是表示一個網頁。

          html中的lang="en"是定義該文件語言是英文

          3、head

          head是html的第一層子元素【子標簽】,負責對網頁進行一些設置以及定義標題,設置包括定義網頁的編碼格式,外鏈css樣式文件和JavaScript文件等。設置的內容不會顯示在網頁上,標題的內容會顯示在標題欄中。即title標簽。

          4、meta

          meta是html語言head標簽中的一個輔助性標簽,該標簽不包含任何內容,但是該標簽的屬性定義了與文檔相關聯的名稱,比如:編碼

          <meta charset="utf-8"></meta>
          

          5、body

          body也是html的第一層子元素,我們頁面中顯示的所有內容全部都是編寫在該標簽體中。

          四、Html文檔規范

          html制定了文檔的編寫規范,必須遵守。

          所有的標簽必須小寫

          所有的屬性必須用雙引號括起來

          五、Html注釋

          html文檔代碼中可以插入注釋,注釋是對代碼的說明和解釋,注釋的內容不會顯示在頁面上。

          注釋的語法:

          <!-- 注釋的內容 -->

          六、html基本屬性

          注:屬性是標簽的輔助作用。

          屬性 描述 bgcolor 設置網頁的背景顏色 background 設置網頁的背景圖片

          1.bgcolor

          設置網頁的背景顏色

          <!DOCTYPE html>
          <html lang="en">
          <head>
              <title>html的屬性</title>
          </head>
          <body bacolor="pink">
              
          </body>
          </html>
          

          2.路徑

          我們在開發網頁時,需要經常的插入圖片、視頻、文件等一些操作,但是我們需要指定文件所在的位置,這個位置就是所謂的路徑

          路徑分為:

          1. 相對路徑 指目標相對于當前文件的路徑,網頁結構設計中多采用這種方式來表示目標的路徑。相對路徑有多種表示方法,其表示的意義不盡相同。表示方法如下: ./ :代表文件所在的目錄(可以省略不寫)../ :代表文件所在的父級目錄../../ :代表文件所在的父級目錄的父級目錄/ :代表文件所在的根目錄【/ : 可以理解為目標文件的絕對路徑】
          2. 絕對路徑 指目標文件的完整路徑,從盤符開始。

          3.background

          設置網頁的背景圖片

          <!DOCTYPE html>
          <html lang="en">
          <head>
              <title>html的屬性</title>
          </head>
          <body background="../images/10.jpg">
              
          </body>
          </html>
          

          注意事項:

          bgcolor和background不能同時使用

          background不能指定絕對路徑

          七、Html標簽

          1.網頁的組成

          網頁的組成:文字、圖片、視頻、超鏈接、列表、表格、表單等組成。

          2、文本段落標簽

          標簽 描述 hn 設置文字標題【n:取值范圍 1~6】 center 居中對齊 hr 水平線 屬性(width:寬度 color:顏色 size:粗細) br 換行 p 段落

          3、文本控制標簽

          標簽 描述 font 設置字體,需要借助屬性設置

          屬性 描述 color 設置字體顏色 size 設置字體大小,不需要帶單位,取值范圍:1~7【瀏覽器默認值:3】 face 設置字體風格

          <font size="2" color="red" face="黑體"></font>
          

          4、文本格式化標簽

          標簽 描述 b 定義粗體文本 em 定義著重文字 i 定義斜體文字 small 定義小號字 strong 定義加重語氣 sub 定義下標字 sup 定義上標字 ins 定義插入字 del 定義刪除字

          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Html文本格式化標簽</title>
          </head>
          <body>
          
              <b>粗體文本</b>
              <i>傾斜文本</i>
              <em>著重文本</em>
              <small>小號字</small>
              <strong>加重語氣</strong>
              <sub>上標</sub>
              <sup>下標</sup>
              <ins>插入字</ins>
              <del>刪除字</del>
              
          </body>
          </html>
          

          5、圖片標簽

          在Html中,圖像由

          標簽定義。

          是空標簽,意思是說,它只包含屬性。

          要在頁面上顯示圖像,你需要使用源屬性(src)。src指"source"。源屬性的值是圖像的URL地址。

          標簽 描述 img 圖片標簽

          屬性 描述 src 指定圖片的地址 width 設置圖片的寬度 height 設置圖片的高度 alt 設置圖片的預備文本

          注意事項:不建議設置圖片大小,容易失真

          6、audio

          在Html中,聲音由標簽定義。

          標簽 描述 audio 聲音標簽

          屬性 描述 src 指定聲音地址

          <audio src="nice.mp3">對不起,您的瀏覽器不支持</audio>
          

          7、video

          在Html中,視頻由video標簽定義

          標簽 描述 video 視頻標簽

          屬性 描述 src 指定視頻地址

          <video src="美女.mp4">對不起,您的瀏覽器不支持</video>
          

          8、超鏈接

          a標簽定義超鏈接,用于從一個頁面鏈接到另一個頁面。

          a標簽最重要的屬性是href,它指定鏈接的目標。

          在所有瀏覽器中,鏈接的默認外觀如下:

          未被訪問的鏈接帶有下劃線而且是藍色的

          已被訪問的鏈接帶有下劃線而且是紫色的

          活動鏈接帶有下劃線而且是紅色的

          語法:

          <a href="鏈接目標">點擊內容</a>
          

          屬性 描述 href 指定鏈接目標 name 指定錨的名稱 download 指定下載鏈接 target 指定跳轉方式 屬性值 描述 _blank 新窗口打開【常用】 _parent 在父窗口中打開鏈接【了解】 _self 默認,在當前窗口打開【了解】 _top 在當前窗體打開鏈接,并替換當前的整個窗體【了解】 framename 到 iframe 在講【常用】

          超鏈接分類:

          • 內部鏈接 鏈接目標:本地頁面 <a href="demo.html">點擊內容</a>
          • 外部鏈接 鏈接目標:外部頁面 <a href="http://www.baidu.com">點擊內容</a>
          • 多媒體鏈接 鏈接目標:圖片、視頻等 <a href="images/美女.jpg">點擊內容</a>
          • 電子郵件鏈接 鏈接目標:電子郵件【系統自帶的電子郵件】 <a href="mailto:12345@qq.com">點擊內容</a>
          • 錨鏈接 鏈接目標:錨點 1.建立錨點
            <
            a name="錨點名"></a>

            2.跳轉
            <a href="#錨點名">點擊內容</a>

          9、列表

          列表的使用與word等軟件的列表概念相似,只不過是應用在網頁展示中。

          1.有序列表

          有序列表是指有數字編號或字母的列表項,可以使用css定義更多樣式。

          <!-- 有序列表 -->
              <ol type="a">
                  <li>新聞一</li>
                  <li>新聞二</li>
                  <li>新聞三</li>
              </ol>
          

          屬性 描述 type 設置符號類型 值:1 a A I i 默認數字 start 從第幾個開始【用于ol標簽中】 value 從第幾個開始【用于li標簽中】

          <!-- 有序列表 -->
              <ol type="a" start="4">
                  <li>新聞一</li>
                  <li type="1" value="1">新聞二</li>
                  <li>新聞三</li>
              </ol>
          

          2、無序列表

          無序列表是指沒有數字編號或字母的列表項,可以使用css定義更多樣式。

          <!-- 無序列表 -->
          <ul>
              <li>童裝</li>
              <li>男裝</li>
              <li>女裝</li>
          </ul>
          

          屬性 描述 type 用于設置符號類型,默認:實心圓 值:空心圓、正方形 【用于ul、li】

          <!-- 無序列表 -->
          <ul type="square">
                  <li>童裝</li>
                  <li type="circle">男裝</li>
                  <li>女裝</li>
              </ul>
          

          3、描述列表

          描述列表指每個列表項有單獨的標題。

          <!-- 描述列表 -->
              <dl>
                  <dt>開源產品</dt>
                  <dd>Java封裝庫</dd>
                  <dd>Web組件庫</dd>
                  
                  <dt>網站導航</dt>
                  <dd>mrliujava.com</dd>
                  <dd>mrliuweb.com</dd>
              </dl>
          

          10、表格

          表格在網頁開發中使用頻率非常高,尤其是數據展示的時候。

          10.1 基本使用

          標簽 描述 table 代表表格標簽 caption 表格標題 thead 表頭部分 tbody 表格主體部分 tfoot 表格尾部

          屬性 描述 border 表格邊框 cellspacing 單元格與單元格間距 width 寬度 height 高度 bgcolor 設置背景顏色 background 設置背景圖片 align 對齊方式

          <!-- 表格 -->
              <table border="1" cellspacing="0" width="600px" height="200px">
                  <caption>員工薪資統計表</caption>
                  <thead>
                      <tr>
                          <th>序號</th>
                          <th>姓名</th>
                          <th>性別</th>
                          <th>職位</th>
                          <th>薪資</th>
                      </tr>
                  </thead>
          
                  <tbody>
                      <tr>
                          <td>1</td>
                          <td>狗蛋</td>
                          <td>男</td>
                          <td>JavaEe工程師</td>
                          <td>8780</td>
                      </tr>
          
                      <tr>
                          <td>2</td>
                          <td>黑妞</td>
                          <td>女</td>
                          <td>Web前端工程師</td>
                          <td>9750</td>
                      </tr>
          
                      <tr>
                          <td>3</td>
                          <td>傻蛋</td>
                          <td>妖</td>
                          <td>測試工程師</td>
                          <td>996</td>
                      </tr>
                  </tbody>
          
                  <tfoot>
                      <tr>
                          <td>當前頁:1 頁</td>
                          <td>上一頁</td>
                          <td>下一頁</td>
                          <td>尾頁</td>
                          <td>共 3 頁</td>
                      </tr>
                  </tfoot>
              </table>
          

          10.2 單元格合并

          屬性 說明 rowspan 行合并 colspan 列合并

          下面是行合并:

          <!-- 表格 -->
              <table border="1" cellspacing="0" width="600px" height="200px">
                  <caption>員工薪資統計表</caption>
                  <thead>
                      <tr>
                          <th>序號</th>
                          <th>姓名</th>
                          <th>性別</th>
                          <th>職位</th>
                          <th>薪資</th>
                      </tr>
                  </thead>
          
                  <tbody>
                      <tr>
                          <td>1</td>
                          <td>狗蛋</td>
                          <td>男</td>
                          <td rowspan="2">JavaEe工程師</td>
                          <td>8780</td>
                      </tr>
          
                      <tr>
                          <td>2</td>
                          <td>黑妞</td>
                          <td>女</td>
                          <td>9750</td>
                      </tr>
          
                      <tr>
                          <td>3</td>
                          <td>傻蛋</td>
                          <td>妖</td>
                          <td>測試工程師</td>
                          <td>996</td>
                      </tr>
                  </tbody>
          
                  <tfoot>
                      <tr>
                          <td>當前頁:1 頁</td>
                          <td>上一頁</td>
                          <td>下一頁</td>
                          <td>尾頁</td>
                          <td>共 3 頁</td>
                      </tr>
                  </tfoot>
              </table>
          

          下面是列合并:

          <!-- 表格 -->
              <table border="1" cellspacing="0" width="600px" height="200px">
                  <caption>員工薪資統計表</caption>
                  <thead>
                      <tr>
                          <th>序號</th>
                          <th>姓名</th>
                          <th>性別</th>
                          <th>職位</th>
                          <th>薪資</th>
                      </tr>
                  </thead>
          
                  <tbody>
                      <tr>
                          <td>1</td>
                          <td>狗蛋</td>
                          <td>男</td>
                          <td>JavaEe工程師</td>
                          <td>8780</td>
                      </tr>
          
                      <tr>
                          <td>2</td>
                          <td>黑妞</td>
                          <td>女</td>
                          <td>Web前端工程師</td>
                          <td>9750</td>
                      </tr>
          
                      <tr>
                          <td>3</td>
                          <td colspan="2">傻蛋</td>
                          <td>測試工程師</td>
                          <td>996</td>
                      </tr>
                  </tbody>
          
                  <tfoot>
                      <tr>
                          <td>當前頁:1 頁</td>
                          <td>上一頁</td>
                          <td>下一頁</td>
                          <td>尾頁</td>
                          <td>共 3 頁</td>
                      </tr>
                  </tfoot>
              </table>
          

          11、表單

          表單是一個包含表單元素的區域。

          表單元素是允許用戶在表單中輸入內容,比如:文本域(textarea)、下拉列表(select)、單選框(radio)、復選框(checkbox)等等。

          11.1 基本使用

          表單需要使用表單標簽來設置:

          <!-- 表單 -->
          <form>
          input元素
          </form>

          11.2 GET&POST

          屬性 說明 action 后臺地址 method 提交方式GET或POST

          GET和POST區別:

          1.GET

          • 數據會顯示在地址欄中,數據不安全
          • 數據大小有限制
          • 數據通過請求頭傳遞

          2.POST

          • 數據不會顯示在地址欄中,數據安全
          • 數據對大小無限制
          • 數據通過實體內容傳遞
          <form action="后端接口" method="POST">
                  <input type="text">
                  <input type="password">
          </form>
          

          11.3 LABEL

          使用label用于描述表單標題,當點擊標題后文本框會獲得焦點,需要保證使用的ID在頁面中是唯一的。

          <form action="后端接口" method="POST">
                  <label for="username">用戶名</label>
                  <input type="text" id="username">
          
                  <label for="password">密碼</label>
                  <input type="password" id="password">
          </form>
          

          也可以將文本框放在label標簽內部,這樣就不需要設置id與for屬性了。

          11.4 INPUT

          文本框用于輸入單行文本使用,下面是常用屬性與示例。

          屬性 說明 type 表單類型,默認為text name 后端接收字段名 required 必須輸入 placeholder 提示文本內容 value 默認指 maxlength 允許最大輸入字符數 size 表單長度,一般用css來控制 disabled 禁用,不可提交后端 readonly 只讀,可提交后端 accept 設置選中類型 比如:.jpg capture 使用麥克風\視頻或攝像頭哪種方式獲取手機上傳文件,支持的值有microphone , video , camera

          11.4.1 基本示例

          <form action="后端接口" method="POST">
                  <label for="username">用戶名</label>
                  <input type="text" name="username" id="username" placeholder="請輸入用戶名" maxlength="5" size="50" required>
          </form>
          

          11.4.2 調用攝像頭

          當input類型為file時手機會讓用戶選擇圖片或者拍照,如果想直接調取攝像頭使用以下代碼.

          <form action="后端接口" method="POST">
                  <label for="file">上傳文件</label>
                  <input type="file" name="file" id="file" accept="*.jpg" capture="camera">
          </form>
          

          11.4.3 其他類型

          通過設置表單的type字段可以指定不同的輸入內容.

          類型 說明 email 輸入內容為郵箱 url 輸入內容為URL地址 password 輸入內容為密碼項 tel 電話號,移動端會調出數字鍵盤 search 搜索框 hidden 隱藏表單 submit 提交表單 reset 重置表單 button 自定義按鈕

          11.4.4 HIDDEN

          隱藏表單用于提交后臺數據,但在前臺內容不顯示所以在其上做用樣式定義也沒有意義.

          <input type="hidden" name="id" value="1">
          

          11.4.5 SUBMIT

          創建提交按鈕可以將表單數據提交到后臺,有多種方式可以提交數據,比如:AJAX,或者Html的表單按鈕.

          a.使用input構建提交按鈕,如果設置了name值,那么按鈕數據也會提交到后臺,如果有多個表單項可以通過這些進行判斷是哪個表單提交的.

          <input type="submit" name="submit" value="提交表單">
          

          b.使用button也可以提交,設置type屬性為submit或不設置都可以提交表單.

          <button type="submit">提交表單</button>
          

          11.4.6 禁用表單

          通過為表單設置disabled或readonly都可以禁止表單,單readonly表單的數據可以提交到后端

          <input type="text" value="數據" readonly>
          

          11.4.7 PATTERN

          表單可以通過設置pattern屬性指定正則驗證.

          屬性 說明 pattern 正則表達式驗證規則 oninvalid 輸入錯誤時觸發的事件

          <form action="">
                  <label for="username">用戶名</label>
                  <input type="text" name="username" id="username" pattern="[a-z]{5,20}" oninvalid="validate('請輸入5~20位字母的用戶名')">
                  <button>提交表單</button>
              </form>
          
              <script>
                  function validate(message){
                      alert(message);
                  }
              </script>
          

          11.4.8 TEXTAREA

          文本域指可以輸入多行文本的表單,當然更復雜的情況可以使用編輯器如ueditor , ckeditor等.

          屬性 說明 cols 列字符數(一般使用css控制更好) rows 行數(一般使用css控制更好)

          <textarea cols="30" rows="3">請踩踩我......</textarea>
          

          11.4.9 SELECT

          下拉列表項可用于多個值中的選擇.

          屬性 說明 multiple 支持多選 size 列表框高度 optgroup 選項組 selected 選中狀態 option 選項值

          <form action="">
                  <select multiple size="10">
                      <option value="">選擇課程</option>
                      <optgroup label="后端">
                          <option value="">JAVA</option>
                          <option value="">PHP</option>
                          <option value="">LINUX</option>
                      </optgroup>
          
                      <optgroup label="前端">
                          <option value="">HTML</option>
                          <option value="">CSS</option>
                          <option value="">JAVASCRIPT</option>
                      </optgroup>
                  </select>
              </form>
          

          11.4.10 RADIO

          單選框指只能選擇一個選項的表單,如性別的選擇:男 , 女 , 保密 只能選擇一個.

          屬性 說明 checked 選中狀態

          <form action="">
                  <input type="radio" name="" id="boy" checked>
                  <label for="boy">男</label>
          
                  <input type="radio" name="" id="girl">
                  <label for="girl">女</label>
              </form>
          

          11.4.11 CHECKBOX

          復選框指允許選擇多個值的表單

          屬性 說明 checked 選中狀態

          <form action="">
                  <input type="checkbox" name="JAVA" id="java">
                  <label for="java">JAVA</label>
          
                  <input type="checkbox" name="WEB" id="web">
                  <label for="web">WEB</label>
              </form>
          

          11.4.12 FILE

          文件上傳有很多方式,可以使用插件或者JS拖放上傳處理.Html本身也提供了默認的上傳功能,只是上傳效果并不是很美觀.

          屬性 說明 multiple 支持多選 accept 允許上傳類型.png , .psd 或者 image/png , image/gif

          <form action="" enctype="multipart/form-data">
                  <input type="file">
                  <input type="submit" value="上傳">
              </form>
          

          11.4.13 日期時間

          屬性 說明 min 最小時間 max 最大時間 step 間隔: date缺省是1天 week缺省是1周 month缺省是1月

          a.日期選擇

          <h1>日期選擇</h1>
              <form action="">
                  <input type="date" step="5" min="2020-09-22" max="2025-01-15" name="datetime">
              </form>
          

          b.周選擇

          <h1>周選擇</h1>
              <input type="week" name="" id="">
          

          c.月份選擇

          <h1>月選擇</h1>
              <input type="month" name="" id="">
          

          d.日期與時間

          <h1>日期與時間</h1>
              <input type="datetime-local" name="" id="">
          

          11.4.14 DATALIST

          input表單的輸入值選項列表

          <form action="">
                  <label for="username">用戶名</label>
                  <input type="text" name="" id="usernmae" list="less">
                  <datalist id="less">
                      <option value="JAVA">后臺管理語言</option>
                      <option value="CSS">美化網站頁面</option>
                      <option value="MYSQL">掌握數據庫使用</option>
                  </datalist>
              </form>
          

          12、框架集

          frameset元素可定義一個框架集。它被用來組織多個窗口(框架),每個框架存有獨立的文檔,在其最簡單的應用中,frameset元素僅僅會規定在框架集中存在多少列或多少行,您必須使用cols或rows屬性。

          注意事項:由于是分割原網頁,所以我們不能在body中進行編寫,在head中進行分割。

          標簽 說明 frameset 框架集 frame 框架

          屬性 說明 cols 定義框架集中列的數目和尺寸 rows 定義框架集中行的數目和尺寸 frame border 去除框架邊框 scrolling 去除滾動條

          12.1 垂直框架

          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Html垂直框架</title>
          
              <frameset cols="50%,*" >
                  <frame src="http://www.baidu.com" frameborder="0" scrolling="no"></frame>
                  <frame src="http://www.taobao.com" frameborder="0"  scrolling="no"></frame>
              </frameset>
          </head>
          <body>
              
          </body>
          </html>
          

          12.2 水平框架

          <!DOCTYPE html>
          <html lang="en">
          	<head>
          		<meta charset="UTF-8">
          		<title>Html水平框架</title>
          		<frameset rows="50%,*" >
          				<frame src="http://www.baidu.com" frameborder="0" scrolling="no"></frame>
                  <frame src="http://www.taobao.com" frameborder="0" scrolling="no"></frame>
          		</frameset>
          	</head>
          <body>
          </body>
          </html>

          12.3 混合框架

          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Html混合框架</title>
          
              <frameset rows="20%,*" >
                  <frame src="http://www.baidu.com" frameborder="0" scrolling="no"></frame>
                  <frameset cols="20%,*">
                      <frame src="http://www.taobao.com" frameborder="0" scrolling="no"></frame>
                      <frame src="https://www.huya.com/" frameborder="0" scrolling="no"></frame>
                  </frameset>
                  
              </frameset>
          </head>
          <body>
              
          </body>
          </html>
          

          12.4 導航框架

          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Html美女</title>
          </head>
          <body>
              
              <img src="../images/10.jpg" alt="">
          
          </body>
          </html>
          
          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Html野獸</title>
          </head>
          <body>
              
          
              <img src="../images/timg.gif" alt="">
          
          </body>
          </html>
          
          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Html動物</title>
          </head>
          <body>
              
              <img src="../images/4.jpg" alt="">
          
          </body>
          </html>
          
          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Html鏈接</title>
          </head>
          <body>
          
              <a href="Html美女.html" target="view">美女圖片</a>
              <a href="Html野獸.html" target="view">野獸圖片</a>
              <a href="Html動物.html" target="view">動物圖片</a>
              
          </body>
          </html>
          
          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>Html垂直框架</title>
          
              <frameset rows="20%,*" >
                  <frame src="http://www.baidu.com" frameborder="0" scrolling="no"></frame>
                  <frameset cols="20%,*">
                      <frame src="Html鏈接.html" frameborder="0" scrolling="no"></frame>
                      <frame src="https://www.huya.com/" frameborder="0" scrolling="no" name="view"></frame>
                  </frameset>
                  
              </frameset>
          </head>
          <body>
              
          </body>
          </html>
          

          13、內聯框架

          iframe元素會創建包含另外一個文檔的內聯框架。

          屬性 說明 align 對齊方式,后期采用css的方式進行設置 width 設置寬度 height 設置高度 src 設置iframe中顯示的文檔的URL name iframe的名稱 scrolling 是否顯示滾動條 frameborder 設置iframe的邊框


          主站蜘蛛池模板: 国产成人无码AV一区二区| 无码精品人妻一区二区三区免费看 | 日本一区午夜爱爱| 亚洲欧洲一区二区三区| 亚洲综合色自拍一区| 中文字幕日韩一区二区三区不卡| 天堂资源中文最新版在线一区| 亚洲香蕉久久一区二区| 国产在线精品一区二区在线看| 中文字幕一区在线| 亚洲国产av一区二区三区丶| 亚洲一区二区三区在线观看网站 | 亚洲一区二区精品视频| 亚洲啪啪综合AV一区| 国产综合无码一区二区色蜜蜜 | 精品在线一区二区| 韩国资源视频一区二区三区| 亚洲av日韩综合一区久热| 久久精品无码一区二区无码| 中文字幕在线无码一区二区三区 | 国产伦一区二区三区免费| 亚洲熟妇av一区| 91午夜精品亚洲一区二区三区 | 国产一区二区三区在线视頻| 亚洲日本精品一区二区| 麻豆一区二区三区精品视频| 日本一区二区三区在线网 | 国产福利微拍精品一区二区| 国产激情一区二区三区在线观看| 久久久久人妻精品一区三寸蜜桃| 国产成人精品久久一区二区三区| 亚洲一区二区三区乱码A| 亚洲国产欧美日韩精品一区二区三区| 一区二区三区精品高清视频免费在线播放| 亚洲AV无码一区二区三区DV| 一级特黄性色生活片一区二区| 中文字幕一区二区三区5566| 爆乳熟妇一区二区三区霸乳 | 亚洲av无码一区二区三区天堂| 农村人乱弄一区二区| 国产综合精品一区二区|