从零开始搭建 vue2+VantUI 移动端项目-完整版
一、使用npm创建项目:
执行以下安装命令,选择vue2项目
lua
vue create my-project
二、配置路由:
执行以下命令,安装vue-router:
css
npm i vue-router@3.5.3 -D
然后,先在src目录下新建页面文件夹views,然后在views文件夹下新建页面index.vue
其次,在src目录下新建文件夹router,然后在router文件夹下新建 index.js
javascript
//index.js
import Vue from "vue"
import Router from "vue-router"
Vue.use(Router)
export default new Router({
mode:"hash",
base:process.env.BASE_URL,
routes:[{
path:'/',
name:'Index',
component :()=> import('@/views/index.vue'),
meta:{
title:'首页'
}
}]
})
javascript
//main.js
import Vue from 'vue'
import App from './App.vue'
import router from './router'
Vue.config.productionTip = false
new Vue({
router,
render: h => h(App),
}).$mount('#app')
xml
<template>
<div id="app">
<router-view></router-view>
</div>
</template>
<script>
export default {
name: 'App',
}
</script>
<style>
</style>
到这里我们就可以在浏览器上看到我们新建的页面也出来:
三、引入VantUI
执行以下命令安装Vant2
css
npm i vant@latest-v2 -D
在main.js下全局引入Vant import Vue from 'vue' import App from './App.vue' import router from './router' import Vant from 'vant'; import 'vant/lib/index.css'; Vue.use(Vant); Vue.config.productionTip = false new Vue({ router, render: h => h(App), }).$mount('#app')
四、手机端适配
通常情况下我们拿到的设计稿单位都是px的,那么在移动端上我们就要转换成rem
执行以下命令:
css
npm i postcss-px2rem-exclude -D
npm i lib-flexible -D
然后再main.js下引入
arduino
import 'lib-flexible';
最后在项目根目录下新建vue.config.js文件:
yaml
//vue.config.js
const webpack = require("webpack")
module.exports = {
assetsDir: 'static',
publicPath: process.env.NODE_ENV == 'development' ? '/' : '../apps/com.awspaas.user.apps.bpm_actions.portal/',
outputDir: './dist',
indexPath: 'index.html',
productionSourceMap: false,
lintOnSave: false,
filenameHashing: true,
css: {
loaderOptions: {
postcss: {
// 这是rem适配的配置 注意: remUnit在这里要根据lib-flexible的规则来配制,如果您的设计稿是750px的,用75就刚刚好。
plugins: [
require('postcss-px2rem-exclude')({
remUnit: 75,
exclude: /node_modules/i //这是为了不影响第三库的样式,如果入写,会导致vant的样式会变小
})
]
},
}
},
devServer: {
hot: true,
port: 8080,
open: false,
noInfo: false,
overlay: {
warnings: true,
errors: true,
},
}
}
5、安装sass并配置全局变量
执行以下命令:
css
npm i sass-loader@8.x -D
npm i node-sass@4.14.1 -D
1、新建文件 variables.scss
css
$primary-color:#6992dd;
$secondary-color:#547fcd;
$text-blue-color:#648eda;
$highlight-color:#7cffe2;
$bgblue-color:#f2f7ff;
css
css: {
loaderOptions: {
sass:{
prependData:`@import "@/assets/style/variables.scss";`
}
}
},
在这里我们这里看的到,我们写的height: 80px;在浏览器里看到的就是80的一半。。
还是一个需要补充的是,根据不同的需求,有时候我们并不想自己的px单位被转换,这个时候我们可以在样式后面加上 /no/
如下所示:
附上项目模板git地址:gitee.com/4564zyfe/vu...