1 如何创建vite项目?

step 1 :npm init vite@latestyarn create vite
step2 :
npm init vite@latest my-vue-app --template vuenpm 7+, 需要额外的双横线:
npm init vite@latest my-vue-app -- --template vue# yarn
yarn create vite my-vue-app --template vue

2 如何让vite项目启动时自动打开浏览器?

注:vite针对开发环境,打包环境和预览环境分别定义了三个选项: server、build、preview。 开发环境server类似于webpack中的devServer。

export default ({mode})=>{
return defineConfig({server:{open:true, //vite项目启动时自动打开浏览器},
}
}

3vite启动默认端口为3000?如何更改默认端口?

export default ({mode})=>{
return defineConfig({server:{port:8080, //vite项目启动时自定义端口},
}
}

4 vite如何设置热更新?

vite默认开发环境关闭了热更新。代码更改需要手动更新,设置更改代码自动刷新页面需要设置hmr:true

export default ({mode})=>{
return defineConfig({server:{hmr:true, //开启热更新},
}
}

5vite中如何配置别名路径?

设置resolver选项

import { resolve } from 'path';export default ({mode})=>{
return defineConfig({resolve:{alias:{"@":resolve(__dirname,"src"),"@c":resolve(__dirname,"src/components"),}},
}
}

6 vite中如何设置便捷图片路径引用?

比如图片资源都在src/assets/image目录下,不想在项目中每次都通过require("…/assets/image/1.jpg")这样写一长串去引用。能否通过 类似nuxt中的快速引用?

  <img src="/images/1.png" alt="" />这里直接引用export default ({mode})=>{
return defineConfig({resolve:{alias:{"/images":"src/assets/images/"//这里不能通过path模块解析路径的写法}},
}
}

7如何把vite打包以后的js,css和img资源分别分门别类在js/css/img文件夹中

//由于是处理打包以后的资源,所以需要配置build选项
export default ({mode})=>{
return defineConfig({build:{assetsDir:"static",rollupOptions:{input:{index:resolve(__dirname,"index.html"),project:resolve(__dirname,"project.html")},output:{chunkFileNames:'static/js/[name]-[hash].js',entryFileNames:"static/js/[name]-[hash].js",assetFileNames:"static/[ext]/name-[hash].[ext]"}},},}
}

8如何通过vite给项目配置多个环境?

以开发、测试和生产环境为例

(1)在项目根目录下分别新建.env.development,.env.test,.env.production文件

//.env.devopment文件内容
NODE_ENV="development"
VITE_APP_BASEAPI="https://www.dev.com"
//.env.test文件内容
NODE_ENV="test"
VITE_APP_BASEAPI="https://www.test.com"
//.env.production文件内容
NODE_ENV="production"
VITE_APP_BASEAPI="https://www.production.com"

(2) package.json文件做如下修改

 "scripts": {"dev": "vite --mode development","build": "vite build --mode production","test": "vite build --mode test","preview": "vite preview"},

(3)项目中通过Import.meta.env.VITE_APP_BASEAPI来获取对应环境的值

<template><div><Item></Item></div></template>
<script setup>import { defineComponent, onMounted, ref } from 'vue'import Item from "@c/item.vue"console.log("env", import.meta.env.VITE_APP_BASEAPI)console.log("可选链", obj?.gender || "male")
})
</script>

9 vite中如何配置多入口,进行多页面开发?

step1:在根目录新建一个入口页面以project.html为例,同时在根目录下新建一个project文件夹,在此文件夹新建一个main.js,App.vue

step2:vite.config.js作如下修改:

import { defineConfig,loadEnv ?} from 'vite'
import {resolve} from "path";export default ({mode})=>{return defineConfig({? build:{
? ? rollupOptions:{
? ? ? input:{
? ? ? ? index:resolve(__dirname,"index.html"),
? ? ? ? project:resolve(__dirname,"project.html")
? ? ? },
? ? ?//output:{
? ? ? ?// chunkFileNames:'static/js/[name]-[hash].js',
? ? ? ? //entryFileNames:"static/js/[name]-[hash].js",
? ? ? ? //assetFileNames:"static/[ext]/name-[hash].[ext]"
? ? ? }
? ? },
? },? plugins: [
? ? vue(),
? ]
})}?

step3:vite run dev 启动以后在url加上project.html查看project项目 localhost:3000/project.html

10 如何设置开启生产打包分析文件大小功能?类似_webpack_-bundle-analyzer

//1 安装rollup-plugin-visualizer 插件
npm i rollup-plugin-visualizer
//2 vite.config.js中引入插件
import {visualizer} from "rollup-plugin-visualizer"
export default ({mode:string})=>{const plugins=[ vue(),AutoImport({resolvers: [ElementPlusResolver()],}),Components({resolvers: [ElementPlusResolver()]}),visualizer({open:true,  //注意这里要设置为true,否则无效gzipSize:true,brotliSize:true})];}return  defineConfig({resolve:{alias:{"@":resolve(__dirname,"src"),"/images":"src/assets/images/"}},plugins})

11 如何解决require is not define报错的的问题? 场景: 比如我们assets文件夹下有一个静态的json:

        list:[{shop_id:1,shop_name:'搜猎人艺术生活',products:[{pro_id:101,text:'洗面奶洗面奶洗面奶洗面奶洗面奶洗面奶洗面奶洗面奶',price:480,num:1,img:require("./images/1.png"),sum:480,checked:false//商品选中状态},{pro_id:102,text:'花露水花露水花露水花露水花露水花露水花露水花露水',price:680,num:1,img:require('./images/2.png'),sum:680,checked:false},{pro_id:103,text:'燕麦片燕麦片燕麦片燕麦片燕麦片燕麦片燕麦片燕麦片',price:380,num:1,img:require('./images/3.png'),sum:380,checked:false}],check:false,//店铺选中状态choose:0,//商品选中个数},{shop_id:2,shop_name:'卷卷旗舰店',products:[{pro_id:201,text:'剃须刀剃须刀剃须刀剃须刀剃须刀剃须刀剃须刀剃须刀',price:580,num:1,img:require('./images/4.png'),sum:580,checked:false},{pro_id:202,text:'卫生纸卫生纸卫生纸卫生纸卫生纸卫生纸卫生纸卫生纸',price:780,num:1,img:require('./images/5.png'),sum:780,checked:false}],check:false,choose:0,},],status:false,//全选选中状态allchoose:0,//店铺选中个数allsum:0,//总计价格allnum:0,//总计数量
}
export default fetchData

此时运行你回发现报错:require is not define? 解决办法:

const fetchData={list:[{shop_id:1,shop_name:'搜猎人艺术生活',products:[{pro_id:101,text:'洗面奶洗面奶洗面奶洗面奶洗面奶洗面奶洗面奶洗面奶',price:480,num:1,img:new URL("./images/1.png",import.meta.url).href,sum:480,checked:false//商品选中状态},{pro_id:102,text:'花露水花露水花露水花露水花露水花露水花露水花露水',price:680,num:1,img:new URL('./images/2.png',import.meta.url).href,sum:680,checked:false},{pro_id:103,text:'燕麦片燕麦片燕麦片燕麦片燕麦片燕麦片燕麦片燕麦片',price:380,num:1,img:new URL('./images/3.png',import.meta.url).href,sum:380,checked:false}],check:false,//店铺选中状态choose:0,//商品选中个数},{shop_id:2,shop_name:'卷卷旗舰店',products:[{pro_id:201,text:'剃须刀剃须刀剃须刀剃须刀剃须刀剃须刀剃须刀剃须刀',price:580,num:1,img:new URL('./images/4.png',import.meta.url).href,sum:580,checked:false},{pro_id:202,text:'卫生纸卫生纸卫生纸卫生纸卫生纸卫生纸卫生纸卫生纸',price:780,num:1,img:new URL('./images/5.png',import.meta.url).href,sum:780,checked:false}],check:false,choose:0,},],status:false,//全选选中状态allchoose:0,//店铺选中个数allsum:0,//总计价格allnum:0,//总计数量
}
export default fetchData

注意引用方式的变化:require------->new URL(’./images/5.png’,import.meta.url).href

vite.config.js配置入门与小记相关推荐

  1. Vue 2 中,使用Vite作为前端构建开发工具,替代webpack(一)——vite.config.js配置文件

    Vue 2 中,使用Vite作为前端构建开发工具,替代webpack(一)--vite.config.js配置文件 当前版本 vite@2.3.7和vite@2.4.4 "vite" ...

  2. vue-cli3中的vue.config.js配置

    vue-cli3中的vue.config.js配置 我的跨域是配置通过chrome浏览器的跨域设置,前端修改跨域问题,以此解决跨域的,故没有配置代理: const path = require('pa ...

  3. Vue Cli3 项目 vue.config.js 配置

    Vue Cli3 项目 vue.config.js 配置 配置优化 一.js文件最小化处理 二.分割代码 三.图片资源压缩 四.开启gzip压缩 先看一下优化配置之前的文件大小 通过vue-cli3脚 ...

  4. 【vue.config.js配置configureWebpack的optimization splitChunks页面空白 - DCloud】

    vue.config.js配置configureWebpack的optimization splitChunks页面空白 - DCloud问答

  5. 【Cli下在vue.config.js配置configureWebpack/resolve/alias之无效 - 】

    cli下在vue.config.js配置configureWebpack/resolve/alias无效 - DCloud问答

  6. vue.config.js配置configureWebpack的optimization splitChunks页面空白

    确实通过这种方式解决: vue.config.js配置configureWebpack的optimization splitChunks页面空白 - DCloud问答 原因可能是这个: Taro项目 ...

  7. vue-cli3.x( bate版 ) 中 vue.config.js 配置含义

    vue-cli3.0 中 vue.config.js 配置含义 在vue-cli3.x( bate版 ) 中有些配置需要自己去配置 需要在最外层同级目录下建立 vue.config.js 文件 下面就 ...

  8. vue.config.js配置proxy代理解决跨越;proxy代理报404;

    像我们本地的vue项目运行起来,访问的地址一般是localhost,这个时候请求后台的接口,端口号也不一致,肯定就会存在跨域问题,所以我们要是想正常访问接口的话,就需要解决掉跨域问题. 本文我们是在v ...

  9. webpack之webpack.config.js配置

    webpack之webpack.config.js配置 wbepack.config.js webpack的配置文件详解: ​ 作用: 指示 webpack 干那些活(当你运行 webpack 指令时 ...

最新文章

  1. Activity的用法(三):开启网页 (没有弹出浏览器,不清楚是什么原因)
  2. VMWare下虚拟机ubuntu与宿主机windows文件共享
  3. 【渝粤教育】 国家开放大学2020年春季 1007公司财务 参考试题
  4. 转载:用大白话聊聊分布式系统
  5. Linux之shell脚本(2)
  6. MUI 宫格组件(grid)怎么取消mui-active背景色?(优先级设置问题)- 踩坑篇
  7. 阿里平头哥“生娃”!最强 RISC-V 处理器玄铁 910 诞生!
  8. python学了真的很有用吗-会Python的人工作不会太差?编程课真的有必要学吗?
  9. 引用和使用引用传递参数《一》
  10. android应用程序跳转到系统的各个设置页面
  11. 监视及系统响应的补充FMEA (FMEA-MSR)
  12. spring 使用注解遇到的问题
  13. nfc门禁卡的复制和迁移
  14. 无法启动此程序因为计算机丢失d3dx9,无法启动此程序.因为计算机中丢失d3dx9_43.dll.尝试重新安装改程序以解决问题...
  15. Objective-C分类 (catagory)
  16. AS运行安装失败,真机提示“软件包似乎无效”问题
  17. 用PHP查看微信撤回的消息,python实现文件助手中查看微信撤回消息
  18. System.Data.SQLite 与 Microsoft.Data.Sqlite
  19. apk文件部署到云服务器,上传apk到云服务器
  20. jzoj3234. 阴阳

热门文章

  1. 一键清空朋友圈软件_“一键清空朋友圈”服务走红 收费1元至30元 你清了吗?...
  2. 我们所不了解的远程答题
  3. [AS/400] 基本概念
  4. matlab 雅可比矩阵求取
  5. 科济药业冲刺港股上市:累计亏损超18亿元,高瓴资本突击入股
  6. 精品科技感ppt模板,可以用作工作汇报,年终总结,需要的小伙伴直接拿走
  7. coursera 吴恩达 -- 第二课 Improving Deep Neural Networks :第一周课后习题(3)Gradient Checking
  8. 【Deeplearning】暗影精灵3安装Windows10+Ubuntu18.04双系统及CUDA10.0配置
  9. junction应用
  10. 投资必读书籍-机器学习与量化交易