做个开源博客学习Vite2 + Vue3 (二)设置别名、代理和ESLint

vite2可以有很多配置,也可以都使用默认配置,这个看项目需要。

vite.config.js

我们先看看 vite.config.js里面的常用配置,其他配置可以看官网:https://cn.vitejs.dev/config/

// vite.config.js

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import { resolve } from "path" // 主要用于alias文件路径别名
// 加别名的函数
function pathResolve(dir) {
  return resolve(__dirname, ".", dir)
}

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [vue()], // 配置需要使用的插件列表,这里将vue添加进去
  // 配置文件别名 vite1.0是/@/  2.0改为/@
  // 这里是将src目录配置别名为 /@ 方便在项目中导入src目录下的文件
  resolve: {
    alias: {
      "/@": pathResolve("src"),
      "/config": pathResolve("public/config"),
      "/com": pathResolve("src/components")
    }
  },
  base: "vue3-blog", // 便于发布到gitee
  // 打包配置
  build: {
    target: 'modules',
    // outDir: 'dist', //指定输出路径
    // assetsDir: 'assets', // 指定生成静态资源的存放路径
    minify: 'terser' // 混淆器,terser构建后文件体积更小
  },
  // 本地运行配置,及反向代理配置
  server: {
    cors: true, // 默认启用并允许任何源
    open: true, // 在服务器启动时自动在浏览器中打开应用程序
    //反向代理配置,注意rewrite写法,开始没看文档在这里踩了坑
    proxy: {
      '/api': {
        target: 'http://192.168.99.223:9000',   //代理接口
        changeOrigin: true,
        rewrite: (path) => path.replace(/^\/api/, '')
      }
    }
  }
})

  • 别名
    这里尝试了好多种方法,发现这种可行。主要是官网似乎也没说 resolve 要 在哪里引用。

  • base
    默认情况下,会认为项目运行在网站的根目录里面,但是有些情况下项目无法运行在根目录里面,
    比如发布到GitHub,只能使用 https://naturefw.gitee.io/vue3-blog 这样的目录,那么这时候就需要设置这个base了。
    也很简单 base: "vue3-blog" 这样就可以,这样发布打包的时候就可以正确设置js、css等的引用路径。

  • 反向代理
    这个主要是处理ajax(axios)的跨域访问的。以前对这个比较模糊,不过尝试之后就清晰了。

跨域访问

尝试一下跨域访问的方式。

  • 安装 axios
yarn add axios
  • 前端测试代码

然后在组件里面做一个简单的测试。

import axios from 'axios'

const get = () => {
  axios.get('api/a')
    .then(res => {
      console.log(res);
    }).catch(err => {
      console.log(err);
    })
}
  • 后端测试代码

后端使用node建立一个最简单的web服务

// server.js
const http = require('http');

http.createServer(function(request, response) {
  // 设置响应头
  response.writeHeader(200, {
    "Content-Type" : "text/plain"
  });
  console.log('有访问者')
  // 响应主体为 "Hello world!"
  response.write("Hello world!");
  response.end();
})
// 设置监听端口为9000
.listen(9000);

console.log('请打开:http://localhost:9000')

用 node server.js 运行这个服务。

  • 测试运行
  1. 运行vue的项目,向后端申请数据,
  2. 这时候会先提交到vite2启动的web服务,
  3. 然后判断后再转给node建立的web服务,
  4. 处理之后返给node建立的web服务,
  5. 最后返给浏览器。

前端得到的数据是这样的:因为是通过vite2建立的服务做周转,所以不算跨域。

反向代理

测试通过。

安装ESlint

编写代码需要有一个共同的规范,虽然大家都有各自的习惯,但是还是需要尽量的统一一下,ESLint就是一个很好的选择。

vue-cli建立项目的时候就非常简单,我们选择一个风格就可以自动安装了,现在vite2还不够自动化,需要我们自己安装,今天学习了一下,补充这块短板。

  • 安装
yarn add eslint
  • 配置

问答的形式进行配置。

npx eslint --init

对自己狠一点,我们选择第三个,严格模式:

检查方式

选择 类型模块,选择 JavaScript modules:

模块类型

当然选 vue.js 了

选择框架

要不要用TS?目前不会,先不用了。

TS?

代码在哪里运行?注意这是多选,那就都选好了。

image.png

进入重点环节了,开始选择代码风格了。这个大概是问你,要套餐还是单点,符合主流,我们选套餐。

套餐还是单点?

vue-cli4.5建立的项, 选择的是 Standard config (ESLint+标准配置),所以这里选第二项。据说这些都是各位大牛总结出来的,我们按照这个来就好。

代码风格

选择配置文件的格式,这里选择js

配置文件的格式

立即执行?

开始安装吗

其实我是想用 yarn 安装的,但是又不知道怎么写。

yarn add 
eslint-plugin-vue@latest 
eslint-config-standard@latest 
eslint@^7.12.1 
eslint-plugin-import@^2.22.1 
eslint-plugin-node@^11.1.0 
eslint-plugin-promise@^4.2.1

也许是这么写吧。

果然还是应该用 yarn 来安装。

VSCode 使用 ESLint 配置文件需要去插件市场下载插件 ESLint 。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,222评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,455评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,720评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,568评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,696评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,879评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,028评论 3 409
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,773评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,220评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,550评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,697评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,360评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,002评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,782评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,010评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,433评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,587评论 2 350

推荐阅读更多精彩内容