✏️
ougege
  • README
  • Docs
    • index
    • Articles
      • AI
        • 体验Chrome AI
        • 体验Cloudflare Workers AI
        • 体验deepseek
      • CSS
        • CSS优化-PurgeCSS
        • 实用效果
        • 开发常用样式
      • Deepin
        • deepin20安装mysql
        • deepin使用tensorflow入门机器学习
        • deepin安装cuda和cuDNN
        • deepin安装lamp
        • deepin安装nvidia驱动
        • deepin安装oh my Zsh
        • deepin安装p7zip
        • deepin换源
        • 安装deepin系统后要做的事
      • Docker
        • CI/CD搭建配置
        • deepin搭建docker环境
        • docker安装和使用gitlab
        • docker搭建nginx+php环境
      • Essay
        • IOS申请邓白氏编码
        • Markdown-Mermaid
        • Markdown Use
        • webview白屏的问题查找和修复
        • 前端开发对接问题和解决办法汇总
        • 国务院机构改革方案
        • 国家级智库
        • 实用网站推荐
        • 常用Markdown数学公式语法
        • 强烈推荐前端要安装的vscode扩展
        • 新建销售计划-页面卡死问题分析
        • 海淘入坑手册
        • 竞品研究
        • 足球知识速成
      • Git
        • GitBook安装和常用命令
        • GitKraken免费版本
        • Git安装和配置
        • Git异常处理
        • Git Worktree使用
        • 前端工程化相关的实用git命令
      • JS
        • ESM模块导出方式对比
        • Emoji多端统一处理
        • JS发布订阅模式
        • JS性能优化
        • JS标准内置对象
        • JS链式调用原理
        • Promise介绍和使用
        • Range的使用
        • Vue+Oauth登录实现
        • Vue实现富文本插入Emoji
        • chrome扩展入门
        • es5新特性
        • es6常用特性
        • es常用片段
        • uniapp使用eslint校验代码
        • 与移动端通信
        • 优秀js库moment
        • 使用vue-socketio
        • 实现一个中间件
        • 小程序webview调试
        • 常用snippets
        • 常用正则
        • 常用的设计模式
        • 微信jssdk封装使用
        • 浏览器宏任务和微任务
        • 浏览器的5种Observer
        • 深入理解赋值、浅拷贝、深拷贝
        • 解析vue指令clickoutside源码
        • 键盘事件与KeyBoardWrapper交互
        • 高德地图常用方法封装
        • 高阶函数片段
      • Network
        • 使用Lighthouse分析前端性能
        • 前后端启用https
        • 宝塔nginx安装ngx_brotli
        • 比较gz与br加载速度
        • 浏览器https提示不安全
        • 浏览器提示HSTS
        • 简单使用tcpdump
        • 静态资源gzip优化
      • Node
        • CommonJS模块导出方式对比
        • Taro command not found 多平台解决方案
        • koa使用和API实现
        • node安装报错Unexpected-token
        • 使用nvm和nrm
        • 使用uniapp给小程序添加云函数
        • 使用verdaccio搭建本地npm仓库
        • 使用vue-cli搭建vue项目
        • 安装Node.js和npm配置
        • 编译成cjs和mjs的思路解析
        • 让你的npmPackage同时支持cjs和mjs
        • 通过GithubAction将内容部署到vps
      • Python
        • Python源管理
        • Python版本管理
        • mitmproxy抓包
        • 微信公众平台开发爬坑经历
      • Shell
        • Ubuntu安装deepin桌面环境
        • Ubuntu安装flatpak软件
        • Ubuntu安装wireshark
        • Ubuntu常见问题汇总
        • dell G3装系统无法识别第二块硬盘
        • linux下virtualbox用gho还原系统
        • mysql常用命令
        • navicat连接一键集成环境的mysql
        • nginx常用命令
        • pm2常用命令
        • virtualbox虚拟机和宿主机互相复制粘贴
        • vps内资源通过mega快传到本地
        • vps报错temporary failure in name resolution
        • vscode修改文件监控数
        • windows+linux双系统引导修复
        • zsh常用插件和命令
        • 一键搭建ChatGPT web版
        • 使用V2ray,CloudFlare Warp解锁GPT
        • 使用vscode进行java开发
        • 利用zx和SSHKey发布代码到服务器
        • 反爬虫一些方案总结和尝试
        • 安装1Panel
        • 安装Bt面板
        • 安装Ubuntu22.04后要做的事
        • 无显示器linux设置默认分辨率
        • 特别实用的shell命令
        • 解决linux安装xmind缺少依赖报错
      • Standards
        • CSS格式化之stylelint
        • CSS规范
        • HTML规范
        • JS规范
        • commit规范
        • 使用husky+commitlint规范代码提交
        • 使用semantic-release自动管理版本号
        • 命名规范
        • 图片规范
        • 版本编号规范
      • Wall
        • 科学上网-Cloudflare-Pages
        • 科学上网-Cloudflare-Warp
        • 科学上网-Geph
        • 科学上网-RackNerd
        • 科学上网-Slicehosting
        • 科学上网-Surfshark
        • 科学上网-Tor
        • 科学上网-XX-NET
        • 科学上网-heroku
        • 科学上网-shadowsock
        • 科学上网-v2ray使用
        • 科学上网-v2ray搭建
        • 科学上网-浏览器代理
        • 科学上网-让终端走代理
      • Windows
        • SourceTree破解免登录(windows版)
        • git bash交互提示符不工作
        • nexus 7 2013 wifi 刷机
        • tree命令生成文件目录
        • 利用charles抓包app
        • 安装Openssl
        • 安装msi文件报错2503和2502
        • 神器vimium使用说明
        • 自用host
        • 解决win10扩展出来的屏幕模糊
        • 解决安装Adobe Air时发生错误
    • Snippets
      • zsh
        • docker
        • extract
        • git-commit
        • git
        • mysql-macports
        • npm
        • nvm
        • pip
        • pm2
        • systemd
        • ubuntu
        • vscode
