前端學習---html基礎知識

来源:https://www.cnblogs.com/charles8866/archive/2018/03/13/8557837.html
-Advertisement-
Play Games

HTML基本知識 學習html首先我們先看看HTML本質: web框架本質 我們在學socket,我們創建一個socketserver,然後運行起來,有一個client客戶端要連接socket服務端,連接上之後,如果兩邊都沒有close,就一直不斷開,可以不斷的進行請求。 那我們說一個網站,我們在服 ...


HTML基本知識

學習html首先我們先看看HTML本質:

web框架本質

我們在學socket,我們創建一個socketserver,然後運行起來,有一個client客戶端要連接socket服務端,連接上之後,如果兩邊都沒有close,就一直不斷開,可以不斷的進行請求。

那我們說一個網站,我們在伺服器端運行我們的網站,所有的客戶端就可以通過瀏覽器訪問我們寫的網站,所以我們用的iis,apache等它們本質上就是一個socket服務端,而我們打開的瀏覽器就是client端,進行數據傳輸。

我們如果基於TCP,客戶端和服務端連接之後,只要兩邊不close,也都可以一直不斷的訪問交互。但是網站瀏覽器瀏覽和這個是不一樣的。瀏覽器訪問了服務端,服務端給我們數據,瀏覽器得到了數據之後,連接就立馬斷開了,如果還想要拿數據,還得再次建立連接。即一次請求,一次響應,一次斷開。 

我們下麵寫一個socket服務端:

 1 import socket
 2 
 3 def handle_request(client):
 4     buf = client.recv(1024)
 5     client.send(bytes("HTTP/1.1 200 ok\r\n\r\n",encoding="utf-8"))
 6     client.send(bytes("Hello,Charles",encoding="utf-8"))
 7 
 8 
 9 def main():
10     sock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
11     sock.bind(('localhost',8000))
12     sock.listen(5)
13 
14     while True:
15         connection,addr = sock.accept()
16         handle_request(connection)
17         connection.close()
18 
19 if __name__ == '__main__':
20     main()

我們運行之後用瀏覽器訪問起來:

 

所以伺服器的本質根源就是這20行代碼,建立socket連接。

其實我網站的顯示內容本質上也就是一大堆的字元串,我們在send函數中發送了hello,clarles,在網站上就顯示了那個內容,如果我們加上一些標簽比如

<h1 style='background-color:red'>Hello,Charles</h1>

 那麼瀏覽器中顯示的就是如下:

 

那所以客戶端和伺服器端進行交互的時候,服務端返回的永遠是字元串,這個字元串之所以我們在瀏覽器上能看到上圖的樣式,那是因為瀏覽器把這個字元串進行瞭解析。瀏覽器認識這種格式。

所以我們要學的html其實就是一套瀏覽器認識的規則,這個就是html本質。

而我們開發者要做的就是:

1.學習html規則|(充當模板的作用)

2.從資料庫中獲取數據,然後替換到html文件的指定位置,這個事情以後就由web框架來做 

html標簽知識

 註釋:<!--註釋的內容-->

標簽分類:

1.自閉合標簽:<meta charset="utf-8">

2.主動閉合標簽:<title>測試</title>

 head內的標簽

meta

 1.頁面編碼(告訴瀏覽器是什麼編碼)

<meta http-equiv="content-type" content="text/html;charse=uft-8" >

2.刷新和跳轉:

<meta http-equiv="Refresh" Content="30">頁面預設30s刷新一次

<meta http-equiv="Refresh" Content="5;Url=http://www.baidu.com" />

3.關鍵詞:給搜索引擎用的

<meta name="keywords" content="啊哈哈哈,慈溪,測測" >

 4.描述:描述網站內容

<meta name="description" content="按實際了的開發唉算了的卡加的辣椒弗蘭德">

5.X-UA-Compatible:專門為IE設置的

<meta http-equiv="X-UA-Compatible" content-type="IE=EmulateIE7;IE=IE8;IE=IE9;" />

title

網頁頭部信息:<title>TItle</title>

Link 

1.css 

<link rel="stylesheet" type="text/css" href="css/common.css">

2.icon:網站圖標

<link ref="shortcut icon" href="image/image.ico"> 

 

Style

在頁面中寫樣式

例如:
<style type="text/css" > 
.bb{ 
       background-color: red; 
   } 
</style> 

Script

1.引進文件

<script type="text/javascript" src="http://www.googletagservices.com/tag/js/gpt.js"> </script >

2.寫js代碼

< script type="text/javascript" > ... </script >

 body內的標簽

