你寫HTML的時候,會注重語義化嗎?

其實說到語義化,多年前端開發經驗的老手估計也不會太在意,有時候工期太緊,有時候自己疏忽,也就不那么在意了,直接DIV+CSS一把梭下去了。

?

目錄

什么是HTML

什么是HTML語義化

HTML語義化所帶來的好處

我把CSS樣式引入到HTML文檔底部會怎么樣?


什么是HTML

什么是HTML,其實慢慢的,相信很多人天天用HTML,但你讓他背概念,還真不一定能背下來。我曾經就被問到過這個問題,瞬間讓人摸不著頭腦,面試題千千萬,總有意想不到的問題啊。他是一種超文本標記語言,是構建網站的基石。

什么是HTML語義化

如果一段好的前端代碼,下一個接手代碼的人,可以通過HTML標簽大概看出來,前任開發者大概是什么意圖,做出來的頁面是要展現一個大概什么樣子的東西。

雖然各個瀏覽器的內核可能不同,但大家支持HTML語義化上,標準還是非常相同的。雖然標準相同,但樣式可能每個瀏覽器的展示效果就大不相同了,alert這個組件大家肯定印象最深。但也不一定,現在alert的使用場景越來越少了,某個前端沒見過alert的樣子我都相信。

通過HTML語義化,即便在不寫CSS樣式的時候,或者CSS樣式加載稍慢的時候,網頁其實也會有一個良好的展示,不至于非常錯亂。而每個HTML標簽,其實也都具有自己獨特的含義,有表示布局盒子的,有表示段落的,有表示按鈕的。當然,也有一些帶有樣式的,例如b標簽,a標簽這樣的,他們其實會帶有一些初始化樣式。

HTML語義化所帶來的好處

就像很多網站的按鈕這種場景,其實應該是使用button標簽來實現的,甚么input標簽,添加了type特有的值后,也會展示成按鈕的樣式。但很多人就是div+css一把鎖下來了,也沒有什么問題,展示的樣式也很好看,功能也實現了,但總感覺差那么點意思,差哪里了呢?

第一個就是SEO相關的優化,網絡爬蟲相對來說,更喜歡爬取瀏覽器所支持的那些默認標簽,HTML語義化標簽寫的越好,爬蟲也越好解析;

第二個就是后續開發者,更好維護代碼了,更清晰的HTML語義化結構,是易讀的;

第三個就是CSS樣式異常的情況,比如CSS樣式加載緩慢,CSS樣式丟失的情況,如果沒有一個很好的HTML語義化結構,那網頁基本就沒法看了,錯亂嚴重。

我把CSS樣式引入到HTML文檔底部會怎么樣?

盡管總說語義化語義化的,但沒有CSS還真不行,而且最好是將CSS樣式放在文檔頭部而非底部。

<!DOCTYPE>
<html><head>// 放這里<style>html, body {}</style></head><body>// 而不是放這里<style>html, body {}</style></body>
</html>

因為HTML語義化始終是單薄的,一個華麗的網頁不可能靠HTML語義化支撐起來,必須得有CSS去裝飾,去做相同功能的樣式控制。但如果把樣式放到底部的話,試想一下,HTML文檔是從上至下渲染的,HTML標簽的DOM樹已經加載過了,到了文檔底部再加載CSS,解析后與DOM樹相結合,可想而知,網頁將會再重新渲染一次,也就是重繪。重繪倒是次要的,誰也不知道一個復雜的網頁會抖動到什么程度。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/12723.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/12723.shtml
英文地址,請注明出處:http://en.pswp.cn/web/12723.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

_pickle.UnpicklingError: STACK_GLOBAL requires str

導致這個報錯的原因是我跑yolo的時候修改數據集了&#xff0c;里面的label.cache沒有刪除&#xff0c;咱只要刪除掉緩存就行&#xff01;&#xff01; 我這里是已經刪除掉了&#xff0c;所以圖片里面沒有&#xff0c;一般就是在箭頭所示位置有.cache文件的

Vue3知識總結-4

