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

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

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


vite.config.js



我们先看看 vite.config.js里面的常用配置,其他配置可以看官网: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,只能使用 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建立的服务做周转,所以不算跨域。


image.png


测试通过。


安装ESlint



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

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


  • 安装


yarn add eslint
复制代码


  • 配置


问答的形式进行配置。


npx eslint --init
复制代码


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


image.png


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


image.png


  1. 当然选 vue.js 了


image.png


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


image.png


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


image.png


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


image.png


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


image.png


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


image.png


  1. 立即执行?


image.png


其实我是想用 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 。



相关文章
|
3月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
66 1
vue学习第一章
|
3月前
|
JavaScript 前端开发 索引
vue学习第三章
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中的v-bind指令,包括基本使用、动态绑定class及style等,希望能为你的前端学习之路提供帮助。持续关注,更多精彩内容即将呈现!🎉🎉🎉
63 1
|
3月前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
55 1
vue学习第四章
|
3月前
|
JavaScript 前端开发
vue学习第五章
欢迎来到我的博客,我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。自学前端2年半,正向全栈进发。如果你从我的文章中受益,欢迎关注,我将持续分享更多优质内容。你的支持是我最大的动力!🎉🎉🎉
40 1
|
3月前
|
JavaScript 前端开发
vue学习第六章(条件显示)
欢迎来到我的博客!我是瑞雨溪,一名自学前端两年半的大一学生,擅长JavaScript与Vue,正向全栈进发。本篇介绍v-if、v-else、v-elseif及v-show的使用方法,附带实例演示。希望我的分享能帮到你,欢迎关注,持续更新中!🎉🎉🎉
35 1
|
2月前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
147 1
|
6天前
|
移动开发 JavaScript API
Vue Router 核心原理
Vue Router 是 Vue.js 的官方路由管理器,用于实现单页面应用(SPA)的路由功能。其核心原理包括路由配置、监听浏览器事件和组件渲染等。通过定义路径与组件的映射关系,Vue Router 将用户访问的路径与对应的组件关联,支持哈希和历史模式监听 URL 变化,确保页面导航时正确渲染组件。
|
10天前
|
监控 JavaScript 前端开发
ry-vue-flowable-xg:震撼来袭!这款基于 Vue 和 Flowable 的企业级工程项目管理项目,你绝不能错过
基于 Vue 和 Flowable 的企业级工程项目管理平台,免费开源且高度定制化。它覆盖投标管理、进度控制、财务核算等全流程需求,提供流程设计、部署、监控和任务管理等功能,适用于企业办公、生产制造、金融服务等多个场景,助力企业提升效率与竞争力。
60 12
|
6天前
|
JavaScript 前端开发 开发者
Vue中的class和style绑定
在 Vue 中,class 和 style 绑定是基于数据驱动视图的强大功能。通过 class 绑定,可以动态更新元素的 class 属性,支持对象和数组语法,适用于普通元素和组件。style 绑定则允许以对象或数组形式动态设置内联样式,Vue 会根据数据变化自动更新 DOM。
|
6天前
|
JavaScript 前端开发 数据安全/隐私保护
Vue Router 简介
Vue Router 是 Vue.js 官方的路由管理库,用于构建单页面应用(SPA)。它将不同页面映射到对应组件,支持嵌套路由、路由参数和导航守卫等功能,简化复杂前端应用的开发。主要特性包括路由映射、嵌套路由、路由参数、导航守卫和路由懒加载,提升性能和开发效率。安装命令:`npm install vue-router`。

热门文章

最新文章