适配方案
1. 安装依赖
npm install px2rem-loader lib-flexible --save
2. 设置viewport
设置: <meta name="viewport" content="width=device-width,initial-scale=1.0">
1. 说明: 因为默认的布局视口大于视觉视口,如果不设置将导致页面的内容显示非常小
2. 原理: 将980的页面在375的屏幕上完全显示只能缩小980页面中的内容
3. 直接设置px问题
1. px为css像素单位等同于独立设备像素单位
2. 设计师给的设计稿的单位是物理像素单位
3. 直很多设备上接设置px像素单位会比设计师的要求大
4. Vue2中使用px2rem, lib-flexible
- 在项目入口文件 main.js 里 引入 lib-flexible, flexible会自动根据设备情况动态设置rem的值的大小
import 'lib-flexible/flexible'
- 在build文件夹下的util.js中添加
// 全局定义px2remLoader
const px2remLoader = {
loader: 'px2rem-loader',
options: {
remUnit: 37.5 // remUnit为转换rem的基础 设计稿单位/等分数 = remUnit
}
}
// 在该函数的loaders中添加
function generateLoaders (loader, loaderOptions) {
// 添加使用 px2remLoader
const loaders = options.usePostCSS ? [cssLoader, postcssLoader,px2remLoader] : [cssLoader, px2remLoader]
if (loader) {
loaders.push({
loader: loader + '-loader',
options: Object.assign({}, loaderOptions, {
sourceMap: options.sourceMap
})
})
}
// Extract CSS when that