Vue3知識總結-4 文章目錄 Vue3知識總結-4插槽Slots渲染作用域默認內容具名插槽插槽中的數據傳遞具名插槽傳遞數據 組件聲明周期聲明周期示意圖 組件生命周期的應用動態組件組件保持存活組件被卸載 異步組件依賴注入 插槽Slots 在某些場景中&#xff0c;可能想要為子組件傳遞一…

xxljob分片廣播+多線程實現高效定時同步elasticsearch索引庫

需求&#xff1a;為了利用elasticsearch實現高效搜索&#xff0c;需要將mysql中的數據查出來&#xff0c;再定時同步到es里&#xff0c;同時在同步過程中通過分片廣播多線程提高同步數據的效率。 1. 添加映射 使用kibana添加映射 PUT /app_info_article {"mappings&quo…

HL7協議

提示&#xff1a;文章寫完后&#xff0c;目錄可以自動生成&#xff0c;如何生成可參考右邊的幫助文檔 文章目錄 1.介紹2.傳輸協議規范2.1. MLLP2.1.1. 數據頭定義2.1.2. 轉義字符集 2.2. 規范說明2.3. 消息格式說明 3.HL7結構介紹3.1. 患者建檔&#xff08;ADT^A28&#xff09;…

linux c++獲取當前程序的運行路徑

比如我的程序名為:aaa 存放路徑是:/homo/code/ 我在/home/ccc 目錄執行shell文件。shell文件的內容為 #!/bin/bash /homo/code/aaa我希望獲取的路徑是 /homo/code/ 而不是腳本的路徑 給出完整接口代碼 #include <iostream> #include <string> #include <stri…

人工智能領域向量化技術加速多模態大模型訓練與應用

目錄 前言1、TextIn文檔解析技術1.1、文檔解析技術1.2、目前存在的問題1.2.1、不規則的文檔信息示例 1.3、合合信息的文檔解析1.3.1、合合信息的TextIn文檔解析技術架構1.3.2、版面分析關鍵技術 Layout-engine1.3.3、文檔樹提取關鍵技術 Catalog-engine1.3.4、雙欄1.3.5、非對稱…

matlab實現馬爾科夫鏈

在MATLAB中實現馬爾科夫鏈算法通常涉及定義狀態轉移矩陣、初始化狀態向量以及迭代狀態轉移過程。以下是一個簡單的步驟和示例代碼&#xff0c;用于演示如何在MATLAB中實現馬爾科夫鏈。 步驟 定義狀態轉移矩陣&#xff1a;狀態轉移矩陣P描述了從一個狀態轉移到另一個狀態的概率…

注冊海外公司為什么?

注冊海外公司通常是為了實現以下目標之一&#xff1a; 國際化業務擴張&#xff1a; 一些企業可能希望在海外注冊子公司&#xff0c;以便在國際市場上開展業務。這樣的公司可能是跨國企業&#xff0c;已經在多個國家有業務&#xff0c;或者是希望進入新的國際市場的企業。 稅收…

計算機服務器中了locked勒索病毒怎么解決,locked勒索病毒解密恢復工具

在網絡技術飛速發展的時代&#xff0c;通過網絡開展各項工作業務成為眾多企業的首選&#xff0c;網絡也為企業的生產運營提供了極大便利&#xff0c;大大提升了企業辦公效率&#xff0c;但是利用網絡避免不了網絡威脅的存在&#xff0c;數據安全問題一直是企業關心的主要話題。…

不知道代理IP怎么挑?一文帶你了解挑選的關鍵點!

IP代理在如今的網絡環境中扮演者至關重要的角色。通過使用代理IP&#xff0c;可以增強用戶個人信息和網絡的安全。但想要挑選到適合自己的代理IP&#xff0c;并非是一件易事。今天就為大家帶來挑選代理IP的關鍵注意點&#xff0c;幫你輕松篩選出最佳的選擇。 穩定性與速度&…

TikTok機房ip好還是住宅ip好?

