HTML与CSS笔记-1

2019-03-19  本文已影响0人  蚂蚁踩死我

HTML

图片语义化

1.alt属性与tittle属性。

2.figure元素与figcaption元素。

<figure>
    <img src="" alt="" title="">
    <figcaption></figcaption>
</figure>

表单分组

fieldset标签、legend标签

<fieldset>
    <legend></legend>
    <input >
</fieldset>
优点:1.增强表单语义
     2.可定义fieldset元素的disabled属性来禁用整个组的表单元素

其他

CSS

CSS单位

CSS特性

CSS优先级

应用方式冲突

行内样式 > (内部样式 = 外部样式)

继承方式冲突

最近的祖元素获胜

指定样式冲突

样式权值高获胜,权值只针对指定样式,不用于继承

继承样式和指定样式冲突

指定样式获胜

!important

会覆盖任何其他样式

CSS选择器

CSS规范

CSS命名规范(适用于开发阶段,发布阶段css文件都合并压缩)

  1. CSS文件命名
    • reset.css重置样式,清除默认样式
    • global.css全局样式,定义公共、基础样式(导航、底部、全局字体、文字颜色)
    • themes.css主题样式
    • module.css模块样式
    • masster.css模板样式,用于母版页的样式
    • columns.css专栏样式
    • forms.css表单样式
    • mend.css补丁样式
    • print.css 打印样式
  2. id和class命名
    • 避免class命名重复,命名取父元素class名为前缀
    • 页面常见部分命名规范

网页主体部分命名

网页部分 命名
最外层 wrapper
头部 header
内容 content
侧栏 sidebar
栏目 column
热点 hot
新闻 news
下载 download
标志 logo
导航条 nav
主体 main
左侧 main-left
右侧 main-right
底部 footer
友情链接 friendlink
加入我们 joinus
版权 copyright
服务 service
登录 login
注册 register

网页细节部分命名

导航命名

网页部分 命名
主导航 main-nav
子导航 sub-nav
边导航 side-nav
左导航 leftside-nav
右导航 rightside-nav
顶导航 top-nav

其他

网页部分 命名
菜单 menu
子菜单 submenu
标题 title
摘要 summary
登录条 loginbar
搜索 search
标签页 tab
广告 banner
小技巧 tips
图标 icon
法律声明 siteinfolegal
网站地图 sitemap
首页 homepage
子页 subpage
合作伙伴 parter
帮助 help
指南 guide
滚动 scroll
提示信息 msg
投票 vote
相关文章 related
文章列表 list

书写规范

CSS属性书写顺序
1.影响文档布局属性 display; position; float; clear; ...
2.自身盒模型属性 width; height; padding; margin; border; overflow; ...
3.文本属性 font; line-height; text-align; text-indent; vertical-align;...
4.装饰属性 color; background-color; opacity; cursor;...
5.其他属性 content; list-style; quotes;...
<!-- 例子 -->

#main {
    /*影响文档流属性*/
    display             : inline-block    ;
    position            : absolute        ;
    top                 : 0               ;
    left                : 0               ;

    /*盒子模型属性*/
    width               : 100px           ;
    height              : 100px           ;
    border              : 1px solid gray  ;

    /*文本属性*/
    font-size           : 15px            ;
    font-weight         : bold            ;
    text-indent         : 2em             ;

    /*装饰属性*/
    color               : #000            ;
    background-color    : #fff            ;

    /*其他属性*/
    cursor              : pointer         ;
}

功能代码

具有某一特殊功能的代码块应该集中放置一起
<!-- 举例 -->
#main {

    /*单行文本居中方法需要使用2个属性实现,就将其写在一起*/
    height              : 50px              ;
    line-height         : 50px              ;

}

注释规范

  1. 顶部注释
/*
    *@sescription:  文件说明
    *@author     :  作者
    *@update     :  更新时间
*/
  1. 模块注释
/*导航部分,开始*/
...
/*导航部分,结束*/
  1. 防止代码压缩删除注释,将需要保留的注释加 ! 符号
/*! 这条注释不会被压缩删掉 */

CSS reset

重置浏览器默认的CSS样式

CSS盒子模型

  1. 内容区
    • width
    • height
    • overflow
  2. 内边距
    • padding-top
    • padding-right
    • padding-bottom
    • padding-left
  3. 边框
    • border-width
    • border-style
    • border-color
  4. 外边距
    • margin-top
    • margin-right
    • margin-bottom
    • margin-left
    • margin可指定负数,盒子向负值相反方向移动

border

border:0border:none差异

padding

margin

外边距叠加

初衷是为了对文章更好排班,第一段外边距显示和其他段落外边距相等。
  1. 同级元素
    • 会发生合并
  2. 父子元素
    • 当父元素没有padding、border把外边距分隔开,父元素和子元素相邻上下外边距会合并
  3. 空元素
    • 自身没有padding、border把外边距分隔开,上下外边距会叠加,再碰到其他元素外边距再次叠加

负margin

  1. margin-top、margin-left为负时,当前元素拉向指定方向
  2. margin-botton、marin-right为负时,后续元素拉向指定方向

负margin使用技巧

<!-- HTML -->

   <div class="content"><p>主体,宽度自适应</p></div>
   <div class="sidebar"><p>侧边栏,固定宽度</p></div>

<!-- CSS  -->
   div{
       float: left;
   }

   .content{
       width: 100%;
       /* 将sidebar向左拉sidebar自身宽度的举例*/
       /*否则sidebar会被content的width百分百挤到下一行 */
       margin-right: -200px;
       background-color: green;
   }
   .content > p{
       /* 防止浏览器宽度不足,两列发生重叠 */
       /* siderbar自身宽度+两列间距10px */
       margin-right: 210px;
   }

   .sidebar{
       width: 200px;
       background-color: red;
   }

overflow

display

inline行内元素

无法定义height、width,
无法定义margin-top、margin-bottom.
不能容纳block块元素

inline-block行内块元素

可定义height、width
可与其他inline行内元素同行

常见inline-block元素

display: none ;

visibility: hidden;的区别

display: table-cell ;

可以让元素以表格单元形式呈现
  1. 大小不固定的图片垂直居中于元素
父元素{
    display: table-cell;
    vertical-align: middle;
    text-align: center;
}
子元素{
    vertical-align: middle;
}
  1. 等高布局
  2. 自动平均划分元素
父元素{display: tabel ;}
子元素{display: table-cell ;}

去除inline-block元素间距

父元素{font-size: 0 ;}
上一篇下一篇

猜你喜欢

热点阅读