前端编码规范 浅析

作者: passMaker | 来源:发表于2018-07-08 15:25 被阅读2次

命名技巧

语义化

  1. 语义化标签优先
  2. 基于功能命名、基于内容命名、基于表现命名
  3. 简略、明了、无后患

tips:

  1. 大声叫出它的名字
  2. 翻译成英文

范例

<!-- 不好  -->
<div class="article">
  <div class="article_title">编码规范</div>
  <div class="the_content">今天讲的内容是编码规范
     <div class="darkbold">evenyao</div> @evenyao </div>
</div>

<!-- 好 -->
<article>
  <h1>编码规范</h1>
  <p>今天讲的内容是编码规范
     <b>evenyao</b> @evenyao</p>
</article>

范例

<!-- 不好  -->
<div class="left"></div>
<div class="red"></div>
<div class="s"></div>
<a class="link" href="#"></a>

<!-- 好 -->
<div class="success"></div>
<div class="theme-color"></div>
<a class="login" href="#"></a>

范例

<!-- 好 -->
<article class="movies">...</article>
<article class="news">...</article>

<!-- 不好 -->
<article class="blue">...</article>
<article class="redBg mt30 bigText">...</article>

命名范例

1.所有命名都使用英文小写

推荐:`<div class="main"></div> `

不推荐: `<div class="Main"></div> `

2.命名用引号包裹

推荐:`<div id="header"></div> `

不推荐: `<div id=header></div> `

3.用中横线连接

推荐:`<div class="mod-modal"></div> `

不推荐: `<div class="modModal"></div> `

4.命名体现功能,不涉及表现样式(颜色、字体、边框、背景等)

推荐:`<div class="text-lesser"></div>`

不推荐: `<div class="light-grey"></div>`

常见命名1

  1. .wrap.wrapper -- 用于外侧包裹
  2. .container.ct -- 包裹容器
  3. .header -- 用于头部
  4. .body -- 页面 body
  5. .footer -- 页面尾部
  6. asidesidebar -- 用于侧边栏
  7. .content -- 和header footer 对应,用于主要内容
  8. .navigation -- 导航元素
  9. .pagination -- 分页

常见命名2

  1. .tabs > .tab -- tab 切换
  2. .breadcrumbs -- 导航列表、面包屑
  3. .dropdown -- 下拉菜单
  4. .article -- 文章
  5. .main -- 用于主体
  6. .thumbnail -- 头像,小图像
  7. .media -- 媒体资源
  8. .panel -- 面板
  9. .tooltip -- 鼠标放置上去的提示
  10. .popup -- 鼠标点击弹出的提示

常见命名3

  1. .button.btn -- 按钮
  2. .ad -- 广告
  3. .subnav -- 二级导航
  4. .menu -- 菜单
  5. .tag -- 标签
  6. .message或者.notice -- 提示消息
  7. .summary -- 摘要
  8. .logo -- logo
  9. .search -- 搜索框
  10. .login -- 登录

常见命名4

  1. .register -- 注册
  2. .username -- 用户名
  3. .password -- 密码
  4. .banner -- 广告条
  5. .copyright -- 版权
  6. .modal或者 .dialog -- 弹窗

常见命名5

var 名字 = {
  状态: [
    'inverse',
    'toggled',
    'switched',
    'original',
    'initial',
    'identified',
    'disabled',
    'loading',
    'pending',
    'syncing',
    'default'
  ],
  修饰: [
    'dark',
    'light',
    'shaded',
    'flat',
    'ghost',
    'maroon',
    'pale',
    'intense',
    'twisted',
    'narrow',
    'wide',
    'smooth',
    'separate',
    'clean',
    'sharp',
    'aligned'
  ],
  元素: [
    'pagination',
    'modal',
    'popup',
    'article',
    'story',
    'flash',
    'status',
    'state',
    'media',
    'block',
    'card',
    'teaser',
    'badge',
    'label',
    'sheet',
    'poster',
    'notice',
    'record',
    'entry',
    'item',
    'figure',
    'square',
    'module',
    'bar',
    'button',
    'action',
    'knob'
  ],
  布局: [
    'navigation',
    'wrapper',
    'inner',
    'header',
    'footer',
    'aside',
    'section',
    'divider',
    'content',
    'container',
    'panel',
    'pane',
    'construct',
    'composition',
    'spacing',
    'frame'
  ]
}

