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>
相关推荐
社恐的下水道蟑螂5 分钟前
LangChain 进阶实战:从玩具 Demo 到生产级 AI 应用(JS/TS 全栈版)
前端·langchain·openai
Fairy要carry7 分钟前
项目01-手搓Agent之loop
前端·javascript·python
亲亲小宝宝鸭12 分钟前
Ctrl ACV工程师的提效之路:删掉项目中的冗余
前端
kyriewen16 分钟前
DOM树与节点操作:用JS给网页“动手术”
前端·javascript·面试
米饭同学i19 分钟前
基于腾讯云COS的小程序素材上传功能实现
前端·javascript·react.js
cxxcode19 分钟前
前端性能指标接入 Prometheus 技术方案
前端
辣椒炒代码20 分钟前
🚀 AI Agent 入门实战:基于 LangChain + MCP 构建智能导游助手
前端
ruanCat24 分钟前
前端工程化工具链从零配置:simple-git-hooks + lint-staged + commitlint
前端·git·代码规范
光影少年26 分钟前
如何开发一个CLI工具?
javascript·测试工具·前端框架·node.js
哈__36 分钟前
ReactNative项目OpenHarmony三方库集成实战:react-native-fingerprint-scanner
javascript·react native·react.js