vue-cli 3+ 脚手架创建项目

55 篇文章 4 订阅
17 篇文章 0 订阅

1 全局安装脚手架 

npm install -g @vue/cli

查看版本

$ vue --version
@vue/cli 4.5.15

2 创建项目

官方地址:创建一个项目 | Vue CLI

 选择默认的Vue2方式;回车后,稍等片刻,安装完成

完成之后的目录结构如下:

 运行 npm run serve启动项目;默认在8080端口启动

3 vue.config.js配置

新建的项目没有该文件,需要我们自己创建;详细配置见配置参考 | Vue CLI

在根目录新建vue.config.js,然后新建一个空对象

// vue.config.js
module.exports={

}

3.1 publicPath

配置网站根路径,如果是开发环境,则在端口号之后不加路径,如果是开发打包环境会自动加上transit-authority才可访问;NODE_ENV变量是内置在环境变量的,暂时不需要额外配置

    // 网站访问根路径
    publicPath:process.env.NODE_ENV==="development"
    ?"/":"/transit-authority/",

3.2 devServer

本地服务相关配置对象;所有 webpack-dev-server 的选项都支持;详细配置见DevServer | webpack

先简单配个端口号:

    // 本地服务配置
    devServer:{
        // 端口号配置
        port:8090
    }

现在的目录和vue.config.js如下所示: 

 3.3 lintOnSave

配置是否开启eslint检查,如果设置为FALSE,在修改代码并ctrl+s保存后,是不会执行eslit检查的

// vue.config.js
module.exports={
    // 网站访问根路径
    publicPath:process.env.NODE_ENV==="development"
    ?"/":"/transit-authority/",
    // 本地服务配置
    devServer:{
        // 端口号配置
        port:8090,
    },
    lintOnSave: false
}

3.4 配置proxy(跨域) 

项目启动后,二级目录是api的接口都会被代理到指定的target地址;

    // 本地服务配置
    devServer:{
        // 端口号配置
        port:8090,
        // 跨域配置
        proxy: {
            '^/api/': {
              target: 'http://localhost:8060',
              changeOrigin: true
            }
        }
    },

3.5 配置打包文件夹

配置文件夹名称

    // 打包后的文件夹名称
    outputDir: 'dist',

首页名称

    // 打包后的首页名称
    indexPath: 'index.html',

4 vue-router配置

4.1 安装vue-router

npm install vue-router

4.2 手动创建router文件

        第一步:在src根目录路新建router文件夹,在其中创建index.js,键入如下内容

import Vue from 'vue';
import Router from 'vue-router';
Vue.use(Router);

const router = new Router({
    mode: 'history',
    base: process.env.BASE_URL,
    routes: []
  });

export default router

第二步:在Vue中注册router

在main.js中引入并注册router对象

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

4.3 添加router-view标签

第一步:在app.vue中添加    <router-view />;这样在路由中的组件内容会被渲染到此处

<template>
  <div id="app">
    <img alt="Vue logo" src="./assets/logo.png">
    <HelloWorld msg="Welcome to Your Vue.js App"/>
    <router-view />
  </div>
</template>
<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
  name: 'App',
  components: {
    HelloWorld
  }
}
</script>

第二步:创建组件

如下创建一个demo1.vue组件

 第三步:引入组件并设置路由

 访问路由,效果如下

其他配置,后续增加即可

5 配置API文件夹

5.1 安装axios

npm install --save axios

5.2 在src目录下新建index.js文件

在index.js文件中写入接口信息;url在项目启动后会直接加上启动服务的ip地址;

import axios from 'axios'
function getInfo() {
    return axios({
      method: 'get',
      url: '/api/getnotice',
    })
  }
  
export { getInfo }

5.3 配置http

一般如果对请求有拦截等设置,可以新建一层http过度一下

新建一个httpInstance.js文件;

import axios from 'axios'
const http = axios.create({
    timeout: 20000,
    withCredentials: true,
    headers: { 'X-Requested-With': 'XMLHttpRequest' },
})


// 加拦截器
// 。。。
export default http

在index.js中使用

import http from './httpInstance'
function getInfo() {
    return http({
      method: 'get',
      url: '/api/getnotice',
    })
  }
  
export { getInfo }
  

5.4 使用接口

然后在接口中,引入使用即可

import {getInfo} from '../../api/index'

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

杨大大28

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值