Programming70 [Vue] 상태 관리 Vuex란? (개념/ 사용 이유) 서론 이번글에서는 vuex라는 vue에서 컴포넌트간 유기적으로 데이터를 주고받을 수 있는 패턴이자 라이브러리에 대해 알아보려한다. Vuex가 왜 필요할까? Vuex를 알아보기 전 Vue의 특성에 대해 알아보면 이해하기 더 쉬운데, Vue는 가상 DOM을 활용하여 모든 요소를 실시간 반응형 컴포넌트로 생성할 수 있다는 특징이 있다. 그런데 프로젝트의 규모가 커질수록 컴포넌트는 늘어날 수 밖에 없고 늘어난 컴포넌트들 관계에서 데이터를 주고 받는 부모 자식 관계는 점점 복집해질 수 밖에 없다. 이 부모와 자식 관계를 예로 들면, vue를 이용하여 페이지를 만든다하면 header, footer, button, list 등의 여러 컴포넌트로 구성된다. 이렇게 한 페이지에서도 여러 컴포넌트가 합쳐져서 만들어지게 되.. Programming/Vue 2022. 5. 19. [Java] 함수형 프로그래밍 - Function Interface / Custom Functional Interface (개념 / 예제) 서론 이번글에서는 함수형 프로그래밍에서 기초라고 볼 수 있는 Function Interface와 Functional Interface를 Custom하여 구현하는 방법에 대해 정리해보려한다. 우선 기본적인 Function Interface 예제를 적용 전과 후를 작성하여 왜 함수형 프로그래밍을 하는지에 대해 알아보자. Function Interface [Function Interface 적용 전] Adder (Class) import java.util.function.Function; public class Adder implements Function{ @Override public Integer apply(Integer x) { return x + 10; } } FunctionInterface (Cla.. Programming/Java 2022. 5. 12. [Java] SOLID - 의존성 역전 원칙 (DIP / Dependency Inversion Principle)이란? (개념/ 예제) 서론 드디어 마지막 순서인 객체지향 설계 원칙(SOLID)의 DIP에 대해서 알아보자! 객체지향 설계 5대 원칙 SRP(Single Responsibility Principle): 단일 책임 원칙 OCP(Open Closed Priciple): 개방 폐쇄 원칙 LSP(Liskov Substitution Priciple): 리스코프 치환 원칙 ISP(Interface Segregation Principle): 인터페이스 분리 원칙 DIP(Dependency Inversion Principle): 의존성 역전 원칙 DIP(Dependency Inversion Principle) - 의존성 역전 원칙이란? DIP의 뜻을 정의한 내용은 아래와 같다. "고수준 모듈은 저수준 모듈에 의존하면 안된다. 이 두 모듈 .. Programming/Java 2022. 5. 12. [Java] SOLID - 인터페이스 분리 원칙 (ISP / Interface Segregation Principle)이란? (개념/ 예제) 서론 이번 글에서는 저번 글에서 정리한 리스코프의 법칙에 이어 SOLID에서 I에 속하는 ISP에 대해 정리해보겠습니다. 객체지향 설계 5대 원칙 SRP(Single Responsibility Principle): 단일 책임 원칙 OCP(Open Closed Priciple): 개방 폐쇄 원칙 LSP(Liskov Substitution Priciple): 리스코프 치환 원칙 ISP(Interface Segregation Principle): 인터페이스 분리 원칙 DIP(Dependency Inversion Principle): 의존 역전 원칙 ISP(Interface Segregation Principle) - 인터페이스 분리 원칙이란? 이 원칙의 개념은 쉽게 이해하기 위해서는 이름 그대로 인터페이스를 .. Programming/Java 2022. 5. 12. [JAVA] SOLID - 리스코프 치환 원칙 LSP(Liskov Substitution Principle) 서론 이번 글에서는 L에 속하는 리스코브 원칙에 대해 알아보려한다. 객체지향 설계 5대 원칙 SRP(Single Responsibility Principle): 단일 책임 원칙 OCP(Open Closed Priciple): 개방 폐쇄 원칙 LSP(Liskov Substitution Priciple): 리스코프 치환 원칙 ISP(Interface Segregation Principle): 인터페이스 분리 원칙 DIP(Dependency Inversion Principle): 의존 역전 원칙 LSP(Liskov Substitution Priciple) - 리스코프 치환 원칙이란? 서브 타입은 언제든 자신의 기반(부모) 타입으로 교체할 수 있어야 한다는 원칙을 말한다. 이 말을 다시 말해 객체의 상속관계에서.. Programming/Java 2022. 5. 8. [Spring Boot] MyBatis 카멜케이스 변환 방법 (Snake -> Camel Case) 서론 보통 DB 컬럼을 생성할 때 우리는 스네이크케이스를 사용하여 만든다. 예를들어 사용자 이름을 만든다고하면 user_nm 이런식으로 _가 붙여져있는 것을 스네이크케이스라고 한다. 근데 클래스에서 생성하는 변수명은 보통 카멜케이스이다. 예로 userNm 이런식으로 새로운 단어가 합쳐지는 부분을 대문자로 사용하는 것을 카멜케이스라고 한다. 그럼 아래의 예시에서 보면 알겠지만 mybatis에서 쿼리를 돌릴 때의 명과 vo의 명이 다른 것을 알 수 있다. 이때 mybatis 쿼리에서 alias를 사용하여 vo 변수명과 맞춰주어도 되지만 이것은 컬럼 하나씩 다 해줘야 되기때문에 매우 비효율적이다. 그렇다면 이제 간단한 변환방법을 알아보자. 변환 전 상황 1. vo 클래스 (스네이크 케이스로 사용 중) @Get.. Programming/Spring 2022. 5. 2. [Vue] lodash를 이용하여 중복 값을 제거하는 방법 (_uniqBy, _unionBy) 서론 보통 백단에서 중복제거를 하고 화면에서는 해당 값을 받아서 처리하는경우가 많은데, 백단 수정이 불가한 api에서 중복 값을 받게 되었을 때 쉽게 중복을 제거할 수 있는 lodash의 기법을 알아보려한다. 이번글에서는 lodash의 개념보단 vue에서 lodash를 사용하여 중복제거하는 방법에 대해서만 정리한다. npm lodash 설치 방법 npm i lodash 터미널에서 위의 명령어를 입력하여 lodash를 설치하면 끝이다. _uniqBy 위는 lodash 홈페이지에서 가져온 이미지이다. 파라미터 형식은 다음과 같다. _uniqBy(Array, '반환할 속성의 고유 이름')으로 되어있다. 속성의 이름은 본인이 설정하면 된다. _uniqBy 기능 1. 배열 데이터 안의 값에서 중복되는 값들을 제거.. Programming/Vue 2022. 4. 27. [Vue] should always be multi-word-component 에러 해결 방법 (ESLint 설정) 서론컴포넌트를 만들때마다 하나의 단어로 만들면 아래의 에러가 발생하는 현상을 겪었다. 필자는 급한 김에 접두사에 My 또는 다른 단어를 합쳐 처리했는데 매번 이렇게 처리하는건 아닌것같아서 해결방법에 대해 정리하려한다. 에러 발생 문구 1:1 error Component name "Headline" should always be multi-word vue/multi-word-component-names ✖ 1 problem (1 error, 0 warnings) 전체 에러 본문 보기 더보기 Compiled with problems: X ERROR C:\Users\jkan.DESKTOP-IKN64I8\Desktop\vue_study\vue_fastcam\vue-web\src\components\Headlin.. Programming/Vue 2022. 4. 25. C# 윈도우 화상 키보드(OSK) 실행 및 종료 방법 (Win32 API 사용) 서론 태블릿 환경에서 개발 중 텍스트박스에서 PasswordChar 속성을 먹였을 경우 패스워드를 입력할 때 키보드 입력창이 안올라오는 현상을 볼 수 있다. 필자는 이 경우 윈도우에 내장되어있는 화상키보드를 실행하여 처리하였다. 실행방법에 대해 알아보자. 실행 및 종료 방법 실행 방법1 (비추천) Process p = new Process(); p.StartInfo.FileName = "C:\\Windows\\System32\\osk.exe"; p.StartInfo.Arguments = null; p.StartInfo.WindowStyle = ProcessWindowStyle.Normal; p.Start(); System.ComponentModel.Win32Exception (0x80004005): 지정.. Programming/C# 2022. 4. 25. [Vue] 컴포넌트(Component)란 ? (개념 / 특징 / 예제) 서론 이번 글에서는 Vue에서 가장 중요하다고 할 수 있는 컴포넌트의 개념에 대해 알아보려한다. 중요도에 비해 생각보다 정리할 내용은 그리 많지 않으니 가볍게 보면 좋을 것 같다. 컴포넌트(Component)란 ? 화면을 구성할 수 있는 블록을 의미한다. 위의 (그림1)에서 보면알 수 있듯 하나의 Object를 각 레이아웃 별로 컴포넌트로 쪼개서 구성할 수 있다. 특징 화면을 빠르게 구조화하여 일괄적인 패턴으로 개발할 수 있다. 코드를 쉽게 이해하고 재사용할 수 있다. 단위테스트에 용이하다. 위의 특징들이 나올 수 있는 이유는 컴포넌트는 "블록" 개념이기 때문이다. 하나의 블록이기 때문에 구조화하기 쉽고, 재사용할 수 있는 장점이 있으며 추가로 블록 별(기능 별) 단위테스트에도 용이하다. 사용 방법 Me.. Programming/Vue 2022. 4. 21. [Vue] 인스턴스 라이프 사이클(Life Cycle)이란? (개념 / 예제) 서론 Vue에서 인스턴스나 컴포넌트를 생성할 때 생기는 과정들을 라이프 사이클이라 하는데, 이 라이프 사이클 과정중 일어나는 일과 해당 개념들에 대해 알아보도록 하자. 인스턴스 라이프 사이클이란? 인스턴스의 상태에 따라 호출할 수 있는 속성들을 라이프 사이클 속성이라고 한다. 그리고 각 라이프 사이클 속성에서 실행되는 커스텀 로직을 라이프 사이클 훅(Hook)이라고 한다. 라이프 사이클 속성 종류 위의 그림은 인스턴스가 생성되고 나서 화면에 인스턴스가 부착된 후 소멸되기까지의 전체적인 흐름을 나타낸 뷰 인스턴스 라이프 사이클 다이어그램이다. 키워드를 보면 총 8개의 속성이 있다. 이 속성에 대해 하나씩 알아보면 다음과 같다. 1. beforeCreate 인스턴스가 생성되고 나서 가장 처음으로 실행되는 라.. Programming/Vue 2022. 4. 18. [Vue] MVVM 패턴이란? (개념 / 특징 / 장점) 서론 이번에는 마틴 파울러의 프레젠테이션 모델 디자인 패턴의 변형인 MVVM패턴에 대해 정리해보려한다. 바로 알아보도록 하자. MVVM 패턴이란 ? MVVM[모델 - 뷰 - 뷰 모델(Model - View - viewModel)]은 아래와 같은 패턴을 말한다. 마크업 언어나 GUI 코드를 비지니스 로직 또는 백엔드 로직과 분리하여 개발하는 소프트웨어 아키텍처 패턴을 말한다. 이 정의를 다시 정리해보면 화면 앞단(프론트엔드)의 화면 동작과 관련된 로직과 화면 뒷단(백엔드)의 DB 데이터 처리 로직을 분리하여 더 깔끔하게 코드를 구성한다는 말을 뜻한다. MVVM 패턴은 데이터를 가능한 순수한 응용 프로그램 모델에 가깝게 바인딩하는 데이터 바인딩과 프레임워크의 장점을 활용함과 동시에 MVC가 제공하는 기능 요.. Programming/Vue 2022. 4. 18. 이전 1 2 3 4 5 6 다음 💲 많이 본 글