vue解决页面放大图片模糊的问题

1.页面放大(或者电脑设置了缩放比例,比如125%),图片模糊

不考虑带宽的情况下,直接请求后端最大尺寸的照片。

2.根据用户电脑的放大倍数或者电脑设置中的放大倍数(DPR),自动请求合适的照片

3.实现:

记住公式:图片尺寸 = css尺寸 * DPR,只要公式成立,就一定是清晰的

4.利用img标签的srcset属性实现,值为:图片地址 + DPR

复制代码
<template>
    <div>
        <img srcset="
        https://picsum.photos/id/88/150 1x,
        https://picsum.photos/id/88/300 2x,
        https://picsum.photos/id/88/600 4x,
        https://picsum.photos/id/88/900 6x,
        https://picsum.photos/id/88/1200 8x,
        " alt="">
    </div>
</template>

<script>
export default{
    name: 'autoImg',
    data(){
        return {

        }
    }
}
</script>
<style lang="less" scoped>
img{
    width: 150px;
    height: 150px;
}
</style>

5.万一图片的css样式(宽高)不是写死的,用的是百分比,该如何实现?

记住公式:图片尺寸 = css尺寸 * DPR,现在css尺寸不固定,DPR也不固定

6.使用srcset+sizes属性实现,srcset的值改为:图片地址+图片原始尺寸,sizes采用媒介查询,当照片宽度最大是300px时,就当作是150px,然后乘以DPR,会自动选择合适图片地址。

复制代码
<template>
    <div>
        <img srcset="
        https://picsum.photos/id/88/150 150w,
        https://picsum.photos/id/88/300 300w,
        https://picsum.photos/id/88/600 600w,
        https://picsum.photos/id/88/900 900w,
        https://picsum.photos/id/88/1200 1200w,
        "
        sizes="
        (max-width: 300px) 150px, //当照片宽度最大是300px时,就当作是150px,然后乘以DPR(当为6时),自动选择900w的https://picsum.photos/id/88/900地址(150*6=900)
        (max-width: 600px) 300px,
        (max-width: 900px) 450px,
        (max-width: 1200px) 600px,
        1200px
        "
        alt="">
    </div>
</template>

<script>
export default {
    name: 'autoImg',
    data() {
        return {

        };
    }
};
</script>
<style lang="less" scoped>
img {
    width: 50vw;
    height: 50vh;
    display: block;
    margin: 0 auto;
}
</style>
相关推荐
吞掉星星的鲸鱼1 小时前
使用高德api实现天气查询
前端·javascript·css
lilye661 小时前
程序化广告行业(55/89):DMP与DSP对接及数据统计原理剖析
java·服务器·前端
....4921 小时前
Vue3 + Element Plus + AntV X6 实现拖拽树组件
javascript·vue.js·elementui·antvx6
zhougl9963 小时前
html处理Base文件流
linux·前端·html
花花鱼3 小时前
node-modules-inspector 可视化node_modules
前端·javascript·vue.js
HBR666_3 小时前
marked库(高效将 Markdown 转换为 HTML 的利器)
前端·markdown
careybobo4 小时前
海康摄像头通过Web插件进行预览播放和控制
前端
TDengine (老段)5 小时前
TDengine 中的关联查询
大数据·javascript·网络·物联网·时序数据库·tdengine·iotdb
杉之6 小时前
常见前端GET请求以及对应的Spring后端接收接口写法
java·前端·后端·spring·vue
喝拿铁写前端6 小时前
字段聚类,到底有什么用?——从系统混乱到结构认知的第一步
前端