์ด์ˆœ๋ช…

๐Ÿ›’ ์Šคํƒ€์ผ์žํŒ๊ธฐ

โ† ๋ฉ”์ธ์œผ๋กœ ๋Œ์•„๊ฐ€๊ธฐ ๋””๋ฒจ๋กœํผ๊ทธ๋ฃน ๊ฒฝ๋ ฅ๊ธฐ์ˆ ์„œ


๐Ÿ“‹ ํ”„๋กœ์ ํŠธ ๊ฐœ์š”

ย  ย 
ํ”„๋กœ์ ํŠธ ์„ค๋ช… ์žํŒ๊ธฐ, ํ‚ค์˜ค์Šคํฌ ์ œํ’ˆ ํŒ๋งค ํ”„๋กœ๊ทธ๋žจ
๊ธฐ์ˆ  ์Šคํƒ Vue2/3, Express
์ฐธ์—ฌ๋„ ํ”„๋ก ํŠธ์—”๋“œ 100%
๊ธฐ๊ฐ„ 2021.08 ~ 2022.05


โญ ์ฃผ์š” ๊ธฐ๋Šฅ

๐Ÿ›๏ธ ์ƒํ’ˆ ํŒ๋งค ์‹œ์Šคํ…œ

๐Ÿ“ฆ ์žํŒ๊ธฐ ์—ฐ๋™

๐Ÿ‘† ํ„ฐ์น˜ ์Šฌ๋ผ์ด๋“œ UX


๐Ÿ›  ๊ธฐ์ˆ ์  ๊ตฌํ˜„

webpack4 โ†’ Vite ์ „ํ™˜

// ๊ธฐ์กด webpack.config.js
module.exports = {
  entry: './src/main.js',
  // ๋ณต์žกํ•œ ์„ค์ •...
};

// vite.config.js
export default defineConfig({
  plugins: [vue()],
  // ๊ฐ„๊ฒฐํ•œ ์„ค์ •
});

์„ฑ๊ณผ: ๋นŒ๋“œ ์†๋„ 50% ๊ฐœ์„ 

GitLab Runner ์ž๋™๋ฐฐํฌ

# .gitlab-ci.yml
stages:
  - build
  - deploy

build:
  stage: build
  script:
    - npm install
    - npm run build

deploy:
  stage: deploy
  script:
    - scp -r dist/* user@server:/var/www/

ํ„ฐ์น˜ ์Šฌ๋ผ์ด๋“œ ๊ตฌํ˜„

// WebAPI touch event ํ™œ์šฉ
element.addEventListener('touchstart', handleTouchStart);
element.addEventListener('touchmove', handleTouchMove);
element.addEventListener('touchend', handleTouchEnd);

function handleTouchMove(e) {
  const touch = e.touches[0];
  const diff = touch.clientX - startX;
  // ์Šฌ๋ผ์ด๋“œ ๋กœ์ง
}


๐Ÿ”ง ํŠธ๋Ÿฌ๋ธ”์ŠˆํŒ…

๋นŒ๋“œ ์†๋„ ๋ฌธ์ œ

์ˆ˜๋™ ๋ฐฐํฌ ๋ฐ˜๋ณต ์ž‘์—…

ํ‚ค์˜ค์Šคํฌ ํ„ฐ์น˜ UX


๐Ÿ’ก ์„ฑ๊ณผ



โ† ๋ฉ”์ธ์œผ๋กœ ๋Œ์•„๊ฐ€๊ธฐ