zoukankan      html  css  js  c++  java
  • HTML与CSS学习笔记(5)

    1、文字阴影?(针对文字)
    text-shadow:
    例如 text-shadow: 10px 10px 10px blue;四个值分别是 x y blur color
    blur表示模糊值,越大越模糊

    注:阴影的默认颜色是跟文字的颜色相同;通过逗号的方式进行分割,可以设置多阴影
    

    2、box-shadow:盒子阴影(针对容器)
    x
    y
    blur
    color
    inset
    多阴影
    例如: box-shadow: 10px 10px 10px 30px blue inset; 前面三个属性依次是x y blur,30px表示:容器周围模糊的扩散范围;inset表示内阴影,默认情况为外阴影

    注:盒子阴影默认颜色是黑色。默认就是外阴影,如果设置outset不起作用,可选的值只有inset:内阴影;同样可以设置多阴影,用逗号隔开
    

    3、mask遮罩
    属性值:url
    repeat
    x
    y
    w
    h
    多遮罩
    注:mask目前还没有标准化,需要添加浏览器前缀;默认是x y 都平铺

    4、倒影
    box-reflect(也没有标准,要加浏览器前缀)
    above:表示上面的方向
    below:表示下面的方向
    left:左边
    right:右边
    距离
    遮罩|渐变
    注:渐变:只是针对透明度的渐变不支持颜色的渐变
    scaleX(-1);scale()取不同轴的负值可以达到图片翻转的效果

    5、模糊与计算
    blur
    filter:blur()

    calc:可以实现百分比与像素的计算
    例如:calc(100% - 100px);无理父容器多大,该子容器始终保持与父容器右边框相差100px距离
        四则运算
    

    6、分栏布局
    column-count:分栏的个数;与column-width冲突只能设置一个
    column-width:分栏的宽度
    column-gap:分栏的间距
    column-rule:分栏的边线
    column-span:合并分栏,比如标题

    7、伪类与伪元素
    在css2.1中对伪类和伪元素的区别比较模糊,css3中对这两个概念做了比较清晰的解释,并且在语法上也做了很明显的区分。
    css3中规定伪类由一个冒号开始,然后为伪类的名称;伪元素由两个冒号开始,然后是伪元素的名称、

    伪类本质上是为了弥补常规css选择器的不足,以便获取到更多的信息。通常表示获取不存在于DOM树中的信息,或获取不能被常规css选择器获取的信息:
        :hover
        :focus
        :empty
        ...
    
    伪元素本质上是创建了一个有内容的虚拟容器,并对该虚拟容器添加样式。这个容器不包含任何DOM元素,但是可以包含内容,另外,开发者还可以为伪元素定制样式。
        ::selection
        ::first-line/first-letter
        ::before/after:往容器里面添加行内元素,并且可以修改行内元素的样式,故为伪元素
        ...
    *伪类和伪元素的区别:
        伪类是为了弥补css选择器的不足,添加的样式是在实际容器上:
         /* 该背景属性通过伪类hover添加到box上去了,弥补了box选择器的不足 */
         .box:hover{background: red;} 
    
        伪类元素则是虚拟一个有内容的容器,并对该容器添加样式:
        为box容器中被选中的内容添加样式,这里被选中的内容即为一个虚拟的容器
         .box::selection{background: red;color: yellow;}
    

    8、css Hack(了解)
    CSS Hack用来解决浏览器的兼容性问题,为不同版本的浏览器定制编写不同的CSS效果,使用每个浏览器单独识别的样式代码,控制浏览器的显示样式。
    Hack分类:
    1、CSS属性前缀法
    是在CSS样式属性名前加上一些只有特定浏览器才能识别的hack前缀,以达到预期的页面展示效果。
    前缀标识 兼容浏览器
    _ IE6
    +、* IE6、IE7
    9 IE6~IE9
    IE8~IE11

            2、选择器前缀法
                是针对一些页面表现不一致或者需要特殊对待的浏览器,在CSS选择器前加上一些只有某些特定浏览器才能识别的前缀进行hack。
                 前缀标识                兼容浏览器
                  *html                    IE6
                  *+html                   IE7
                  :root                IE9以上及现代浏览器
            3、IE条件注释法
                这是一种IE浏览器转悠的Hack写法,微软官方推荐使用的hack方式
                 前缀标识                兼容浏览器
      <!--[if IE]>...<![endif]-->           IE
      <!--[if IE 7]>...<![endif]-->         IE7
      <!--[if lte IE]>...<![endif]-->       IE7以下
      <!--[if ! IE 7]>...<![endif]-->       非IE7
    
        注:IE10以上已经不支持注释法了(了解即可)
    

    9、IE低版本的BUG(部分)
    常见兼容性问题
    1、透明度:opacity:IE8及以下版本不识别,写成兼容性写法:filter: alpha(opacity=50);

        2、双边距:
            /* IE6下的双边距bug,及解决方案 */加:_display:inline;(加_表示仅针对IE6)
        .box{float:left; 100px;height: 100px;background: red;margin-left: 50px;_display:inline;}
    
        3、最小高度:
             /* IE6下的最下高度bug,最小高度为19px */
             解决方法为加overflow-hidden;
    
        4、图片链接产生边框:
        <a href="#">
            <img src="../img/练习1.jpg" alt="">
        </a>
        解决方法: img{border: none;}
    

    10、渐进增强与优雅降级
    渐进增强:针对低版本的浏览器进行构建页面,保证最基本的功能,然后再针对高级浏览器进行效果、交互等改进和最佳功能达到更好地用户体验。

    优雅降级:一开始就构建完整的功能,然后在针对低版本浏览器进行向下兼容(用不同方式实现和高级浏览器上一样的显示效果)
    

    11、网页布局扩展

    1、等高布局:
        子容器的margin如果取负值则,则会使父容器的高度小于子容器的高度:
        利用margin负值和padding的组合实现:
         .parent{border: 10px black solid;overflow: hidden;}
        .box1{float: left; 100px;background:red;margin-bottom: -2000px;padding-bottom: 2000px;}
        .box2{float: right; 100px;background:blue;margin-bottom: -2000px;padding-bottom: 2000px;}
    随着box1和box2内容的变多撑大父容器漏出hidden的区域,实现一种等高效果
    
    2、三列布局:左右固定,中间自适应
        
        1、BFC方式
        2、定位
        3、浮动(双飞翼布局、圣杯布局)(了解,一般用flex来做)
            终点了解:利用margin负值
        4、flex弹性
  • 相关阅读:
    Bootstrap的下拉菜单float问题
    style标签进行实时编辑及修改css(转)
    立即调用的函数表达式IIFE
    标签球Js插件
    如何正确使用Google搜索
    练习一:四则运算
    ARM伪指令
    vim 命令总结
    dialog BLE SDK 学习(1)
    ARM指令集
  • 原文地址:https://www.cnblogs.com/AhuntSun-blog/p/11982567.html
Copyright © 2011-2022 走看看