Powered by GitBook
On this page
  • 背景
  • 代码规范
  • 注释规范
  • 文件模板
  • 参考

Was this helpful?

  1. Docs
  2. Articles
  3. Standards

HTML规范

背景

参考凹凸实验室的规范,整理提炼出适合当前团队使用的前端规范. 旨在增强团队开发协作,提高代码质量和打造开发基石的编码规范.

代码规范

  1. DOCTYPE 声明

    ::: tip DOCTYPE HTML 文件必须加上 DOCTYPE 声明,并统一使用 HTML5 的文档声明: :::

    <!DOCTYPE html>
  2. LANG 页面语言

    ::: tip LANG 推荐使用属性值 cmn-Hans-CN(简体, 中国大陆),但是考虑浏览器和操作系统的兼容性,目前仍然使用 zh-CN 属性值 :::

    <html lang="zh-CN">
  3. CHAESET

    ::: tip CHAESET HTML-5 中默认的字符编码是 UTF-8 请尽量统一写成标准的 UTF-8 ,不要写成 utf-8 或 utf8 或 UTF8。根据 IETF 对UTF-8 的定义,其编码标准的写法是 UTF-8 ;而 UTF8 或 utf8 的写法只是出现在某些编程系统中,如 .NET framework 的类 System.Text.Encoding 中的一个属性名就叫 UTF8 :::

    <meta charset="UTF-8">
  4. 元素及标签闭合

    HTML 元素有5种: ::: info 空元素 area 、base 、br 、col 、command 、embed 、hr 、img 、input 、keygen 、link 、meta 、param 、source 、track 、wbr ::: ::: info 原始文本元素 script 、style ::: ::: info RCDATA 元素 textarea 、title ::: ::: info 外来元素 MathML 命名空间和 SVG 命名空间的元素 ::: ::: info 常规元素 常规元素:其他 HTML 允许的元素都称为常规元素 :::

    <!-- 所有具有开始标签和结束标签的元素都要写上起止标签 -->
    <!-- 某些允许省略开始标签或和束标签的元素亦都要写上 -->
    <!-- 空元素标签都不加 “/” 字符 -->
    <div>
      <h1>我是h1标题</h1>
      <p>我是一段文字,我有始有终,浏览器能正确解析</p>
    </div>
    <br>
  5. 书写风格

    <!-- HTML标签名、类名、标签属性和大部分属性值统一用小写 -->
    <div class="demo"></div>
    
    <!-- HTML文本、CDATA、JavaScript、meta标签某些属性等内容可大小写混合 -->
    <!-- 优先使用 IE 最新版本和 Chrome Frame -->
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"/>
    
    <!-- HTML文本内容 -->
    <h1>I AM WHAT I AM </h1>
    
    <!-- JavaScript 内容 -->
    <script type="text/javascript">
      var demoName = 'demoName';
      ...
    </script>
      
    <!-- CDATA 内容 -->
    <script type="text/javascript"><![CDATA[
    ...
    ]]></script>
  6. 类型属性

    <!-- 不需要为 CSS、JS 指定类型属性,HTML5 中默认已包含 -->
    <link rel="stylesheet" href="" >
    <script src=""></script>
  7. 元素属性

    <!-- 元素属性值使用双引号语法 -->
    <input type="text">
    
    <!-- 元素属性值可以写上的都写上 -->
    <input type="radio" name="name" checked="checked" >
  8. 特殊字符引用

    在 HTML 中不能使用小于号 “<” 和大于号 “>”特殊字符,浏览器会将它们作为标签解析,若要正确显示,在 HTML 源代码中使用字符实体

    <a href="#">more&gt;&gt;</a>
  9. 代码缩进

    统一使用四个空格进行代码缩进,使得各编辑器表现一致(各编辑器有相关配置)

    <div class="jdc">
        <a href="#"></a>
    </div>
  10. 纯数字输入框

    <!-- 使用 type="tel" 而不是 type="number" -->
    <input type="tel">
  11. 代码嵌套

    <!-- 元素嵌套规范,每个块状元素独立一行,内联元素可选 -->
    <div>
      <h1></h1>
      <p></p>
    </div>	
    <p><span></span><span></span></p>
    
    <!-- 段落元素与标题元素只能嵌套内联元素 -->
    <h1><span></span></h1>
    <p><span></span><span></span></p>