CSS规范

书写规范

  1. tab 用两个空格表示
  2. css的 :后加个空格, {前加个空格
  3. 每条声明后都加上分号
  4. 换行,而不是放到一行
  5. 颜色用小写,用缩写, #fff
  6. 小数不用写前缀, 0.5s -> .5s;0不用加单位
  7. 尽量缩写, margin: 5px 10px 5px 10px -> margin: 5px 10px

范例

/* Not recommended */
.test {
  display: block;
  height: 100px
}
/* Recommended */
.test {
  display: block;
  height: 100px;
}

/* Not recommended */
h3 {
  font-weight:bold;
}
/* Recommended */
h3 {
  font-weight: bold;
}

/* Not recommended: missing space */
#video{
  margin-top: 1em;
}

/* Not recommended: unnecessary line break */
#video
{
  margin-top: 1em;
}
/* Recommended */
#video {
  margin-top: 1em;
}

/* Not recommended */
a:focus, a:active {
  position: relative; top: 1px;
}
/* Recommended */
h1,
h2,
h3 {
  font-weight: normal;
  line-height: 1.2;
}

/* Always put a blank line (two line breaks) between rules. */
html {
  background: #fff;
}

body {
  margin: auto;
  width: 50%;
}

/* Not recommended */
@import url("//www.google.com/css/maia.css");

html {
  font-family: "open sans", arial, sans-serif;
}
/* Recommended */
@import url(//www.google.com/css/maia.css);

html {
  font-family: 'open sans', arial, sans-serif;
}

参考

相关文章

  • 前端编码规范 浅析

    命名技巧 语义化 语义化标签优先基于功能命名、基于内容命名、基于表现命名简略、明了、无后患 tips: 大声叫出它...

  • 前端开发规范(实验室版)

    前端编码规范—— HTML 篇 前端编码规范—— CSS 篇 前端编码规范—— JavaScript 篇 这几天和...

  • 雷铭大前端组件库

    雷铭大前端组件库 包含《雷铭前端开发规范》、《雷铭Android编码规范》、《雷铭iOS编码规范》以及不同技术分类...

  • 前端编码规范

    前端编码规范参考链接 go!!

  • Eslint搭建及使用

    内容 本文将讲解如何在 VSCode 中配合 ESLint 扩展来实践团队内部的前端编码规范。 前端编码规范 ES...

  • 无标题文章

    # CSS 编码规范 此为前端开发团队遵循和约定的 CSS 编码规范,意在提高代码的规范性和可维护性。 ## 代码...

  • 前端编码规范

    一、命名技巧 1、语义化 即合适标签+合适命名 (1)语义化标签优先 (2)基于功能命名、内容命名、表现命名 (3...

  • 前端编码规范

    英文单词保证拼写正确。 尽量不使用中文拼音; 重要常量、变量、方法等保证详细注释,关键业务逻辑进行详细记录; 变量...

  • 前端编码规范

    CSS编码规范 1 前言 2 代码风格 2.1 文件 2.2 缩进 2.3 空格 2.4 行长度 2.5 选择器 ...

  • 前端编码规范

    很久没有更新文章了。。。实在是比较忙啊。。。从本身一个iOS开发,现在要兼顾前端、产品、维护等,每天都有不同的事,...

网友评论

    本文标题:前端编码规范 浅析

    本文链接:https://www.haomeiwen.com/subject/ffyouftx.html