③ 프레임워크·라이브러리/vue

뷰 프로젝트 세팅 가이드

개발자 이프로 2022. 2. 6. 15:32
728x90

https://msko.tistory.com/65

 

Vue CLI 없이 Wepack으로 프로젝트 구성(+ ESLint)

1. Vue package 설치 npm i vue@next npm i vue 로 설치 시, Vue2 버전이 설치됨 기본적은 Vue의 문법을 사용하는 용도 2. .Vue 파일을 관리하기 위한 Package 설치 npm i -D vue-loader@next vue-style-loader @v..

msko.tistory.com

 

{
  "name": "vue-setting",
  "version": "1.0.0",
  "description": "bolier settings for vue",
  "main": "index.js",
  "scripts": {
    "start": "SET NODE_ENV=development & webpack-dev-server --mode development --open --hot",
    "build": "webpack --mode production"
  },
  "keywords": [
    "vue",
    "bolier",
    "settings"
  ],
  "author": "leepro",
  "license": "ISC",
  "dependencies": {
    "vue": "3.2.29"
  },
  "devDependencies": {
    "@babel/core": "^7.17.0",
    "@babel/preset-env": "^7.16.11",
    "@vue/compiler-sfc": "3.2.29",
    "babel-loader": "^8.2.3",
    "copy-webpack-plugin": "^10.2.4",
    "css-loader": "^6.6.0",
    "html-webpack-plugin": "^5.5.0",
    "sass-loader": "^12.4.0",
    "style-loader": "^3.3.1",
    "vue-loader": "17.0.0",
    "vue-style-loader": "4.1.3",
    "webpack-cli": "^4.9.2",
    "webpack-dev-server": "^4.7.4"
  }
}

 

 

const path = require("path");
const HTMLPlugin = require("html-webpack-plugin");
const CopyPlugin = require("copy-webpack-plugin");
const { VueLoaderPlugin } = require("vue-loader");

module.exports = {
  entry: "./src/index.js",
  output: {
    clean: true,
    path: path.resolve(__dirname, "dist"),
    filename: "index_build.js",
  },
  module: {
    rules: [
      {
        test: /\.vue$/,
        use: "vue-loader",
      },
      {
        test: /\.s?css$/,
        use: ["vue-style-loader", "style-loader", "css-loader", "sass-loader"],
      },
      {
        test: /\.js$/,
        use: ["babel-loader"],
      },
      {
        test: /\.(ico|png|jpg|jpeg|gif|svg|woff|woff2|ttf|eot|otf)(\?v=[0-9]\.[0-9])?$/,
        use: [
          {
            loader: "url-loader",
            options: {
              name: "[hash].[ext]",
              limit: 10000,
            },
          },
        ],
      },
    ],
  },
  resolve: {
    extensions: [
      ".wasm",
      ".mjs",
      ".js",
      ".jsx",
      ".ts",
      ".tsx",
      ".json",
      ".vue",
    ],
  },
  plugins: [
    new HTMLPlugin({
      template: "./public/index.html",
    }),
    // new CopyPlugin({
    //   patterns: [{ from: "static" }],
    // }),
    new VueLoaderPlugin(),
  ],
  devServer: {
    host: "localhost",
  },
};
728x90