✏️
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
  • 代码规范
  • 代码风格
  • 注释规范
  • SASS规范
  • 重置样式
  • 媒体查询
  • 移动端常用私有属性
  • 参考

Was this helpful?

  1. Docs
  2. Articles
  3. Standards

CSS规范

代码规范

  1. 样式文件必须写上 @charset 规则,并且一定要在样式文件的第一行首个字符位置开始写,编码名用 UTF-8

  2. 字符 @charset ""; 都用小写字母,不能出现转义符,编码名允许大小混写

  3. 考虑到在使用 "UTF-8" 编码情况下 BOM 对代码的污染和编码显示的问题,在可控范围下,坚决不使用 BOM。

    @charset "UTF-8";
    
    .jdc{}

代码风格

  1. 代码格式化

    /*推荐使用展开格式*/
    .jdc {
      display: block;
      width: 50px;
    }
  2. 代码大小写

    /*样式选择器,属性名,属性值关键字全部使用小写字母书写,属性字符串允许使用大小写。*/
    .jdc {
      display:block;
    }
  3. 选择器

    /*尽量少用通用选择器*/
    .jdc {}
    
    /*不使用 ID 选择器*/
    .jdc li {}
    
    /*不使用无具体语义定义的标签选择器*/
    .jdc li p{}
  4. 代码缩进

    /*统一使用四个空格进行代码缩进,使得各编辑器表现一致(各编辑器有相关配置)*/
    .jdc {
        width: 100%;
        height: 100%;
    }
  5. 分号

    /*每个属性声明末尾都要加分号;*/
    .jdc {
        width: 100%;
        height: 100%;
    }
  6. 代码易读性

    /*左括号与类名之间一个空格,冒号与属性值之间一个空格*/
    .jdc { 
        width: 100%; 
    }
    
    /*逗号分隔的取值,逗号之后一个空格*/
    .jdc {
        box-shadow: 1px 1px 1px #333, 2px 2px 2px #ccc;
    }
    
    /*为单个css选择器或新申明开启新行*/
    .jdc, 
    .jdc_logo, 
    .jdc_hd {
        color: #ff0;
    }
    .nav{
        color: #fff;
    }
    
    /*颜色值 rgb() rgba() hsl() hsla() rect() 中不需有空格,且取值不要带有不必要的0*/
    .jdc {
        color: rgba(255,255,255,.5);
    }
    
    /*属性值十六进制数值能用简写的尽量用简写*/
    .jdc {
        color: #fff;
    }
    
    /*不要为 0 指明单位*/
    .jdc {
        margin: 0 10px;
    }
  7. 属性值引号

    /*css属性值需要用到引号时,统一使用单引号*/
    .jdc { 
      font-family: 'Hiragino Sans GB';
    }
  8. 属性书写顺序

    ::: tip 布局定位属性 display / position / float / clear / visibility / overflow ::: ::: tip 自身属性 width / height / margin / padding / border / background ::: ::: tip 文本属性 color / font / text-decoration / text-align / vertical-align / white- space / break-word ::: ::: tip 其他属性 content / cursor / border-radius / box-shadow / text-shadow / background:linear-gradient :::

    .jdc {
        display: block;
        position: relative;
        float: left;
        width: 100px;
        height: 100px;
        margin: 0 10px;
        padding: 20px 0;
        font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif;
        color: #333;
        background: rgba(0,0,0,.5);
        -webkit-border-radius: 10px;
        -moz-border-radius: 10px;
        -o-border-radius: 10px;
        -ms-border-radius: 10px;
        border-radius: 10px;
    }
  9. CSS3 浏览器私有前缀写法

    /*CSS3 浏览器私有前缀在前,标准前缀在后*/
    .jdc {
        -webkit-border-radius: 10px;
        -moz-border-radius: 10px;
        -o-border-radius: 10px;
        -ms-border-radius: 10px;
        border-radius: 10px;
    }

注释规范

  1. 单行注释

        # 使用 /*  */ 注释方式
    /* 这是单行注释 */
    .jdc{}
  2. 模块注释

        # /* 注释内容第一个字符和最后一个字符都是一个空格字符 */ 
        # /* 与 模块信息描述占一行,多个横线分隔符-与*/占一行,行与行之间相隔两行
    /* Module A
    ---------------------------------------------------------------- */
    .mod_a {}
    
    
    /* Module B
    ---------------------------------------------------------------- */
    .mod_b {}
  3. 文件信息注释

    /* 在样式文件编码声明 @charset 语句下面注明页面名称、作者、创建日期等信息 */ 
    @charset "UTF-8";
    /**
    * @desc File Info
    * @author Author Name
    * @date 2015-10-10
    */

SASS规范

  1. SASS 注释规范 SASS 支持 CSS 标准的多行注释 /* */,同时也支持单行注释 //

    /* 全部遵循 CSS 注释规范 */ 
    /* 注释内不放 SASS 变量 */ 
    
    @charset "UTF-8";
    
    /**
    * @desc File Info
    * @author liqinuo
    * @date 2015-10-10
    */
    
    /* Module A
    ----------------------------------------------------------------*/
    .mod_a {}
    
    /* module A logo */
    .mod_a_logo {}
    
    /* module A nav */
    .mod_a_nav {}
    
    
    /* Module B
    ----------------------------------------------------------------*/
    .mod_b {}
    
    /* module B logo */
    .mod_b_logo {}
    
    /* module B nav */
    .mod_b_nav {}
  2. 嵌套规范

    ::: code-group

    /* 选择器嵌套 */
    .jdc {}
    body .jdc {}
    .jdc {
        body & {}
    }

    :::

  3. 属性嵌套

    ::: code-group

    .jdc {
        background-color: red;
        background-repeat: no-repeat;
        background-image: url(/img/icon.png);
        background-position: 0 0;
    }
    .jdc {
        background: {
            color: red;
            repeat: no-repeat;
            image: url(/img/icon.png);
            position: 0 0;
        }
    }

    :::

  4. 变量

    ::: code-group

    /* 可复用属性尽量抽离为页面变量,易于统一维护 */
    .jdc {
        color: red;
        border-color: red;
    }
    $color: red;
    .jdc {
        color: $color;
        border-color: $color;
    }

    :::

  5. 混合

    ::: tip @include 根据功能定义模块,然后在需要使用的地方通过 @include 调用,避免编码时重复输入代码段 ::: ::: code-group

    .jdc_1 {
        -webkit-border-radius: 5px;
        border-radius: 5px;
    }
    .jdc_2 {
        -webkit-border-radius: 10px;
        border-radius: 10px;
    }
    @mixin radius($radius:5px) {
        -webkit-border-radius: $radius;
        border-radius: $radius;
    }
    .jdc_1 {
        @include radius; //参数使用默认值
    }
    .jdc_2 {
        @include radius(10px);
    }
    :::
    
    ::: code-group
    ```css [css]
    .jdc_1 {
        background: url(/img/icon.png) no-repeat -10px 0;
    }
    .jdc_2 {
        background: url(/img/icon.png) no-repeat -20px 0;
    }
    @mixin icon($x:0, $y:0) {
        background: url(/img/icon.png) no-repeat $x, $y;
    }
    .jdc_1 {
        @include icon(-10px, 0);
    }
    .jdc_2 {
        @include icon(-20px, 0);
    }
  6. 占位选择器

    ::: tip @extend 如果不调用则不会有任何多余的 css 文件,占位选择器以 % 标识定义,通过 @extend 调用 ::: ::: code-group

    %borderbox {
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
    }
    .jdc {
        @extend %borderbox;
    }

    :::

  7. extend 继承

    ::: code-group

    .jdc_1 {
        font-size: 12px;
        color: red;
    }
    .jdc_2 {
        font-size: 12px;
        color: red;
        font-weight: bold;
    }
    .jdc_1 {
        font-size: 12px;
        color: red;
    }
    .jdc_2 {
        @extend .jdc_1;
        font-weight: bold;
    }
    
    /* 或者 */
    %font_red {
        font-size: 12px;
        color: red;
    }
    .jdc_1 {
        @extend %font_red;
    }
    .jdc_2 {
        @extend %font_red;
        font-weight: bold;
    }
  8. for 循环

    ::: code-group

    .jdc_1 {background-position: 0 -20px;}
    .jdc_2 {background-position: 0 -40px;}
    .jdc_3 {background-position: 0 -60px;}
    @for $i from 1 through 3 {
        .jdc_#{$i} {
            background-position: 0 (-20px) * $i;
        }
    }
  9. each 循环

    ::: code-group

    .jdc_list {
        background-image: url(/img/jdc_list.png);
    }
    .jdc_detail {
        background-image: url(/img/jdc_detail.png);
    }
    @each $name in list, detail {
        .jdc_#{$name} {
            background-image: url(/img/jdc_#{$name}.png);
        }
    }

    :::

    ::: code-group

    .jdc_list {
        background-image: url(/img/jdc_list.png);
        background-color: red;
    }
    .jdc_detail {
        background-image: url(/img/jdc_detail.png);
        background-color: blue;
    }
    @each $name, $color in (list, red), (detail, blue) {
        .jdc_#{$name} {
            background-image: url(/img/jdc_#{$name}.png);
            background-color: $color;
        }
    }
  10. function 函数

    ::: code-group

    @function pxToRem($px) {
        @return $px / 10px * 1rem;
    }
    .jdc {
        font-size: pxToRem(12px);
    }
  11. 运算规范

    ::: code-group

    /* 注意运算单位,单位同时参与运算,所以 10px 不等于 10 */
    .jdc {
        width: 100px - 50px;
        width: 100px + 50px;
        width: 100px * 2;
        width: 100px / 2;
    }

    :::

重置样式

  1. 移动端

    * { -webkit-tap-highlight-color: transparent; outline: 0; margin: 0; padding: 0; vertical-align: baseline; }
    body, h1, h2, h3, h4, h5, h6, hr, p, blockquote, dl, dt, dd, ul, ol, li, pre, form, fieldset, legend, button, input, textarea, th, td { margin: 0; padding: 0; vertical-align: baseline; }
    img { border: 0 none; vertical-align: top; }
    i, em { font-style: normal; }
    ol, ul { list-style: none; }
    input, select, button, h1, h2, h3, h4, h5, h6 { font-size: 100%; font-family: inherit; }
    table { border-collapse: collapse; border-spacing: 0; }
    a { text-decoration: none; color: #666; }
    body { margin: 0 auto; min-width: 320px; max-width: 640px; height: 100%; font-size: 14px; font-family: -apple-system,Helvetica,sans-serif; line-height: 1.5; color: #666; -webkit-text-size-adjust: 100% !important; text-size-adjust: 100% !important; }
    input[type="text"], textarea { -webkit-appearance: none; -moz-appearance: none; appearance: none; }
  2. PC端

    html, body, div, h1, h2, h3, h4, h5, h6, p, dl, dt, dd, ol, ul, li, fieldset, form, label, input, legend, table, caption, tbody, tfoot, thead, tr, th, td, textarea, article, aside, audio, canvas, figure, footer, header, mark, menu, nav, section, time, video { margin: 0; padding: 0; }
    h1, h2, h3, h4, h5, h6 { font-size: 100%; font-weight: normal }
    article, aside, dialog, figure, footer, header, hgroup, nav, section, blockquote { display: block; }
    ul, ol { list-style: none; }
    img { border: 0 none; vertical-align: top; }
    blockquote, q { quotes: none; }
    blockquote:before, blockquote:after, q:before, q:after { content: none; }
    table { border-collapse: collapse; border-spacing: 0; }
    strong, em, i { font-style: normal; font-weight: normal; }
    ins { text-decoration: underline; }
    del { text-decoration: line-through; }
    mark { background: none; }
    input::-ms-clear { display: none !important; }
    body { font: 12px/1.5 \5FAE\8F6F\96C5\9ED1, \5B8B\4F53, "Hiragino Sans GB", STHeiti, "WenQuanYi Micro Hei", "Droid Sans Fallback", SimSun, sans-serif; background: #fff; }
    a { text-decoration: none; color: #333; }
    a:hover { text-decoration: underline; }

媒体查询

  1. 常用查询语句

    /* 判断设备横竖屏 */
    /* 横屏 */
    @media all and (orientation :landscape) {
    
    } 
    
    /* 竖屏 */
    @media all and (orientation :portrait) {
    
    }
    
    /* 判断设备宽高 */
    /* 设备宽度大于 320px 小于 640px */
    @media all and (min-width:320px) and (max-width:640px) {
        
    }
    
    /* 判断设备像素比 */
    /* 设备像素比为 1 */
    @media only screen and (-webkit-min-device-pixel-ratio: 1), only screen and (min-device-pixel-ratio: 1) {
        
    }
    
    /* 设备像素比为 1.5 */
    @media only screen and (-webkit-min-device-pixel-ratio: 1.5), only screen and (min-device-pixel-ratio: 1.5) {
        
    }
    
    /* 设备像素比为 2 */
    @media only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min-device-pixel-ratio: 2) {
        
    }

移动端常用私有属性

/* 隐藏滚动条 */
.scroll::-webkit-scrollbar {
    width: 0;
    height: 0;
} 

参考

PreviousCSS格式化之stylelintNextHTML规范

Last updated 10 months ago

Was this helpful?

CSS规范
W3C
Apple Developer
带BOM的UTF-8和无BOM的UTF-8有什么区别?网页代码一般使用哪个?