9. React 구성하기
Last updated
Was this helpful?
Last updated
Was this helpful?
이번에는 SpringBoot와 React를 이용해 볼 예정이다.
환경 = OSX , JAVA8, Visual Studio code
VScode에 대해 환경을 설치하는 방법은 하단에 Visual Studio Code 설치법에 대해 언급했다.(Maven도 가능하니 따라서 하면 됨)
스프링 부트를 통해 서버 API 구축, UI를 REACT에서 담당
이제 SpringBoot 웹 프로젝트 생성해보자!
spring initializr: Generate Maven 생성
Java 선택
Package , Artifact id 설정
SpringBoot Version 선택
Dependency : DevTools, Spring Web Starter Web 선택
DevTools : 코드가 변경되면 자동으로 Rebuild를 지원해준다.
생성
JSP 와 JSTL을 사용하기 위해 라이브러리를 추가
pom.xml > dependencies 내부에
SpringBoot를 실행해 본다. 방법: vscode terminal에서 'mvn spring-boot:run' 입력하면 서버가 실행됨
터미널에서 'npm init' >> package.json 생성 (질문들이 나오는데 전부 enter)
react 의존 라이브러리 설치
webpack을 통해 react 개발 할 때, 자바스크립트 기능과 jsp에 포함할 .js파일 생성가능 프로젝트의 루트경로에 webpack.config.js 파일을 만든다.
코드 내용
React 소스 경로를 src/main/jsx로 설정
MainPage와 Page1Page.jsx 빌드
빌드 결과 js 파일들을 src/main/webapp/js/react아래 [페이지 이름].bundle.js 로 설정
MainController.java 파일을 생성한다.
~~~
package com.example.demo.Controller;
import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PathVariable;
@Controller public class MainController{
}
src main webapp jsp css
<%@ page language="java" contentType="text/html; charset=utf-8"%> <!doctype html>
${pageName}
</html>
.main { font-size: 1.5em; border-bottom:solid 1px black; } .page1 { font-size:0.8em; background-color:orange; }
// custom.css 파일 import import '../webapp/css/custom.css';
import React from 'react'; import ReactDom from 'react-dom';
class MainPage extends React.Component { render(){ return demo 메인페이지; } } ReactDom.render(,document.getElementById('root'));
// custom.css 파일 import import '../webapp/css/custom.css';
import React from 'react'; import ReactDom from 'react-dom';
class Page1Page extends React.Component { render(){ return demo page1페이지; } } ReactDom.render(,document.getElementById('root'));
node_modules/.bin/webpack --watch -d -d : 개발 시 -p : 운영 시
"script": { "test": "echo \"Error: no test specified\" && exit1", "start": "mvn spring-boot:run", "watch": "node_modules/.bin/webpack --watch -d" }
~~~ 이제 빌드를 할 때, 'npm run watch'로 하면 되고, 'npm run start'로 서버를 실행 할 수 있다.
해당버전은 OSX 대상이므로 윈도우는 위 부분을 수정해주어야 됨!!
빌드가 이루어 졌기 때문에 이지 우리가 만든 페이지를 확인할 수 있다.
해당 경로로 들어가면 작성한 jsx파일로 작성한 모습이 보인다.
Template에 조언사항을 적어놓았습니다. 확인하시면 좀 더 쉽게 이해하실 수 있습니다.
Gyoogle 님의 글에서 OSX에서 사용할 때로 변경해 놓았습니다.
Window를 사용하시는 분은 Gyoogle에서 참고해주세요 :)
MainPage:
Page1Page:
참고 사이트 :
에러가 발생할 시 대처법 :
Template 다운로드 :