標簽一般分為兩種:塊級標簽 和 行內標簽

行內標簽:a、span、select 等

塊級標簽:div、h1、p 等

各種符號

http://www.cnblogs.com/web-d/archive/2010/04/16/1713298.html

空格:&nbsp;    小於號:&gt;    大於號:&lt;

1.p和br

p表示段落,預設段落之間是有間隔的!

br 是換行

<p>1231<br/>32132</p>
<p>123132132</p>
<p>123132132</p>

2.H 標簽

<h1>h1</h1>

3.input系列:

a.text文本框:<input type="text" name="user" value="輸入框中的預設值"> ,顯示效果:

b.password密碼框:<input type="password" name="passwd">輸入的密碼是點,顯示效果:

c. submit提交按鈕:<input type="submit" value="提交">,顯示效果:

 用於表單的提交

d.button按鈕:<input type="button" value="登錄">,顯示效果:

 僅僅只是一個按鈕,沒有辦法進行表單的提交

e. radio單選框:<input type="radio" value="登錄" name="gender">,

name屬性如果都相同,則互斥

value屬性用於後臺獲取選擇的值

<form>
        <div>
            <p>請選擇性別:</p>
        男:<input type="radio" name="gender" value="1"/>
        女:<input type="radio" name="gender" value="2"/>
        </div>
        <input type="submit" value="提交"/>
    </form>

f.checkbox多選框:<input type="checkbox" value="1" name="hobby">

<p>愛好</p>
籃球:<input type="checkbox" name="hobby" value="1"/>
足球:<input type="checkbox" name="hobby" value="2"/>
排球:<input type="checkbox" name="hobby" value="3"/>
網球:<input type="checkbox" name="hobby" value="4"/>
<p>技能</p>
 python:<input type="checkbox" name="skill" value="python"/>
 php:<input type="checkbox" name="skill" value="php"/>

 效果:

如果需要預設選中的話:加一個屬性:checked="checked"

g.file上傳文件:<input type="file" name="fname">

如果你要用上傳文件功能,你再form表單中一定要加一個屬性:enctype='multipart/form-data' 

h:reset內容重置:<input type="reset" name="重置">

4.textarea多行文本:

<textarea name="meno">asdfasdf</textarea>

多行文本的預設值寫在中間

5.select下拉框:

<select name="city" size="10" multiple="multiple">
      <option value="1">北京</option>
       <option value="2" selected="selected">上海</option>
       <option value="3">南京</option>
       <option value="4">廣州</option>
       <option value="5">深證</option>
</select>

 顯示效果:

參數解釋:

  • size設置一次顯示多少個值
  • multiple可以多選,按住control鍵
  • selected="selected":預設選擇的值

分組顯示:optgroup,但是這些江蘇省,湖南省沒有辦法選中

<select name="city2" size="5">
     <optgroup label="江蘇省">
             <option>宿遷</option>
             <option>蘇州</option>
     </optgroup>
     <optgroup label="湖南省">
             <option>湘潭</option>
             <option>長沙</option>
     </optgroup>
</select>

 效果如圖:

6. a標簽

作用:

  • 跳轉
  • 錨點 :href="#某個標簽的id"標簽的ID不允許重覆
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <a href="#i1">第一章</a>
    <a href="#i2">第二章</a>
    <a href="#i3">第三章</a>
    <a href="#i4">第四章</a>
    <div id="i1" style="height:600px;">第一章內容</div>
    <div id="i2" style="height:600px;">第二章內容</div>
    <div id="i3" style="height:600px;">第三章內容</div>
    <div id="i4" style="height:600px;">第四章內容</div>
</body>
</html>

 

這個就是一個錨的效果:點擊第一章,跳轉到本頁面的第一章位置;點擊第二章,跳轉到本頁面的第二個位置 

7.img標簽

<img src="圖片鏈接" style="height:200px;width:200px" alt="沒有圖片顯示的內容" title="滑鼠放在圖片上的時候顯示的文字" />

註意:預設img標簽,有一個1px的邊框,在使用的時候應該先用border:0;把邊框去掉

8.列表 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <ul style="background-color: red">
        <li>asdf</li>
        <li>asdf</li>
        <li>asdf</li>
    </ul>
    <ol style="background-color: green">
        <li>asd</li>
        <li>asd</li>
        <li>asd</li>
    </ol>
    <dl style="background-color: yellow">
        <dt>asdf</dt>
            <dd>asdf12</dd>
            <dd>asdf12</dd>
        <dt>asdf</dt>
            <dd>asdf12</dd>
            <dd>asdf12</dd>
    </dl>
