news 2026/5/29 4:39:24

前端自适应布局之等比例缩放

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
前端自适应布局之等比例缩放

问题描述:
有个插件Postcss-pxtorem能自动转换px做适配,但是某些插件不能转换,例如antd。
设计图只有一套1920*1080.要做到尽量1比1还原,又能适配大小屏幕,如果一个个转百分比会非常麻烦。
这时就可以选择用等比例缩放实现自适应布局。
运行环境:react+umi(其他也可用,原理一样)
1.根据设计图1比1写px。
2.在layout写

import React, { useEffect, useRef, useState } from 'react'; import { Outlet } from '@umijs/max'; import styles from './ScaleLayout.less'; import { LayoutProvider } from './context'; const ScaleLayout: React.FC = () => { const [bg, setBgState] = useState(''); const scaleRootRef = useRef<HTMLDivElement>(null); useEffect(() => { const setScale = () => { const scaleX = window.innerWidth / 1920; const scaleY = window.innerHeight / 1080; // Use Math.min to fit the screen while maintaining aspect ratio (letterboxing) const scale = Math.min(scaleX, scaleY); console.log('scale', scale); if (scaleRootRef.current) { scaleRootRef.current.style.transform = `scale(${scale})`; } }; // Initial scale setScale(); // Add event listener window.addEventListener('resize', setScale); // Cleanup return () => window.removeEventListener('resize', setScale); }, []); return ( <LayoutProvider value={{ setBg: setBgState }}> <div className={styles.viewport}> <div className={styles.pageBg} style={{ backgroundImage: bg ? `url(${bg})` : 'none' }} /> <div className={styles.scaleRoot} ref={scaleRootRef}> <Outlet /> </div> </div> </LayoutProvider> ); }; export default ScaleLayout;

layout样式:

.viewport { width: 100vw; height: 100vh; background: #050b16; // Match the app's dark theme overflow: hidden; display: flex; justify-content: center; align-items: center; } /* 页面背景层(不参与缩放) */ .pageBg { position: absolute; inset: 0; background-size: cover; background-position: center; z-index: 0; } .scaleRoot { width: 1920px; height: 1080px; transform-origin: center center; flex-shrink: 0; overflow: hidden; }

背景有黑边?把背景提到缩放盒子外边。这样就能实现内容的1比1,又不会太难看。
context.tsx

import React, { createContext, useContext, useState } from 'react'; interface LayoutContextType { setBg: (bg: string) => void; } const LayoutContext = createContext<LayoutContextType | undefined>(undefined); export const useLayout = () => { const context = useContext(LayoutContext); if (!context) { throw new Error('useLayout must be used within a LayoutProvider'); } return context; }; export const LayoutProvider: React.FC<{ children: React.ReactNode; value: LayoutContextType }> = ({ children, value }) => { return <LayoutContext.Provider value={value}>{children}</LayoutContext.Provider>; };

页面设置背景

import { useLayout } from '@/layouts/context'; import bg from '@/assets/imgs/training/zice/learn_sel_bg.png' const { setBg } = useLayout(); useEffect(() => { setBg(bg); return () => setBg(''); }, []);
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/23 17:15:36

UnrealPakViewer完全指南:5步掌握UE4 Pak文件深度分析技巧

UnrealPakViewer完全指南&#xff1a;5步掌握UE4 Pak文件深度分析技巧 【免费下载链接】UnrealPakViewer 查看 UE4 Pak 文件的图形化工具&#xff0c;支持 UE4 pak/ucas 文件 项目地址: https://gitcode.com/gh_mirrors/un/UnrealPakViewer UnrealPakViewer是一款专为虚…

作者头像 李华
网站建设 2026/5/28 2:49:18

ViGEmBus终极指南:3步掌握Windows虚拟游戏控制器驱动开发

想要在Windows系统上创建虚拟游戏控制器&#xff1f;ViGEmBus驱动为您提供了一种创新的解决方案。这款强大的内核模式驱动程序能够实现Xbox 360和DualShock 4控制器的功能&#xff0c;让您的游戏应用开发更加灵活高效。 【免费下载链接】ViGEmBus Windows kernel-mode driver e…

作者头像 李华
网站建设 2026/5/18 19:13:11

XUnity自动翻译插件终极指南:3分钟解锁多语言游戏新体验

XUnity自动翻译插件终极指南&#xff1a;3分钟解锁多语言游戏新体验 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator Unity游戏玩家们&#xff0c;是否曾因语言障碍而错失精彩游戏内容&#xff1f;XUnity …

作者头像 李华
网站建设 2026/5/26 19:40:22

4步实战指南:用OpenCore Legacy Patcher让老旧Mac完美兼容最新系统

4步实战指南&#xff1a;用OpenCore Legacy Patcher让老旧Mac完美兼容最新系统 【免费下载链接】OpenCore-Legacy-Patcher 体验与之前一样的macOS 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 你是否还在使用一台性能尚可但已被官方&quo…

作者头像 李华