serii81
@serii81
Я люблю phр...

Как правильно задавать пути к шрифтам для vite?

Всем привет.
Хочу прикрутить сборку vite в wordpress.
В основном работает, но есть проблемы с путями к шрифтам и к картинкам, добавленные через scss.

Главный файл, который подключаю в vite - main.js, в нем подключаю my.scss а уже в нем шрифты.
@font-face {
	font-family: Comfortaa;
	font-display: swap;
	src: url("../fonts/Comfortaa-Bold.woff2") format("woff2"), url("../fonts/Comfortaa-Bold.woff") format("woff");
	font-weight: 700;
	font-style: normal;
}


V8TkVwk.png

Шрифты находится в src/fonts

vite.config.js
import { defineConfig } from "vite";
import liveReload from "vite-plugin-live-reload";
import vue from "@vitejs/plugin-vue";

// import { chunkSplitPlugin } from "vite-plugin-chunk-split";

const { resolve } = require("path");
const fs = require("fs");
const path = require("path");

// https://vitejs.dev/config
export default defineConfig({
  plugins: [
    vue(),
    liveReload(__dirname + "/**/*.php"),
  ],

  // config
  root: "",
  base: process.env.NODE_ENV === "development" ? "/" : "/dist/",

  build: {
    // output dir for production build
    outDir: resolve(__dirname, "./dist"),
    emptyOutDir: true,

    // emit manifest so PHP can find the hashed files
    // manifest: true,
    manifest: false,

    // esbuild target
    target: "es2018",

    // our entry
    rollupOptions: {
      input: {
        main: resolve(__dirname + "/main.js"),
      },

      output: {
        entryFileNames: `[name].js`,
        chunkFileNames: `[name].js`,
        assetFileNames: `[name].[ext]`,
      },
    },

    // minifying switch
    minify: true,
    write: true,
  },

  css: {
    devSourcemap: true,
  },

  server: {
    // required to load scripts from custom host
    cors: true,

    strictPort: true,
    port: 3000,

    // serve over http
    https: false,
    hmr: {
      host: "localhost",
      //port: 443
    },
  },

  // required for in-browser template compilation
  // https://v3.vuejs.org/guide/installation.html#with-a-bundler
  resolve: {
    alias: {
      // vue: 'vue/dist/vue.esm-bundler.js'
      // "@": path.resolve(__dirname, "src"),
    },
  },
});


И ошибка в браузере.
pR1Uv3C.png

Загрузил проект на Github

Заранее благодарен.
  • Вопрос задан
  • 3935 просмотров
Решения вопроса 1
serii81
@serii81 Автор вопроса
Я люблю phр...
Нашел решение.
В fonts.scss
@font-face {
  font-family: Inter;
  font-display: swap;
  src: url("/wp-content/themes/bs-base-vite/assets/fonts/Inter-Bold.woff2") format("woff2"),
  url("/wp-content/themes/bs-base-vite/assets/fonts/Inter-Bold.woff") format("woff");
  font-weight: 700;
  font-style: normal;
}
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
22 нояб. 2024, в 02:56
10000 руб./за проект
22 нояб. 2024, в 00:55
500 руб./за проект
21 нояб. 2024, в 23:30
300000 руб./за проект