Project | React - Webucks Clone Coding [Mission 4]
14525 ワード
[Mission 4]コーヒー詳細ページ讃機能の実装
右上のHeartボタンをクリックすると、Heartの色が赤になればいいです.また押すとHeartが元に戻ります
⭐️ My Thoughts
これまでのClone Coding Project
と同様に、右上のHeartをクリックすると、色を変えるために(賛ボタンのように)、React
を利用して実現されたプロセスです.違いは、アイコンをロードするプロセスがHTML
とは異なり、JavaScript
ではなくReact
を使用してクリックに関する機能を実現することである.
📲 インプリメンテーションコード
- JSX
import React from 'react';
import { Link } from 'react-router-dom';
import './Login.scss';
import { useNavigate } from 'react-router-dom';
import { useState } from 'react';
function Login() {
const navigate = useNavigate(); // 페이지 이동을 위한 useNavigate()
const goToList = () => {
navigate("/list");
};
const [saveID, saveIDchange] = useState(''); // ID 입력을 위한 State
const [savePW, savePWchange] = useState(''); // PW 입력을 위한 State
return (
<section>
<h1>WeBucks</h1>
<div className="input">
<input type="text" placeholder="전화번호, 사용자 이름 또는 이메일" class="userid"
onChange={(e) => saveIDchange(e.target.value)} />
</div>
<div className="input">
<input type="password" placeholder="비밀번호" className="pw"
onChange={(e) => savePWchange(e.target.value)} />
<button className="hide">show&hide</button>
</div>
<div className="btn">
<button className="but" disabled={
saveID.includes('@') && savePW.length >= 5 ?
false : true
} // 위와 같이 버튼의 disabled 속성에 삼항연산자 조건을 걸어주고, 이에 따른 disabled 속성을 반환해주면 원하는 기능을 구현할 수 있다.
onClick={goToList}>로그인</button>
</div>
<div className="forget">
<Link to='Detail'>비밀번호를 잊으셨나요?</Link>
</div>
</section>
);
}
export default Login
- CSS (SASS)
.btn {
display: flex;
justify-content: center;
margin-top: 20px;
.but {
height: 45px;
width: 32%;
border-radius: 10px;
border: none;
color: white;
background-color: #add3eb;
font-size: 17px;
.but:enabled {
background-color: blue;
cursor: pointer;
}
}
}
🐳 に感銘を与える
React
のJSX
構文では、if
文は使用できません.삼항연산자
を利用して条件文を表現することを学びました.また함수
または컴포넌트
を通じてif
を使うのが面倒なときは、このように使ったほうがいいと思います.
Reference
この問題について(Project | React - Webucks Clone Coding [Mission 4]), 我々は、より多くの情報をここで見つけました
https://velog.io/@peaceminusone/Project-React-Webucks-Clone-Coding-Mission-4
テキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol
import React from 'react';
import { Link } from 'react-router-dom';
import './Login.scss';
import { useNavigate } from 'react-router-dom';
import { useState } from 'react';
function Login() {
const navigate = useNavigate(); // 페이지 이동을 위한 useNavigate()
const goToList = () => {
navigate("/list");
};
const [saveID, saveIDchange] = useState(''); // ID 입력을 위한 State
const [savePW, savePWchange] = useState(''); // PW 입력을 위한 State
return (
<section>
<h1>WeBucks</h1>
<div className="input">
<input type="text" placeholder="전화번호, 사용자 이름 또는 이메일" class="userid"
onChange={(e) => saveIDchange(e.target.value)} />
</div>
<div className="input">
<input type="password" placeholder="비밀번호" className="pw"
onChange={(e) => savePWchange(e.target.value)} />
<button className="hide">show&hide</button>
</div>
<div className="btn">
<button className="but" disabled={
saveID.includes('@') && savePW.length >= 5 ?
false : true
} // 위와 같이 버튼의 disabled 속성에 삼항연산자 조건을 걸어주고, 이에 따른 disabled 속성을 반환해주면 원하는 기능을 구현할 수 있다.
onClick={goToList}>로그인</button>
</div>
<div className="forget">
<Link to='Detail'>비밀번호를 잊으셨나요?</Link>
</div>
</section>
);
}
export default Login
.btn {
display: flex;
justify-content: center;
margin-top: 20px;
.but {
height: 45px;
width: 32%;
border-radius: 10px;
border: none;
color: white;
background-color: #add3eb;
font-size: 17px;
.but:enabled {
background-color: blue;
cursor: pointer;
}
}
}
Reference
この問題について(Project | React - Webucks Clone Coding [Mission 4]), 我々は、より多くの情報をここで見つけました https://velog.io/@peaceminusone/Project-React-Webucks-Clone-Coding-Mission-4テキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol