使用的是vue-cli+webpack,經過npm來安裝的css
npm i lib-flexible --save
在main.js中引入lib-flexiblehtml
import 'lib-flexible/flexible'
經過meta標籤,設置設備寬度以及縮放比例vue
<meta name="viewport" content="width=device-width, initial-scale=1.0">
npm install px2rem-loader
這裏是重要的一步~~webpack
在build文件中找到util.js,將px2rem-loader添加到cssLoaders中,如:web
const cssLoader = {
loader: 'css-loader',
options: {
minimize: process.env.NODE_ENV === 'production',
sourceMap: options.sourceMap
}
}
const px2remLoader = {
loader: 'px2rem-loader',
options: {
remUnit: 75 // 這裏設置html根字體,vant-UI的官方根字體大小是37.5
}
}
同時,在generateLoaders方法中添加px2remLoadervue-cli
function generateLoaders (loader, loaderOptions) {
const loaders = options.usePostCSS ? [cssLoader, postcssLoader, px2remLoader] : [cssLoader, px2remLoader]npm
if (loader) {
loaders.push({
loader: loader + '-loader',
options: Object.assign({}, loaderOptions, {
sourceMap: options.sourceMap
})
})
}post
if (options.extract) {
return ExtractTextPlugin.extract({
use: loaders,
fallback: 'vue-style-loader'
})
} else {
return ['vue-style-loader'].concat(loaders)
}
}字體
當配置完以後,只須要重啓下服務,就自動轉化爲rem了flex
npm run dev