使用vw进行移动端适配(nuxt项目)
基于nuxt 2.0.0
安装postcss-px-to-viewport
npm安装
npm install postcss-px-to-viewport --save-dev
或 yarn安装
yarn add -D postcss-px-to-viewport
在nuxt中配置postcss-px-to-viewport
在nuxt.config.js中配置
export default {
...
...
...
/*
** Build configuration
*/
build: {
/*
** You can extend webpack config here
*/
postcss: {
// 添加插件名称作为键,参数作为值
plugins: {
"postcss-px-to-viewport": {
unitToConvert: "px", // 默认值`px`,需要转换的单位
viewportWidth: 375, // 视窗的宽度,对应设计稿宽度
viewportHeight: 667, // 视窗的高度, 根据375设备的宽度来指定,一般是667,也可不配置
unitPrecision: 3, // 指定`px`转换为视窗单位值的小数位数
propList: ["*"], // 转化为vw的属性列表
viewportUnit: "vw", // 指定需要转换成视窗单位
fontViewportUnit: "vw", // 字体使用的视窗单位
selectorBlaskList: [".ignore-"], // 指定不需要转换为视窗单位的类
mediaQuery: false, // 允许在媒体查询中转换`px`
minPixelValue: 1, // 小于或等于`1px`时不转换为视窗单位
replace: true, // 是否直接更换属性值而不添加备用属性
exclude: [/node_modules/, /main/], // 忽略某些文件夹下的文件或特定文件
landscape: false, // 是否添加根据landscapeWidth生成的媒体查询条件 @media (orientation: landscape)
landscapeUnit: "vw", // 横屏时使用的单位
landscapeWidth: 1134 // 横屏时使用的视窗宽度
}
},
preset: {
// 更改postcss-preset-env 设置
autoprefixer: {}
}
}
}
}
这样基本的配置就可以了。
其他适配问题可以参考下面的文章👇
参考:
nuxt中如何添加postcss插件:https://zh.nuxtjs.org/faq/postcss-plugins/#%E5%A6%82%E4%BD%95%E6%B7%BB%E5%8A%A0-postcss-%E6%8F%92%E4%BB%B6-
postcss-px-to-viewport: https://github.com/evrone/postcss-px-to-viewport
再聊移动端页面的适配(收费):https://www.w3cplus.com/css/vw-for-layout.html
再聊移动端页面的适配(转载):https://blog.csdn.net/qq_21729177/article/details/79466951
转载
https://www.cnblogs.com/MaiJiangDou/p/13066342.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
2023-03-19 微信开放平台和微信公众平台
2019-03-19 JS 获取当前时间和日期,以及是否处于有效期内