住宅ip比較好&#xff0c;機房數據中心IP高效、低價&#xff0c;所以使用的人多且用處復雜&#xff0c;這類ip極大可能存在濫用的黑歷史&#xff0c;通過此類ip訪問tiktok&#xff0c;被禁止的可能性更高&#xff0c;更容易被拉入黑名單。所以我們推薦tiktok獨享原生ip搭建節點…

CC工具箱使用指南:【界線導出Excel(一橫)】

一、簡介 群友定制工具。 這個工具的目的是將面要素的邊界線的屬性導出Excel。 給定的Excel模板如下&#xff1a; 結果需要輸出每一段界一的起點、終點的坐標&#xff0c;這里以度分秒的方法表達。 每段界線的方位角以及方向&#xff0c;方向按16位方位角描述&#xff1a; …

高通QCS6490開發(六):連接使用攝像頭

本文將會介紹如何在FV01開發板上連接攝像頭和顯示預覽。 所用硬件有&#xff1a; 1. FV01開發板 2.Raspberry 攝像頭 操作步驟如下&#xff1a; 通過FPC線和杜邦線將FV01板和攝像頭連接起來&#xff0c;接線如下&#xff1a; 1、Camera設備連接&#xff0c;通過22pin轉15pi…

togaf培訓簡介2

1.定義 2.ADM 業務下降期不要瞎折騰&#xff0c;上升期配合業務做一些改革&#xff1f; 項目交付物不能是聊天記錄、PPT什么的&#xff0c;最起碼是郵件。 3.架構內容框架 或者叫&#xff1a;企業統一體。 包括&#xff1a;企業連續性和解決方案連續性 方案和工具的解耦很大程…

【回溯】1255. 得分最高的單詞集合

本文涉及知識點 回溯 力扣難道&#xff1a;1881 LeetCode1255. 得分最高的單詞集合 你將會得到一份單詞表 words&#xff0c;一個字母表 letters &#xff08;可能會有重復字母&#xff09;&#xff0c;以及每個字母對應的得分情況表 score。 請你幫忙計算玩家在單詞拼寫游戲…

Mysql常見數據類型探索

Mysql常見數據類型探索 數值類型 MySQL 支持所有標準 SQL 數值數據類型。 這些類型包括嚴格數值數據類型(INTEGER、SMALLINT、DECIMAL 和 NUMERIC)&#xff0c;以及近似數值數據類型(FLOAT、REAL 和 DOUBLE PRECISION)。 關鍵字INT是INTEGER的同義詞&#xff0c;關鍵字DEC是…

K8s 二進制部署 上篇

一 K8S按裝部署方式&#xff1a; ① Minikube Minikube是一個工具&#xff0c;可以在本地快速運行一個單節點微型K8S&#xff0c;僅用于學習、預覽K8S的一些特 性使用。 部署地址&#xff1a;https://kubernetes.io/docs/setup/minikube ② Kubeadmin Kubeadmin也是一個工…

vue網頁端控制臺展示獨有標記

效果展示 實現步驟 1. 新建js文件 定義一個類 用于提供控制臺打印日志顯示樣式的方法 src\libs\util.log.js class Logger {// 定義靜態方法static typeColor(type "default") {let color "";switch (type) {case "default":color "#3…

后臺菜單數據遞歸展示

后臺菜單數據遞歸展示 效果示例圖aslide.vueaslideItem.vuemenu 效果示例圖 aslide.vue <script setup>import {ref} from vue;const props defineProps({isCollapse: {type: Boolean,default: false}});import AslideItem from "./aslideItem.vue"const def…

MIRO時,修改頁簽“采購訂單參考”的數量時,金額不自動計算

MIRO 發票校驗時&#xff0c;進入到如下界面&#xff0c;系統參考采購訂單自動帶出已經收貨的金額和數量。 此時如果想要修改數量時&#xff0c;有些用戶賬號下&#xff0c;金額不自動計算&#xff0c;但是有些用戶賬號下&#xff0c;數量更改時&#xff0c;系統自動計算和建議…