zoukankan      html  css  js  c++  java
  • image以最小边为标准填满正方形父级元素

    需求:

      上传图片并实现预览, 图片以最小边为标准填满正方形的父级div,且不变形,且点击可以预览大图.

      有两种实现方式:

      1.div+img标签, 利用object-fit:cover,据说兼容性不好,但在手机上安卓和IOS暂无发现问题.

    //HTML
    <div>
        <img :src="item.imgUrl" v-if="item.imgUrl" class="upload_warp_img" @click="getShowImg($event,index)"/>
    </div>
    
    
    //CSS
     div{
        border: 1px solid #ccc;
         100px;
        height: 100px;
       
      }
      .file-border .upload_warp_img{
         100%; 
        height: 100%;   
        object-fit:cover;
      }

    这样会出现一个问题,当img src为空时设置宽高,会显示失败图标,如下:

      我是依据imgUrl是否存在用v-if控制触发上传还是预览的,不过预览事件是加在Img上的.

      这样设置默认有图片,点击方框的时候是预览模式,而非上传照片.

      后面解决也是考虑了两种方式,:

        一是点击事件加到父级div上.

        二是同样用用v-if控制img的上传与隐藏.失败的img隐藏了就不会触发预览事件了.

      2. 就是利用背景定位了, 加上background-size: cover;

      此种方法可以解决一部分问题,但是不能全部选择这种方式.

      和用户相关的比较重要的图片还是以img标签显示为好.

    div{
    100px;
    height:100px;
    border:1px solid #ccc; background:url(
    '111.jpg') no-repeat center; background-size: cover; }

      因我采取了第一种方式,第二种未来得及验证src为空的时候有副作用不.

      暂时知道这两种方式,如有其它方式,请多多指教,先酱紫~

  • 相关阅读:
    java----设计模式--创建型模式(GOF23)
    java----作用域
    java和python对比----实例化的对象属性:
    java----关键字
    java----Java的栈,堆,代码,静态存储区的存储顺序和位置
    java----面对对象
    算法----取0~30不重复的10个整数
    算法----二分查找算法
    织梦 验证码不显示问题
    dedecms 后台修改系统设置,但是config.cache.inc.php文件不能写入
  • 原文地址:https://www.cnblogs.com/qiezuimh/p/8696585.html
Copyright © 2011-2022 走看看