直播短视频源码,基于create-react-app 适配移动端方案
直播短视频源码,基于create-react-app 适配移动端方案
最近在react的时候发现基于create-react-app搭建的项目有不少坑(react大佬请绕路),首先公司如果没有固定的手脚架的话就需要自己搭建项目,npm各种的库,难免会耗不少时间,以下是我搭建的经历(坑)
安装基本react依赖库
npm i react-dom react-redux react-router-dom redux-thunk -S
有关webpack选项的自定义
选择的是react-app-rewired + customize-cra
npm install react-app-rewired customize-cra --save-dev
customize-cra的更多用法
然后将package.json中的scripts改成以下:
"scripts": { "start": "react-app-rewired start", "build": "react-app-rewired build", "test": "react-app-rewired test", "eject": "react-app-rewired eject" }
在根目录新建一个config-overrides.js文件,写入代码
const {override} = require("customize-cra"); module.exports = override();
关于适配
我使用的是postcss-px-to-viewport进行设置适配(px装换成vw)
npm代码我就不写了,额...
npm装以下的包:
"devDependencies": { "cssnano": "^4.1.7", "cssnano-preset-advanced": "^4.0.5", "postcss-aspect-ratio-mini": "^1.0.1", "postcss-cssnext": "^3.1.0", "postcss-import": "^12.0.1", "postcss-px-to-viewport": "^0.0.3", "postcss-url": "^8.0.0", "postcss-viewport-units": "^0.1.6", "postcss-write-svg": "^3.0.1" },
在根目录新建postcss.config.js文件
加入一下代码:
module.exports = { "postcss-import": {}, "postcss-url": {}, "postcss-aspect-ratio-mini": {}, "postcss-write-svg": {utf8: false}, "postcss-cssnext": {}, "postcss-px-to-viewport": { viewportWidth: 750 / 2, // (Number) The width of the viewport. viewportHeight: 1334 / 2, // (Number) The height of the viewport. unitPrecision: 3, // (Number) The decimal numbers to allow the REM units to grow to. viewportUnit: "vw", // (String) Expected units. selectorBlackList: [".ignore", ".hairlines"], // (Array) The selectors to ignore and leave as px. minPixelValue: 1, // (Number) Set the minimum pixel value to replace. mediaQuery: false, // (Boolean) Allow px to be converted in media queries. }, "postcss-viewport-units": {}, "cssnano": { "cssnano-preset-advanced": { zindex: false, autoprefixer: false, }, // preset: 'advanced', // autoprefixer: false, // 'postcss-zindex': false, }, };
postcss-px-to-viewport更多的用法
注意:低版本的android手机存在不支持vw的方法,如果需要考虑低版本的手机网上有垫片方案
然后我们在配置刚刚新建的config-overrides.js文件
const {override, addPostcssPlugins} = require("customize-cra"); const postcss = require("./postcss.config.js"); // postcss 配置项 const postcssPlugin = Object.keys(postcss).map(key => require(key)(postcss[key])); module.exports = override( addPostcssPlugins(postcssPlugin), );
可以看到我是通过引入postcss.config.js,然后遍历对象导入有关postcss的配置项,后期如果需要加postcss的插件,在postcss.config.js增加即可。
以上就是直播短视频源码,基于create-react-app 适配移动端方案, 更多内容欢迎关注之后的文章
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现