注释规范

  1. 单行注释

    <!-- 一般用于简单的描述,如某些状态描述、属性描述等 -->
    <!-- 注释内容前后各一个空格字符,注释位于要注释代码的上面,单独占一行 -->
    <!-- Comment Text -->
    <div>...</div>
  2. 模块注释

    <!-- 一般用于描述模块的名称以及模块开始与结束的位置 -->
    <!-- 模块与模块之间相隔一行 -->
    <!-- S Comment Text A -->	
    <div class="mod_a">
      ...
    </div>
    <!-- E Comment Text A -->
      
    <!-- S Comment Text B -->	
    <div class="mod_b">
      ...
    </div>
    <!-- E Comment Text B -->
  3. 嵌套模块注释

    <!-- S Comment Text A -->
    <div class="mod_a">
        
        <div class="mod_b">
            ...
        </div>
        <!-- /mod_b -->
          
        <div class="mod_c">
          ...
        </div>
        <!-- /mod_c -->
        
    </div>
    <!-- E Comment Text A -->

文件模板

  1. HTML5 标准模板

    <!DOCTYPE html>
    <html lang="zh-CN">
    <head>
    <meta charset="UTF-8">
    <title>HTML5标准模版</title>
    </head>
    <body>
      
    </body>
    </html>
  2. 移动端

    <!DOCTYPE html>
    <html lang="zh-CN">
    <head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no, shrink-to-fit=no" >
    <meta name="format-detection" content="telephone=no" >
    <title>移动端HTML模版</title>
      
    <!-- S DNS预解析 -->
    <link rel="dns-prefetch" href="">
    <!-- E DNS预解析 --> 
    
    <!-- S 线上样式页面片,开发请直接取消注释引用 -->
    <!-- #include virtual="" -->
    <!-- E 线上样式页面片 -->
    
    <!-- S 本地调试,根据开发模式选择调试方式,请开发删除 --> 
    <link rel="stylesheet" href="css/index.css" >
    <!-- /本地调试方式 -->
    
    <link rel="stylesheet" href="http://srcPath/index.css" >
    <!-- /开发机调试方式 -->
    <!-- E 本地调试 -->
    
    </head>
    <body>
    
    </body>
    </html>
  3. PC端

    <!DOCTYPE html>
    <html lang="zh-CN">
    <head>
    <meta charset="UTF-8">
    <meta name="keywords" content="your keywords">
    <meta name="description" content="your description">
    <meta name="author" content="author,email address">
    <meta name="robots" content="index,follow">
    <meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1">
    <meta name="renderer" content="ie-stand">
    <title>PC端HTML模版</title>
    
    <!-- S DNS预解析 --> 
    <link rel="dns-prefetch" href="">
    <!-- E DNS预解析 --> 
    
    <!-- S 线上样式页面片,开发请直接取消注释引用 -->
    <!-- #include virtual="" -->
    <!-- E 线上样式页面片 -->
    
    <!-- S 本地调试,根据开发模式选择调试方式,请开发删除 --> 
    <link rel="stylesheet" href="css/index.css" >
    <!-- /本地调试方式 -->
    
    <link rel="stylesheet" href="http://srcPath/index.css" >
    <!-- /开发机调试方式 -->
    <!-- E 本地调试 -->
    
    </head>
    <body>
    
    </body>
    </html>

参考

PreviousCSS规范NextJS规范

Last updated 10 months ago

Was this helpful?

HTML规范
W3C
Apple Developer