CSS基础汇总——点击标题跳转详细博客【学习笔记】

CSS 网页的美容师
理想中的结果: 结构(html)与样式(css)相分离

1.引入CSS样式表(书写位置)

  • 行内式(内联样式) :
<标签名 style="属性1:属性值1; 属性2:属性值2; 属性3:属性值3;"> 内容 标签名>
  • 内部样式表(内嵌样式表):
<head>
<style type="text/CSS">
   选择器(选择的标签) {
       
     属性1: 属性值1;
     属性2: 属性值2; 
     属性3: 属性值3;
   }
style>
head>
  • 外部样式表(外链式):
<head>
 <link rel="stylesheet" type="text/css" href="css文件路径">
head>

2.CSS样式规则

CSS基础汇总——点击标题跳转详细博客【学习笔记】_第1张图片

3.css基础选择器

选择器 作用 缺点 使用情况 用法
标签选择器 可以选出所有相同的标签,比如p 不能差异化选择 较多 p { color:red;}
类选择器 可以选出1个或者多个标签 可以根据需求选择 非常多 .nav { color: red; }
id选择器 一次只能选择器1个标签 只能使用一次 不推荐使用 #nav {color: red;}
通配符选择器 选择所有的标签 选择的太多,有部分不需要 不推荐使用 * {color: red;}

4.CSS字体样式属性

font:

属性 表示 注意点 用法
font-size 字号 我们通常用的单位是px 像素,一定要跟上单位 font-size:20px;
font-family 字体 实际工作中按照团队约定来写字体 font-family: Arial,“Microsoft Yahei”, “微软雅黑”;
font-weight 字体粗细 记住加粗是 700 或者 bold 不加粗 是 normal 或者 400 记住数字不要跟单位 font-weight=400;
font-style 字体样式 记住倾斜是 italic 不倾斜 是 normal 工作中我们最常用 normal font-style=" italic";
font 字体连写 1. 字体连写是有顺序的 不能随意换位置 2. 其中字号 和 字体 必须同时出现 font: italic 700 16px “微软雅黑”;

字体外观属性:

属性 表示 注意点
color 颜色 我们通常用 十六进制 比如 而且是简写形式 #fff
line-height 行高 控制行与行之间的距离
text-align 水平对齐 可以设定文字水平的对齐方式
text-indent 首行缩进 通常我们用于段落首行缩进2个字的距离 text-indent: 2em;
text-decoration 文本修饰 记住 添加 下划线 underline 取消下划线 none

5.CSS 列表和表单

表格是用来显示数据的,列表是用来布局的。
列表:

标签名 定义 说明
    无序标签 里面只能包含li 没有顺序,我们以后布局中最常用的列表
      有序标签 里面只能包含li 有顺序, 使用情况较少
      自定义列表 里面有2个兄弟, dt 和 dd

      表单:

      • input控件
      属性 说明 作用
      type 表单类型 用来指定不同的控件类型
      value 表单值 表单里面默认显示的文本
      name 表单名字 页面中的表单很多,name主要作用就是用于区别不同的表单。
      checked 默认选中 表示那个单选或者复选按钮一开始就被选中了

      input常用属性:

      CSS基础汇总——点击标题跳转详细博客【学习笔记】_第2张图片
      h5新增的表单属性placeholder也很常用,显示用户提示文字。

      • label标签

      label标签绑定元素:

      1. 第一种用法就是用label直接包括input表单。
      <label> 用户名: <input type="radio" name="usename" value="请输入用户名">   label>
      

      适合单个表单选择

      1. 第二种用法 for 属性规定 label 与哪个表单元素绑定。
      <label for="sex">label>
      <input type="radio" name="sex"  id="sex">
      
      • textarea控件(多行文本输入框)
      <textarea >
        文本内容
      textarea>
      
      • select下拉列表
      <select>
        <option>选项1option>
        <option>选项2option>
        <option>选项3option>
        ...
      select>
      
      • form表单域
        常用属性:
      属性 属性值 作用
      action url地址 用于指定接收并处理表单数据的服务器程序的url地址。
      method get/post 用于设置表单数据的提交方式,其取值为get或post。
      name 名称 用于指定表单的名称,以区分同一个页面中的多个表单。
      • fieldset表单字段集

      标签可以将表单内的相关元素分组。

      标签会在相关表单元素周围绘制边框。

      标签为

      元素定义标题

      
      <fieldset style="border: 1px solid #01567F">
          <legend style="font-size: 15px; font-family: 黑体; color: #0A467E; margin-left: 15px;">用户信息legend>
          <div>用户名称:<input type="text">div>
          <div>用户密码:<input type="password">div>
      fieldset>
      

      6.CSS复合选择器

      选择器 作用 特征 使用情况 隔开符号及用法
      后代选择器 用来选择元素后代 是选择所有的子孙后代 较多 符号是空格 .nav a
      子代选择器 选择 最近一级元素 只选亲儿子 较少 符号是**>** .nav>p
      交集选择器 选择两个标签交集的部分 既是 又是 较少 没有符号 p.one
      并集选择器 选择某些相同样式的选择器 可以用于集体声明 较多 符号是逗号 .nav, .header
      链接伪类选择器 给链接更改状态 较多 重点记住 a{} 和 a:hover 实际开发的写法

      7.标签显示模式(display)

      • 块转行内:display:inline;
      • 行内转块:display:block;
      • 块、行内元素转换为行内块: display: inline-block;
      元素模式 元素排列 设置样式 默认宽度 包含
      块级元素 一行只能放一个块级元素 可以设置宽度高度 容器的100% 容器级可以包含任何标签
      行内元素 一行可以放多个行内元素 不可以直接设置宽度高度 它本身内容的宽度 容纳文本或则其他行内元素
      行内块元素 一行放多个行内块元素 可以设置宽度和高度 它本身内容的宽度

      8.CSS 背景(background)

      属性 作用
      background-color 背景颜色 预定义的颜色值/十六进制/RGB代码
      background-image 背景图片 url(图片路径)
      background-repeat 是否平铺 repeat/no-repeat/repeat-x/repeat-y
      background-position 背景位置 length/position 分别是x 和 y坐标, 切记 如果有 精确数值单位,则必须按照先X 后Y 的写法
      background-attachment 背景固定还是滚动 scroll/fixed
      背景简写 更简单 背景颜色 背景图片地址 背景平铺 背景滚动 背景位置; 他们没有顺序
      背景透明 让盒子半透明 background: rgba(0,0,0,0.3); 后面必须是 4个值

      9.CSS三大特性

      • CSS层叠性

      • CSS继承性

      • CSS优先级

        • 权重计算公式
      标签选择器 计算权重公式
      继承或者 * 0,0,0,0
      每个元素(标签选择器) 0,0,0,1
      每个类,伪类 0,0,1,0
      每个ID 0,1,0,0
      每个行内样式 style="" 1,0,0,0
      每个!important 重要的 ∞ 无穷大

      10.CSS盒子模型

      标准盒子模型

      CSS基础汇总——点击标题跳转详细博客【学习笔记】_第3张图片

      1. 盒子边框(border)

      CSS基础汇总——点击标题跳转详细博客【学习笔记】_第4张图片

      • 语法:
      border : border-width || border-style || border-color 
      
      属性 作用
      border-width 定义边框粗细,单位是px
      border-style 边框的样式
      border-color 边框颜色
      • 边框的样式:
      • none:没有边框即忽略所有边框的宽度(默认值)
      • solid:边框为单实线(最为常用的)
      • dashed:边框为虚线
      • dotted:边框为点线

      表格的细线边框

      通过表格的cellspacing="0",将单元格与单元格之间的距离设置为0,

      • 但是两个单元格之间的边框会出现重叠,从而使边框变粗

      • 通过css属性:

        table{ border-collapse:collapse; }  
        
        • collapse 单词是合并的意思
        • border-collapse:collapse; 表示相邻边框合并在一起。

      圆角边框(CSS3)
      在这里插入图片描述

      • 语法:
      border-radius:length;  
      
      • 其中每一个值可以为 数值或百分比的形式。

      盒子阴影(CSS3)

      在这里插入图片描述

      • 语法:
      box-shadow:水平阴影 垂直阴影 模糊距离(虚实)  阴影尺寸(影子大小)  阴影颜色  内/外阴影;
      

      CSS基础汇总——点击标题跳转详细博客【学习笔记】_第5张图片

      • 前两个属性是必须写的。其余的可以省略。
      • 外阴影 (outset) 是默认的 但是不能写 想要内阴影可以写 inset
      2. 内边距(padding)

      CSS基础汇总——点击标题跳转详细博客【学习笔记】_第6张图片

      属性 作用
      padding-left 左内边距
      padding-right 右内边距
      padding-top 上内边距
      padding-bottom 下内边距

      当我们给盒子指定padding值之后, 发生了2件事情:

      1. 内容和边框 有了距离,添加了内边距。
      2. 盒子会变大了。

      padding简写:

      值的个数 表达意思
      1个值 padding:上下左右内边距;
      2个值 padding: 上下内边距 左右内边距 ;
      3个值 padding:上内边距 左右内边距 下内边距;
      4个值 padding: 上内边距 右内边距 下内边距 左内边距 ;
      • 盒子的实际的大小 = 内容的宽度和高度 + 内边距 + 边框

      内边距产生的问题

      • 问题:会撑大原来的盒子
      • 解决:通过给设置了宽高的盒子,减去相应的内边距的值,维持盒子原有的大小

      padding不影响盒子大小情况

      如果没有给一个盒子指定宽度, 此时,如果给这个盒子指定padding, 则不会撑开盒子。

      3. 外边距(margin)

      CSS基础汇总——点击标题跳转详细博客【学习笔记】_第7张图片

      属性 作用
      margin-left 左外边距
      margin-right 右外边距
      margin-top 上外边距
      margin-bottom 下外边距

      margin值的简写 (复合写法)代表意思 跟 padding 完全相同。

      块级盒子水平居中

      • margin-left: auto; margin-right: auto;
      • margin: auto;
      • margin: 0 auto;

      清除元素的默认内外边距

       * {
           
         padding:0;         /* 清除内边距 */
         margin:0;          /* 清除外边距 */
      }
      

      外边距合并

      • 相邻块元素垂直外边距的合并:

      CSS基础汇总——点击标题跳转详细博客【学习笔记】_第8张图片

      解决方案:尽量给只给一个盒子添加margin值

      • 嵌套块元素垂直外边距的合并(塌陷)

      CSS基础汇总——点击标题跳转详细博客【学习笔记】_第9张图片

      解决方案:

      1. 可以为父元素定义上边框。
      2. 可以为父元素定义上内边距
      3. 可以为父元素添加overflow:hidden。

      还有其他方法,比如浮动、固定、绝对定位的盒子不会有问题

      盒子模型布局稳定性: width > padding > margin

      • margin 会有外边距合并 还有 ie6下面margin 加倍的bug(讨厌)所以最后使用。
      • padding 会影响盒子大小, 需要进行加减计算(麻烦) 其次使用。
      • width 没有问题,经常使用宽度剩余法 高度剩余法来做。

      11.浮动(float)

      • 让盒子从普通流中起来,主要作用让多个块级盒子一行显示。
      1. 脱离标准普通流的控制
      2. 移动到指定位置。
      选择器 { float: 属性值; }
      
      属性值 描述
      none 元素不浮动(默认值
      left 元素向浮动
      right 元素向浮动

      浮动口诀
      float ----- 浮 漏 特

      特点 说明
      加了浮动的盒子是浮起来的,漂浮在其他标准流盒子的上面。
      加了浮动的盒子是不占位置的,它原来的位置漏给了标准流的盒子
      特别注意:浮动元素会改变display属性, 类似转换为了行内块,但是元素之间没有空白缝隙

      1). 浮动元素与父盒子的关系

      • 子盒子的浮动参照父盒子对齐
      • 不会与父盒子的边框重叠,也不会超过父盒子的内边距

      2). 浮动元素与兄弟盒子的关系

      在一个父级盒子中,如果前一个兄弟盒子是:

      • 浮动的,那么当前盒子会与前一个盒子的顶部对齐;
      • 普通流的,那么当前盒子会显示在前一个兄弟盒子的下方。

      浮动只会影响当前的或者是后面的标准流盒子,不会影响前面的标准流。

      清除浮动

      什么时候用清除浮动呢?

      1. 父级没高度
      2. 子盒子浮动了
      3. 影响下面布局了,我们就应该清除浮动了。
      清除浮动的方式 优点 缺点
      额外标签法(隔墙法) 通俗易懂,书写方便 添加许多无意义的标签,结构化较差。
      父级overflow:hidden; 书写简单 溢出隐藏
      父级after伪元素 结构语义化正确 由于IE6-7不支持:after,兼容性问题
      父级双伪元素 结构语义化正确 由于IE6-7不支持:after,兼容性问题

      12.定位(position)

      在 CSS 中,通过 position 属性定义元素的定位模式,语法如下:

      选择器 {
            position: 属性值; }
      

      定位模式是有不同分类的,在不同情况下,我们用到不同的定位模式。

      语义
      static 静态定位
      relative 相对定位
      absolute 绝对定位
      fixed 固定定位

      在 CSS 中,通过 topbottomleftright 属性定义元素的边偏移:(方位名词)

      边偏移属性 示例 描述
      top top: 80px 顶端偏移量,定义元素相对于其父元素上边线的距离
      bottom bottom: 80px 底部偏移量,定义元素相对于其父元素下边线的距离
      left left: 80px 左侧偏移量,定义元素相对于其父元素左边线的距离
      right right: 80px 右侧偏移量,定义元素相对于其父元素右边线的距离
      定位模式 是否脱标占有位置 移动位置基准 模式转换(行内块) 使用情况
      静态static 不脱标,正常模式 正常模式 不能 几乎不用
      相对定位relative 不脱标,占有位置 相对自身位置移动 不能 基本单独使用
      绝对定位absolute 完全脱标,不占有位置 相对于定位父级移动位置 要和定位父级元素搭配使用
      固定定位fixed 完全脱标,不占有位置 相对于浏览器移动位置 单独使用,不需要父级

      定位改变display属性:

      display 是 显示模式, 可以改变显示模式有以下方式:

      • 可以用inline-block 转换为行内块
      • 可以用浮动 float 默认转换为行内块(类似,并不完全一样,因为浮动是脱标的)
      • 绝对定位和固定定位也和浮动类似, 默认转换的特性 转换为行内块。

      所以说, 一个行内的盒子,如果加了浮动固定定位绝对定位,不用转换,就可以给这个盒子直接设置宽度和高度等。

      13.CSS高级技巧

      13.1 显示与隐藏

      属性 区别 用途
      display 隐藏对象,不保留位置 配合后面js做特效,比如下拉菜单,原先没有,鼠标经过,显示下拉菜单, 应用极为广泛
      visibility 隐藏对象,保留位置 使用较少
      overflow 只是隐藏超出大小的部分 1. 可以清除浮动 2. 保证盒子里面的内容不会超出该盒子范围

      display:隐藏之后,不再保留位置

      display: none 隐藏对象
      
      display:block 除了转换为块级元素之外,同时还有显示元素的意思。
      

      CSS基础汇总——点击标题跳转详细博客【学习笔记】_第10张图片
      visibility:隐藏之后,继续保留原有位置。

      visibility:visible ;  对象可视
      
      visibility:hidden;    对象隐藏
      

      CSS基础汇总——点击标题跳转详细博客【学习笔记】_第11张图片
      overflow:

      属性值 描述
      visible 不剪切内容也不添加滚动条
      hidden 不显示超过对象尺寸的内容,超出的部分隐藏掉
      scroll 不管超出内容否,总是显示滚动条
      auto 超出自动显示滚动条,不超出不显示滚动条

      13.2 用户界面样式

      属性 用途 用途
      鼠标样式 更改鼠标样式cursor 样式很多,重点记住 pointer
      轮廓线 表单默认outline outline 轮廓线,我们一般直接去掉,border是边框,我们会经常用
      防止拖拽 主要针对文本域resize 防止用户随意拖拽文本域,造成页面布局混乱,我们resize:none

      鼠标样式:

      属性值 描述
      default 小白 默认
      pointer 小手
      move 移动
      text 文本
      not-allowed 禁止

      轮廓线 outline:

       outline : outline-color ||outline-style || outline-width 
      

      防止拖拽文本域resize:

      <textarea  style="resize: none;">textarea>
      

      13.3 vertical-align对齐

      (1)水平居中对齐

      • 有宽度的块级元素居中对齐,是margin: 0 auto;
      • 让文字居中对齐,是 text-align: center;

      (2)vertical-align 垂直

      vertical-align 垂直对齐,它只针对于行内元素或者行内块元素

      vertical-align : baseline |top |middle |bottom 
      

      图片、表单和文字对齐: 默认的图片会和文字基线对齐
      CSS基础汇总——点击标题跳转详细博客【学习笔记】_第12张图片

      (3)去除图片底侧空白缝隙
      CSS基础汇总——点击标题跳转详细博客【学习笔记】_第13张图片
      解决的方法就是:

      • 给img vertical-align:middle | top| bottom等等。 让图片不要和基线对齐。
      • 给img 添加 display:block; 转换为块级元素就不会存在问题了。

      13.4 溢出的文字省略号显示

      首先强制一行内显示,再次和overflow属性 搭配使用

       /*1. 先强制一行内显示文本*/
           white-space: nowrap;
       /*2. 超出的部分隐藏*/
           overflow: hidden;
       /*3. 文字用省略号替代超出的部分*/
           text-overflow: ellipsis;
      

      13.5 CSS精灵技术(sprite)

      CSS 精灵其实是将网页中的一些背景图像整合到一张大图中(精灵图),然而,各个网页元素通常只需要精灵图中不同位置的某个小图,要想精确定位到精灵图中的某个小图。

      CSS基础汇总——点击标题跳转详细博客【学习笔记】_第14张图片

      这样,当用户访问该页面时,只需向服务发送一次请求,网页中的背景图像即可全部展示出来。

      我们需要使用CSS的

      • background-image、
      • background-repeat
      • background-position属性进行背景定位,
      • 其中最关键的是使用background-position 属性精确地定位。

      13.6. 滑动门

      核心技术就是利用CSS精灵(主要是背景位置)和 盒子padding撑开宽度, 以便能适应不同字数的导航栏。

      一般的经典布局都是这样的:

      <li>
        <a href="#">
          <span>导航栏内容span>
        a>
      li>
      
      

      css样式

      * {
           
            padding:0;
            margin:0;
      
          }
          body{
           
            background: url(images/wx.jpg) repeat-x;
          }
          .father {
           
            padding-top:20px;
          }
          li {
           
            padding-left: 16px;
            height: 33px;
            float: left;
            line-height: 33px;
            margin:0  10px;
            background: url(./images/to.png) no-repeat left ;
          }
          a {
           
            padding-right: 16px;
            height: 33px;
            display: inline-block;
            color:#fff;
            background: url(./images/to.png) no-repeat right ;
            text-decoration: none;
          }
          li:hover,
           li:hover a {
           
            background-image:url(./images/ao.png);
          }
      
      

      ao.png:
      在这里插入图片描述
      to.png:
      在这里插入图片描述

      总结:

      1. a 设置 背景左侧,padding撑开合适宽度。
      2. span 设置背景右侧, padding撑开合适宽度 剩下由文字继续撑开宽度。
      3. 之所以a包含span就是因为 整个导航都是可以点击的。

      13.7 margin负值之美

      1). 负边距+定位:水平垂直居中

      一个绝对定位的盒子, 利用 父级盒子的 50%, 然后 往左(上) 走 自己宽度的一半 ,可以实现盒子水平垂直居中。

      2). 压住盒子相邻边框

      CSS基础汇总——点击标题跳转详细博客【学习笔记】_第15张图片

      13.8 CSS三角形之美

       div {
           
       	width: 0; 
          height: 0;
          line-height:0;
          font-size: 0;
      	border-top: 10px solid red;
      	border-right: 10px solid green;
      	border-bottom: 10px solid blue;
      	border-left: 10px solid #000; 
       }
      
      1. 我们用css 边框可以模拟三角效果
      2. 宽度高度为0
      3. 我们4个边框都要写, 只保留需要的边框颜色,其余的不能省略,都改为 transparent 透明就好了
      4. 为了照顾兼容性 低版本的浏览器,加上 font-size: 0; line-height: 0;

      你可能感兴趣的:(#,前端,javaweb,css)