从零开始搭建 vue2+VantUI 移动端项目-完整版

从零开始搭建 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:'首页'
        }
    }]
})

然后在main.js下引入路由:

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')

最后在App.vue页面上加上

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;

2、在vue.config.js文件下添加以下代码:

css 复制代码
css: {
        loaderOptions: {
            sass:{
                prependData:`@import "@/assets/style/variables.scss";`
            }
        }
},

这样就是在页面中全局使用sass变量了。

在这里我们这里看的到,我们写的height: 80px;在浏览器里看到的就是80的一半。。

还是一个需要补充的是,根据不同的需求,有时候我们并不想自己的px单位被转换,这个时候我们可以在样式后面加上 /no/

如下所示:

附上项目模板git地址:gitee.com/4564zyfe/vu...

相关推荐
Cachel wood1 小时前
Vue.js前端框架教程4:Vue响应式变量和指令(Directives)
前端·vue.js·windows·python·单元测试·django·前端框架
rainoway1 小时前
CRDT宝典 - Delta-state AWOSet
前端·分布式·算法
minstbe1 小时前
半导体数据分析(二):徒手玩转STDF格式文件 -- 码农切入半导体系列
前端·javascript·数据库
Catherinemin2 小时前
CSS|08 浮动&清除浮动
前端·css
kaoa0002 小时前
Linux入门攻坚——42、Nginx及web站点架构模式
linux·前端·nginx
赵大仁2 小时前
在M系列芯片的Mac上使用Uniapp开发的依赖安装指南
前端·windows·macos·ios·小程序·uni-app·安卓
Beekeeper&&P...4 小时前
AddressBookController
java·前端·网络
今天也要暴富4 小时前
CSS Grid 布局:属性及使用详解
前端·css
前端熊猫4 小时前
组件十大传值
前端·javascript·vue.js
oumae-kumiko4 小时前
【JS/TS鼠标气泡跟随】文本提示 / 操作提示
前端·javascript·typescript