cd .\Desktop\
npx degit minseung-moon/webpack-template-basic vue3-webpack-template
cd vue3-webpack-template
code . -r
npm i vue@next
npm i -D vue-loader@next vue-style-loader @vue/compiler-sfc
// path : NodeJS에서 파일 및 디렉토리경로 작업을 위한 전역 모듈
const path = require("path");
const HtmlPlugin = require("html-webpack-plugin");
const CopyPlugin = require("copy-webpack-plugin");
const { VueLoaderPlugin } = require('vue-loader')
// export
module.exports = {
// 파일을 읽어들이기 시작하는 진입점 설정
entry: "./src/main.js",
// 결과물(번들)을 반환하는 설정
output: {
// 주석은 기본값!, `__dirname`은 현재 파일의 위치를 알려주는 NodeJS전역변수
// path: path.resolve(__dirname, "dist"),
// filename: "main.js",
clean: true,
},
// 모듈 처리 방식을 설정
module: {
rules: [
{
test : /\.vue$/,
// use 속성에 loader가 하나면 배열로 안해도 된다!
use : 'vue-loader'
},
{
test: /\.s?css$/,
// 순서 중요
use: [
'vue-style-loader',
"style-loader",
"css-loader",
"postcss-loader",
"sass-loader"
],
},
{
test: /\.js$/,
use: ["babel-loader"],
},
],
},
// 번들링 후 결과물의 처리 방식 등 다양한 플러그인들을 설정
plugins: [
new HtmlPlugin({
template: "./index.html",
}),
new CopyPlugin({
patterns: [{ from: "static" }],
}),
new VueLoaderPlugin()
],
// 개발 서버 옵션
devServer: {
host: "localhost",
},
};
<template>
<h1>{{ message }}</h1>
</template>
<script>
export default {
data() {
return {
message : 'Hello Vue!!!'
}
}
}
</script>
import { createApp } from "vue";
import App from "./App.vue";
// import Vue from "vue";
// CDN
// Vue.createApp(App).mount("#app");
// CLI
// import {createApp} from "vue";
createApp(App).mount("#app");
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>webpack</title>
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/reset-css@5.0.1/reset.min.css">
</head>
<body>
<div id="app"></div>
</body>
</html>
// path : NodeJS에서 파일 및 디렉토리경로 작업을 위한 전역 모듈
const path = require("path");
const HtmlPlugin = require("html-webpack-plugin");
const CopyPlugin = require("copy-webpack-plugin");
const { VueLoaderPlugin } = require("vue-loader");
// export
module.exports = {
resolve: {
extensions: [".js", ".vue"],
},
// 파일을 읽어들이기 시작하는 진입점 설정
entry: "./src/main.js",
// 결과물(번들)을 반환하는 설정
output: {
// 주석은 기본값!, `__dirname`은 현재 파일의 위치를 알려주는 NodeJS전역변수
// path: path.resolve(__dirname, "dist"),
// filename: "main.js",
clean: true,
},
// 모듈 처리 방식을 설정
module: {
rules: [
{
test: /\.vue$/,
// use 속성에 loader가 하나면 배열로 안해도 된다!
use: "vue-loader",
},
{
test: /\.s?css$/,
// 순서 중요
use: [
"vue-style-loader",
"style-loader",
"css-loader",
"postcss-loader",
"sass-loader",
],
},
{
test: /\.js$/,
use: ["babel-loader"],
},
],
},
// 번들링 후 결과물의 처리 방식 등 다양한 플러그인들을 설정
plugins: [
new HtmlPlugin({
template: "./index.html",
}),
new CopyPlugin({
patterns: [{ from: "static" }],
}),
new VueLoaderPlugin(),
],
// 개발 서버 옵션
devServer: {
host: "localhost",
},
};
<template>
<img src="~assets/관광고.jpg" alt="관광고">
</template>
npm i -D file-loader
// path : NodeJS에서 파일 및 디렉토리경로 작업을 위한 전역 모듈
const path = require("path");
const HtmlPlugin = require("html-webpack-plugin");
const CopyPlugin = require("copy-webpack-plugin");
const { VueLoaderPlugin } = require("vue-loader");
// export
module.exports = {
resolve: {
extensions: [".js", ".vue"],
// 경로 별칭
alias: {
"~": path.resolve(__dirname, "src"),
assets: path.resolve(__dirname, "src/assets"),
},
},
// 파일을 읽어들이기 시작하는 진입점 설정
entry: "./src/main.js",
// 결과물(번들)을 반환하는 설정
output: {
// 주석은 기본값!, `__dirname`은 현재 파일의 위치를 알려주는 NodeJS전역변수
// path: path.resolve(__dirname, "dist"),
// filename: "main.js",
clean: true,
},
// 모듈 처리 방식을 설정
module: {
rules: [
{
test: /\.vue$/,
// use 속성에 loader가 하나면 배열로 안해도 된다!
use: "vue-loader",
},
{
test: /\.s?css$/,
// 순서 중요
use: [
"vue-style-loader",
"style-loader",
"css-loader",
"postcss-loader",
"sass-loader",
],
},
{
test: /\.js$/,
use: ["babel-loader"],
},
{
test: /\.(png|jpe?g|gif|webp)$/,
use: "file-loader",
},
],
},
// 번들링 후 결과물의 처리 방식 등 다양한 플러그인들을 설정
plugins: [
new HtmlPlugin({
template: "./index.html",
}),
new CopyPlugin({
patterns: [{ from: "static" }],
}),
new VueLoaderPlugin(),
],
// 개발 서버 옵션
devServer: {
host: "localhost",
},
};
<template>
<h1>{{ message }}</h1>
<HelloWorld />
</template>
<script>
import HelloWorld from '~/components/HelloWorld';
export default {
components : {
HelloWorld
},
data() {
return {
message : 'Hello Vue!!!'
}
}
}
</script>