美文网首页
css 图片相关

css 图片相关

作者: 云上笔记 | 来源:发表于2021-01-19 12:06 被阅读0次

    展示图片

    1. 使用 <img /> 标签;
    2. ::after 和 ::before 设置图片;
    3. 鼠标 hover 自定义光标样式;
    4. border-image 自定义边框图案;
    5. list-style-image 设置列表项样式;
    6. background-image 设置背景图片;
    /* 居中不重复的背景图片 */
    background: url(../asset/img/logo.jpg) no-repeat center;
    
    /* x轴重复 */
    background: url(../asset/img/logo.jpg) repeat-x;
    
    /* background 是以下属性值的缩写
        image: 背景图片 
        color: 背景颜色 
        repeat: 定义图片重复的方式 可选值 repeat-x/repeat-y/repeat/space/round/no-repeat
        size: 背景图片大小 可选值 contain/cover/百分比/具体像素
        clip: 背景图片延伸到哪个位置 可选值 text/border-box/padding-box/content-box 
        origin: 背景图片相对于哪个区域开始摆放 border-box/padding-box/content-box
        attachment: 背景图片在视口内固定还是随包含它的区块滚动 scroll/fixed/local
        position: 相对origin为图片设置初始位置  left/bottom/top/right/center/百分比/具体像素
        position-x: 设置背景图片在水平方向的位置 left/center/right/百分比/具体像素
        position-y: 设置背景图片在垂直方向的位置 top/center/bottom/百分比/具体像素
    */
    
    div::after{
      content: url(../asset/img/logo.jpg);
    }
    
    cursor: url(../asset/img/cursor.jpg) auto;
    
    /* border-image: source slice width outset repeat|initial|inherit; */
    border: 10px solid transparent;
    border-image: url(./images/logo.png) 30 30 10 round;
    
    /* 列表项标记样式 */
    list-style-image: url(./images/checked.png);
    

    图片缩放

    ①纯css实现缩放

    /* 方式一 */
    transform: scale(.8);
    
    /* 方式二 */
    zoom: 50%;
    

    ②图片随鼠标滚轮缩放

    /* html */
    <img src="./images/desktop.jpg" alt="" onmousewheel="return zoom(this)" />
    
    /* javascript */
    function zoom(el) {
        var zoom = parseInt(el.style.zoom, 10) || 100;
            zoom += event.wheelDelta / 100;
            console.log(event.wheelDelta);
            if (zoom > 0) {
                el.style.zoom = zoom + '%';
            }
        return false;
    }
    

    图片填充设置

    object-fit 可以设置替换元素 (<img /> <iframe>...) 的内容如何填充到容器中,在<img /> 元素中的使用如下:

    object-fit: contain;
    
    /* object-fit 包含以下几种值, 
       fill: 默认值,填充,图片填满容器,可能会改变宽高比,导致图片拉伸;
       contain: 包含,整个图片会保持宽高比展示在容器中,可能会被缩放,部分背景会空白;
       cover: 覆盖,图片保持宽高比填满容器,图片可能会被裁剪;
       none: 保持图片原尺寸和比例;
       scale-down: 等比缩小,类似依次设置了 none 和 contain,最终展示尺寸较小的那个;
    */
    

    图片位置设置

    object-position 可以设置替换元素的内容在容器中的位置,可用 left、top 等方位值控制,也可以用具体的数值表示,在<img /> 元素中的使用如下:

    object-position: left top;
    
    /* 
      object-position: 水平方向可能的值       垂直方向可能的值
      object-position: left/center/right   top/center/bottom;
      object-position: 10px 15px; 
      如果只设置了一个值,则默认另一个方向的值为 center    
      如:object-position: top; => object-position: center top;
    */
    

    图片热区

    定义:在图片中指定某个区域,当用户点击该区域内时可以链接跳转到指定页面。
    应用场景:中国地图图片点击具体的省份跳转到各省对应的官网。
    创建图片热区:

    /* 
      <area shape="rect/circle/poly" href="" coords="" target="_blank/_parent/_self/_top"> 
      shape: 规定区域的形状;  
      href: 目标 url;  
      coords: 坐标; shape="rect" => x1,y1,x2,y2; shape="circ" => x,y,radius
      target: 在何处打开目标 url
    */
    <img src="../asset/images/china.jpg" usemap="#mapname"/>
    <map name="mapname" id="mapname">
        <area shape="rect" href="" coords="0,0,50,50"/>
    </map>
    

    滤镜属性

    filter 属性可以调节元素的视觉效果,如设置图片灰度、透明度、饱和度等

    filter: none | 默认
            blur(px) | 高斯模糊
            brightness(%) | 亮度
            contrast(%) | 对比度
            drop-shadow() | 阴影
            grayscale(%) | 灰度
            hue-rotate() | 色相旋转
            invert(%) | 反相
            opacity(%) | 透明度
            saturate(%) | 饱和度
            sepia(%) | 深褐色
            url();
    

    3 像素bug

    描述:img 标签渲染之后下方会出现几个像素(谷歌是 4px, 火狐 3.5px)的空白;
    原因:img 是行内元素,默认display:inline; 它与文本的默认行为类似,下边缘是与基线对齐,而不是贴紧容器下边缘,所以会有几像素的空白;
    解决办法:
    把 img 设置为display: block;
    给 img 和其父元素都设置 vertical-align: top;让其 top 对齐而不是 baseline 对齐;
    给 img 父元素设置 line-height: 0;

    相关文章

      网友评论

          本文标题:css 图片相关

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