본문 바로가기
학습정리/자습

리액트 16~20강 정리

by sunnykim91 2019. 9. 9.

webpack.config.js 파일에서

 

plugin들의 모음이  preset이다.

 

preset-env내에서 어떤식으로 브라우저 지원하게 할지 문자열 알 수 있는 사이트

https://github.com/browserslist/browserslist

 

browserslist/browserslist

🦔 Share target browsers between different front-end tools, like Autoprefixer, Stylelint and babel-preset-env - browserslist/browserslist

github.com

const path = require('path'); // node에서 경로 쉽게 조작하기 위함임 , 그냥 외우자!
const webpack = require('webpack');

module.exports = {
  mode: 'development', // 실서비스에서는 production 으로 바꾼다.
  devtool: 'eval',
  resolve: {
    extensions: ['.js', '.jsx'], // webpack이 알아서 확장자를 찾는다
  },  
  // 제일 중요한 부분
  // 입력
  entry: {
    app: ['./client'],  // client.jsx가 wordRelay를 불러오기때문에 써줄 필요가 없다. 확장자도 생략가능! 대신 resolve써줘야함 위처럼
  },

  module: {
    rules: [{
      test: /\.jsx?/, // 정규표현식 js파일과 jsx파일을 룰을 적용하겠다.
      loader: 'babel-loader',
      options: {
        presets: [
            ['@babel/preset-env', {
                targets: {
                    browsers: ['> 1% in KR'],
                },
                debug: true,
            }],
            '@babel/preset-react'
        ],
        plugins: [],
      }
    }],
  },
  
  // 추가적으로 하고 싶은 것.
  plugins: [
    new webpack.LoaderOptionsPlugin({debug: true}),
  ],

  // 출력
  output: {
    path: path.join(__dirname, 'dist'),  // 현재폴더에 안에 들어있는 dist라는 폴더가 된다. 
                                        // c:desktop/개발자....어디어디 이런거 안치게 해줌
    filename: 'app.js'
  },
}

 

 

 

react에서 form태그안에서는

value와 onChange는 세트로 속성에 넣어주어야한다. 만약 한가지만 넣을거면 defaultValue만 사용.

 

// 클래스형 wordrelay

const React = require('react');  // 쪼갠파일에서 필요한 패키지나 라이브러리 가져오는 부분
const { Component } = React;

class WordRelay extends Component {
  state = {
    word: '서니킴',
    value: '',
    result: '',
  };

  onSubmitForm = (e) => {
    e.preventDefault();
    if(this.state.word[this.state.word.length - 1] === this.state.value[0]) {
      this.setState({
        result: '딩동댕',
        word: this.state.value,
        value: '',
      })
      this.input.focus();
    } else {
      this.setState({
        result: '땡',
        value: '',
      });
      this.input.focus();
    }
  };

  onChangeInput = (e) => {
    this.setState({ value: e.target.value});
  };

  onRefInput = (c) => {
    this.input = c;
  };


  render() {
    return (
      <>
        <div>{this.state.word}</div>
        <form onSubmit={this.onSubmitForm}>
          <input ref={this.onRefInput} value={this.state.value} onChange={this.onChangeInput} />
          <button>입력!</button>
        </form>
        <div>{this.state.result}</div>
      </>
    )
  }
}

module.exports = WordRelay; // 쪼갠 파일을 밖에서도 사용하게 해줌.

 

// Hooks로 만들기

const React = require('react');  // 쪼갠파일에서 필요한 패키지나 라이브러리 가져오는 부분
const { useState, useRef } = React;

const WordRelay = () => {

  const [word, setWord] = useState('써니킴');
  const [value, setValue] = useState('');
  const [result, setResult] = useState('');
  const inputRef = useRef(null);

  const onSubmitForm = (e) => {
    e.preventDefault();
    if(word[word.length - 1] === value[0]) {
      setResult('딩동댕');
      setWord(value);
      setValue('');
      inputRef.current.focus();
    } else {
      setResult('땡');
      setValue('');
      inputRef.current.focus();
    }
  };

  const onChangeInput = (e) => {
    setValue(e.target.value);
  };

  return (
    <>
      <div>{word}</div>
      <form onSubmit={onSubmitForm}>
        <input ref={inputRef} value={value} onChange={onChangeInput} />
        <button>입력!</button>
      </form>
      <div>{result}</div>
    </>
  )
  
}

module.exports = WordRelay; // 쪼갠 파일을 밖에서도 사용하게 해줌.

 

werbapck-dev-server : 내 컴퓨터가 서버가 되어서 동작하게끔 만들어줌. locathost주소로 작동하게끔

react-hot-loader : 코드 수정하면 화면이 자동으로 바뀌게끔 만들어줌.

 

path는 실제의 경로 publicPath 는 가상의 경로

 

 

반응형

'학습정리 > 자습' 카테고리의 다른 글

리액트 21~25강 정리  (0) 2019.09.15
poiemaweb 8~9강 복습  (0) 2019.09.10
리액트 11~15강 정리  (0) 2019.09.08
poiemaweb 6~7강 정리  (0) 2019.09.07
리액트 예습 6~10강  (0) 2019.09.05