vite的基本使用(Mhua)

依赖预构建

依赖预构建是vite自带的功能,具体作用如下:
1、把所有依赖的文件,如果是 CommonJS 规范, 将会转化为 ESModule 规范。
2、把第三方库分散的文件合并打包到一起,减少 HTTP 请求。

如果不希望第三方库进行依赖预构建,可在vite.config.js 配置文件进行配置。

import { defineConfig } from "vite";

export default defineConfig({
  optimizeDeps: {
    // exclude:将指定数组的依赖不进行依赖构建
    exclude: ["lodash-es"],
  },
});

环境变量

.env:所有环境都需要用到的环境变量。(包括开发、生产环境)
.env.development:开发环境用到的环境变量(默认情况下vite将我们的开发环境取名为development)
.env.production:生产环境需要用到的环境变量(默认情况下vite将我们的生产环境取名为production)

vite内置 dotenv库, 利用 dotenv 库可读取 .env .env.development .env.production配置文件中的环境变量。

注意:在开发环境中,.env文件和.env.development中存在同名变量时,后者文件会覆盖前者文件中的变量。生产环境也是同理。

  • 获取方式1:在js文件中获取环境变量。注意:环境变量必须以 VITE_ 开头,才能获取到。
console.log(import.meta.env);
  • 获取方式2:在node端中获取环境变量。

1、loadEnv函数:1、调用loadEnv函数时,首先获取 .env 文件的环境变量。2、根据函数中的第一个参数值进行拼接,如: .env.development,并且获取指定文件名的环境变量,存放到一个对象中。

2、process.cwd:返回node进程的工作目录。

console.log(process.cwd()); // C:\Users\Lenovo\Desktop\vite_project

3、代码如下:

import { defineConfig, loadEnv } from "vite";
// 获取开发环境的环境变量
const developmentEnv = loadEnv("development", process.cwd(), "");
// 获取生产环境的环境变量
const productionEnv = loadEnv("production", process.cwd(), "");

拆分配置文件

vite.base.config.js:公共配置文件
vite.dev.config.js:开发环境配置文件
vite.prod.config.js:生产环境配置文件
vite.config.js:用于生成相关配置文件。

// vite.config.js 配置文件内容如下
import { defineConfig } from 'vite';
import viteBaseConfig from "./vite.base.config.js"
import viteDevConfig from "./vite.dev.config.js"
import viteProdConfig from "./vite.prod.config.js"

// 写法1
// const envResolver = {
//   "build": () => ({...viteBaseConfig, ...viteProdConfig}),
//   "serve": () => ({...viteBaseConfig, ...viteDevConfig})
// }

// 写法2
// 策略模式
const envResolver = {
  "build": () => Object.assign({}, viteBaseConfig, viteProdConfig),
  "serve": () => Object.assign({}, viteBaseConfig, viteDevConfig)
}

export default defineConfig(({ command, mode }) => {
  // command: "serve" || "build" (开发环境值为 serve,生产环境值为 build)
  const env = loadEnv(mode, process.cwd(), "")
  return envResolver[command]()
})

vite.config.js 配置文件为什么可以书写成 esmodule的形式呢? 这是因为 vite 在读取 vite.config.js 配置文件的时候会率先解析文件语法,如果发现是 esmodule 规范会直接将 esmodule 规范替换为 CommonJS规范。

环境变量前缀

vite在客户端的环境变量校验前缀默认值是 VITE_,所以我们设置的环境变量只有以 VITE_ 开头的,调用 import.meta.env 才能获取到相关变量。环境变量前缀,可以在vite.config.js配置文件中修改。

import { defineConfig } from "vite"

export default defineConfig({
  // 配置 vite 注入客户端环境变量校验的env前缀
  envPrefix: "hello_"
});

css 配置

一、vite默认对css文件是支持的。
1、vite在读取到main.js中引用 的 css 文件,然后使用fs模块读取 css 文件内容。
2、创建 style 标签,将index.css中的内容拷贝进style标签
3、将style标签插入到 index.html 的head标签中。
4、将该css文件中的内容直接替换为js脚本(方便热更新或css模块化),同时设置Content-type为js,从而让浏览器以JS脚本的形式来执行该css后缀的文件。

二、css 模块化
1、css文件以 module.css结尾(module是一个规范,表示需要开启css模块化)

/* 新建一个main.module.css文件 */
.footer {
  width: 100px;
  height: 100px;
}

2、它会将所有类名进行一定规则的替换。比如:

/* vite 会把 main.module.css文件内容替换为如下 */
._footer_1wr6r_1 {
  width: 100px;
  height: 100px;
};

3、并且会创建一个映射对象。

import main from "./main.module.css";
console.log(main); // { footer: '_footer_1wr6r_1' }

4、将替换后的内容塞进style标签,然后放入head标签中。
在这里插入图片描述

5、将main.module.css内容进行全部抹除,替换为JS脚本。
6、将创建的映射对象在脚本中进行默认导出。
在这里插入图片描述

css 在vite.config.js 相关配置如下:

import { defineConfig, loadEnv } from "vite";

export default defineConfig({
  css: {
    // modules配置最终会丢给 postcss modules 
    modules: {
      // 驼峰,中划线
      // camelCaseOnly: header-content类 转化为 headerContent
      // camelCase:header-content类 转化为 header-content,headerContent
      localsConvention: "camelCase",

      // global 全局
      // local  局部,开启模块化
      scopeBehaviour: "local",

      // 生成类名(方式1)
      // generateScopedName: "[name]_[local]_[hash:5]",
      // 生成类名(方式2)
      // generateScopedName(name, filename, css) {
      //   // name:css文件类名
      //   // filename:当前文件的绝对路径
      //   // css:当前文件的样式
      //   return `${name}_${Math.random(0, 1)}`
      // },

      // hashPrefix:生成hash会根据你的类名去进行生成。如果要生成的hash更加独特,可以配置hashPrefix。
      hashPrefix: "hello",

      globalModulePaths: ["./src/app.module.css"],  // 不参与css模块化的路径
    },
    preprocessorOptions: {  // key: 预处理器名
      // less 配置
      less: {
        math: "always",
        globalVars: {   // 设置全局变量
          mainColor: "red"
        }
      },
      // sass 配置
      sass: {}
    },
    // 文件索引,用于定位样式具体位置
    devSourcemap: true
  },
});

postcss

1、postcss 用于对 css 高级语法进行降级。
2、前缀补全,兼容不同浏览器。

一、新建 postcss.config.js配置文件。
postcss-low-level:语法降级
postcss-compiler:编译插件
postcss-preset-env:该插件一次性把必须的插件都给你装上(包含以上两种)。

// postcss.config.js 配置文件。
const postcssPresetEnv = require("postcss-preset-env");
module.exports = {
  plugin: [postcssPresetEnv(/* pluginOptions */)]
}

别名配置

import { defineConfig} from "vite";
import path from "path";

export default defineConfig({
  resolve: {
    alias: {
      "@": path.resolve(__dirname, "./src"),
      "@assets": path.resolve(__dirname, "./assets/images")
    }
  }
});

文件打包配置

import { defineConfig } from "vite";

export default defineConfig({
  build: {
    rollupOptions: {
      output: {
        // 打包后文件命名
        assetFileNames: "[hash].[name].[ext]"
      }
    },
    // 图片大小分界线:大于 4kb,图片正常打包。小于 4kb,图片会转化为 base64。
    assetsInlineLimit: 4096,  // 4kb
    // 打包后名称,默认是 dist
    outDir: "testDir",
    // 打包后静态目录名称
    assetsDir: "static"
  }
})
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值