news 2025/12/24 20:46:40

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

作者头像

张小明

前端开发工程师

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进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/20 9:54:56

Godot资源逆向工程实战:从PCK文件解析到游戏资源提取全流程

Godot资源逆向工程实战&#xff1a;从PCK文件解析到游戏资源提取全流程 【免费下载链接】godot-unpacker godot .pck unpacker 项目地址: https://gitcode.com/gh_mirrors/go/godot-unpacker 在独立游戏开发和游戏研究领域&#xff0c;Godot引擎的PCK资源文件格式一直是…

作者头像 李华
网站建设 2025/12/16 22:57:25

快速解决Fiji Jaunch组件重复文件错误的终极指南

快速解决Fiji Jaunch组件重复文件错误的终极指南 【免费下载链接】fiji A "batteries-included" distribution of ImageJ :battery: 项目地址: https://gitcode.com/gh_mirrors/fi/fiji Fiji是一款功能强大的图像处理软件&#xff0c;但近期Windows x64平台的…

作者头像 李华
网站建设 2025/12/16 22:57:11

百度网盘提取码自动获取工具:3步告别手动查找烦恼

百度网盘提取码自动获取工具&#xff1a;3步告别手动查找烦恼 【免费下载链接】baidupankey 项目地址: https://gitcode.com/gh_mirrors/ba/baidupankey 还在为百度网盘分享链接的提取码而四处搜索吗&#xff1f;每次遇到需要输入提取码的资源&#xff0c;都要在多个网…

作者头像 李华
网站建设 2025/12/16 22:55:19

单链表的应用-反转链表and删除链表中间结点

反转链表解法&#xff1a;多指针1.创建三个指针first&#xff1a;记录当前节点的 “前一个节点”&#xff08;反转后&#xff0c;当前节点要指向它&#xff09;&#xff1b;second&#xff1a;指向当前正在处理的节点&#xff08;每轮循环要反转它的next指针&#xff09;&#…

作者头像 李华
网站建设 2025/12/16 22:55:01

JavaScript 中的组合模式(Composite Pattern):实现树形结构的统一操作

JavaScript 中的组合模式&#xff1a;实现树形结构的统一操作各位技术爱好者&#xff0c;欢迎来到今天的讲座。我们将深入探讨 JavaScript 中一个极其强大且实用的设计模式——组合模式&#xff08;Composite Pattern&#xff09;。这个模式的核心在于&#xff0c;它能让我们以…

作者头像 李华