</body>
</html>

顯示效果如圖:

9.表格:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <table border="1">
        <tr>
            <td>主機名</td>
            <td>ip</td>
            <td>埠號</td>
        </tr>
        <tr>
            <td>localhost</td>
            <td>192.168.1.1</td>
            <td>8080</td>
        </tr>
    </table>
    <!--最規範的寫法,有表頭,有內容-->
    <table border="1">
        <thead>
            <tr>
                <th>主機名</th>
                <th>ip</th>
                <th>埠號</th>
            </tr>
        </thead>
        <tbody>
            <tr>
                <td>localhost</td>
                <td>192.168.1.1</td>
                <td>8080</td>
            </tr>
        </tbody>
    </table>
</body>
</html>

效果顯示:

要註意代碼的規範性!!

合併單元格:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <!--最規範的寫法,有表頭,有內容-->
    <table border="1">
        <thead>
            <tr>
                <th>表頭1</th>
                <th>表頭2</th>
                <th>表頭3</th>
                <th>表頭4</th>
            </tr>
        </thead>
        <tbody>
            <tr>
                <td>1</td>
                <td colspan="2">1</td>
                <td>1</td>
            </tr>
            <tr>
                <td rowspan="2">2</td>
                <td>2</td>
                <td>2</td>
                <td>2</td>
            </tr>
            <tr>
                <td>3</td>
                <td>3</td>
                <td>3</td>
            </tr>
        </tbody>
    </table>
</body>
</html>

 行合併用:rowspan       列合併用:colspan

效果顯示:

10.label標簽:用於點擊文字,使得關聯的標簽獲得游標

<label for="username">用戶名:</label>
<input id="username" type="text" name="user">

用id把input 和 label進行關聯,原本如果只是寫一個label和一個input,我們在點擊用戶名的時候,input沒有被選中,如果用for關聯了input里的id之後,我們點擊“用戶名”的時候也就選中input輸入框

11.fieldset: 在一個框中然後插入標題

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>

    <fieldset>
        <legend>登錄</legend>
        <label for="username">用戶名:</label>
            <input id="username" type="text" name="user"><br>
        <label for="password">&nbsp;&nbsp;&nbsp;&nbsp;碼:</label>
            <input id="password" type="text" name="pwd">
    </fieldset>
</body>
</html>

顯示效果:

 


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

-Advertisement-
Play Games
更多相關文章
  • //js判斷當前移動設備平臺 var isiOs = false; var isAndroid = false; var isWindowsPhone = false; if(/(iPhone|iPad|iPod|iOS)/i.test(navigator.userAgent)) { isiOS = ...
  • //獲取字元串長度String.prototype.strLen = function() { var len = 0; for (var i = 0; i < this.length; i++) { if (this.charCodeAt(i) > 255 || this.charCodeAt(i ...
  • 各種頁面常見佈局+知名網站實例分析+相關閱讀推薦 閱前必看:本文總結了各種常見的佈局實現,每個方法的優缺點分析往後在github上陸續補充。還有就是這篇文章沒提到的其他佈局,待本人後續想到或遇到定會在github上及時更新。由於文章篇幅較長,排版有些混亂,希望別介意哈。為了方便閱讀,還特意做了個錨點 ...
  • <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scal ...
  • function 是 js 的標識符 Function 是 js 裡面的一個 構造函數 1、new function 與 new Function 的區別 new 運算符在 js 裡面是 創建一個自定義的對象的實例 或者是 一個具有構造函數的本地對象的實例。 語法:new constructor [ ...
  • 這是很正常的video寫法,我們查看微信是什麼樣式 這樣種video控制項樣式並不是我們想要的。所有我們需要自己來寫視頻封面的樣式。 常用的方式:自己來設置視頻封面的樣式。 第一步:找一張視頻封面,設置大小。 第二步:video隱藏。 第三步: 用js來監聽用戶是否點擊圖片。用戶點擊圖片,則video ...
  • 請參考Mongoose的文檔 1、findOneAndUpdate([query], [doc], [options], [callback]) 有callback傳遞才執行。 2、exec是promise的寫法,代替callback,和使用callback作用一樣。 3、ts可以使用await/a ...
  • 1:中國人民通過對 ASCII 編碼的中文擴充改造,產生了 GB2312 編碼,可以表示6000多個常用漢字。 2:漢字實在是太多了,包括繁體和各種字元,於是產生了 GBK 編碼,它包括了 GB2312 中的編碼,同時擴充了很多。 3:中國是個多民族國家,各個民族幾乎都有自己獨立的語言系統,為了表示 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...