웹 양식은 웹 사이트 및 응용 프로그램에 필수적입니다. 기본 HTML 양식은 기본 기능을 제공하지만 상태, 검증 및 제출을 관리하면 복잡해질 수 있습니다. 구성 요소 중심 접근 방식으로 React는 양식 처리를 단순화하지만 여전히 장황 코드로 이어질 수 있습니다. 가벼운 라이브러리 인 Formik은 이러한 과제를 우아하게 해결하고 상태 관리, 검증 및 제출을 단순화합니다.
이 기사는 Formik을 사용하여 React Form을 구축하여 상태, 검증 및 제출을 처리하는 기능을 보여줍니다. 기본 React 구성 요소로 시작한 다음 Formik을 통합합니다.
제어 된 반응 형태 구축
반응 구성 요소는 상태 및 소품에 의존합니다. HTML 양식 요소는 value
속성을 통해 내부 상태를 유지합니다. 이로 인해 통제되지 않은 구성 요소가됩니다. DOM은 상태를 관리합니다. 그러나 React가 상태를 관리하는 통제 된 구성 요소는 더 나은 통제력과 단일 진실의 원천을 제공합니다.
간단한 통제되지 않은 HTML 양식은 다음과 같습니다.
<div class="formRow"> <label for="email">이메일 주소</label> <input type="email" id="email"> </div> <div class="formRow"> <label for="password">비밀번호</label> <input type="password" id="password"> </div> <button type="submit">제출하다</button>
이것을 제어 된 반응 구성 요소로 변환합니다.
함수 htmlform () { const [email, seteMail] = react.usestate ( ""); const [password, setpassword] = react.usestate ( ""); 반품 (); }
이 접근법은 양식 값에 대한 단일 진실의 소스를 제공하여 더 쉽게 검증 및 성능 최적화를 가능하게합니다.
Formik을 선택하는 이유는 무엇입니까?
React (예 : React Hook Form, Redux Form)에 대한 수많은 양식 관리 라이브러리가 존재합니다. Formik은 다음을 통해 자신을 구별합니다.
- 선언적 접근 : 추상화는 상태, 검증 및 제출을 단순화합니다.
- 탈출 해치 : 추상화에도 불구하고 필요할 때 제어를 제공합니다.
- 공동 위치 : 구성 요소 내에서 형태 관련 논리를 유지합니다.
- 적응성 : 필요한만큼 Formik을 사용하거나 거의 사용하지 않습니다.
- 사용 편의성 : 간단하고 효과적입니다.
Formik을 양식 구성 요소에 통합합시다.
Formik 구현
기본 로그인 양식을 작성하여 세 가지 Formik 사용 방법을 탐색합니다.
-
useFormik
후크 - 반응 컨텍스트와 함께 Formik (
<formik></formik>
)) -
withFormik
고차원 구성 요소
데모에는 formik 및 yup 패키지가 필요합니다.
방법 1 : useFormik
후크
우리의 현재 형태는 비 기능적입니다. useFormik
후크는 Formik 함수 및 변수를 제공합니다. 반환 된 값을 기록하면 내용이 나타납니다.
initialValues
과 onSubmit
핸들러와 함께 useFormik
사용하겠습니다.
// 반응 구성 요소 함수 baseformik () { const formik = useformik ({ InitialValues : {이메일 : "", 암호 : ""}, onsubmit (값) { // 제출 로직을 양식합니다 } }); 반품 (); }
요소를 형성하기위한 결합 형태 :
// 반응 구성 요소 함수 baseformik () { const formik = useformik ({ InitialValues : {이메일 : "", 암호 : ""}, onsubmit (값) { // 제출 로직을 양식합니다 } }); 반품 (); }
이것은 제출 ( onSubmit={formik.handleSubmit}
) 및 입력 상태 ( formik.getFieldProps
통한 value
, onChange
)를 처리합니다. 수동 상태 관리 및 이벤트 처리를 피합니다. Destructuring getFieldProps
및 handleSubmit
코드 선명도를 더욱 향상시킵니다.
그만큼<formik></formik>
구성 요소는 내장 구성 요소와 같은 추가 추상화를 제공합니다<field></field>
,,,<form></form>
, 그리고<errormessage></errormessage>
. 이 구성 요소는 렌더 소품 패턴을 사용합니다.
'formik'에서 {formik, field, form} 가져 오기; 함수 formikrenderProps () { const initialValues = {이메일 : "", 비밀번호 : ""}; const onsubmit = (값) => { 경고 (json.stringify (값, null, 2)); }; 반품 ( <formik initialvalues="{initialValues}" onsubmit="{onSubmit}"> {() => ( <form> <field classname="email formField" name="email" type="email"></field> {/ * ... 다른 형태의 요소 */} </form> )} </formik> ); }
Formik은 상태 및 제출을 처리합니다. 우리는 형태 구조에 중점을 둡니다.
Formik을 사용한 양식 검증
Formik은 양식 수준 ( validate
또는 validationSchema
사용), 필드 레벨 또는 수동 트리거에서 유효성 검사를 제공합니다. 양식 수준 검증은 전체 양식을 한 번에 검증합니다. validate
사용자 정의 유효성 검사 용이며 validationSchema
YUP와 같은 라이브러리를 사용합니다.
validate
사용 예 :
const formik = useformik ({ // ... 검증 : () => { const errors = {}; if (! formik.values.email) {errors.email = "필수"; } // ... 기타 유효성 검사 반환 오류; }, // ... });
Yup과 함께 validationSchema
사용하는 예 :
const formik = useformik ({ // ... validationschema : yup.object (). shape ({ 이메일 : yup.string (). email ( "유효하지 않은 이메일"). 필수 ( "필수"), // ... 기타 유효성 검사 }), // ... });
필드 수준 및 수동 검증도 가능합니다.
방법 3 : withFormik
고차 구성 요소
withFormik
양식 구성 요소를 감싸는 고차 컴포넌트입니다.
실제 사례
오류 메시지 표시 및 사용자 이름을 생성하는 것을 설명하겠습니다.
오류 메시지 표시
Formik은 오류 표시를 단순화합니다. errors
객체 및 표시 메시지를 확인하십시오.
<label htmlfor="email"> 이메일 주소 {formik.touched.email && formik.errors.email} </label>
또는 사용<errormessage></errormessage>
:
<errormessage name="email"></errormessage>
사용자 이름을 생성합니다
Formik의 setValues
이메일에서 사용자 이름을 생성하는 데 사용될 수 있습니다.
onsubmit (값) { formik.setValues ({... value, username :`@$ {values.email.split ( "@") [0]}}); }
결론
Formik은 반응 양식 처리를 크게 단순화합니다. 이 기사는 기본 사항을 다룹니다. 고급 기능 및 사용 사례에 대한 Formik의 문서를 탐색하십시오.
위 내용은 Formik을 사용하여 React의 양식을 처리합니다의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

@keyframesandcsstransitionsdifferincomplexity :@keyframesallowsfordeTailEdanimationsections, whilecsStransitsimplestateChanges.UsecsStransitionSforHovereffects likeToncolorChanges 및@keyframesforintricateanimationspinners.

알고 있습니다. 컨텐츠 관리 시스템 옵션이 수많은 톤을 사용할 수 있으며, 여러 번 테스트했지만 실제로는 아무도 없었습니다. y ' 이상한 가격 책정 모델, 어려운 커스터마이즈, 일부는 전체가되었습니다.

HTML의 일부에서 요소를 사용하여 CSS 파일을 HTML에 연결하면 달성 할 수 있습니다. 1) 태그를 사용하여 로컬 CSS 파일을 연결하십시오. 2) 여러 개의 태그를 추가하여 여러 CSS 파일을 구현할 수 있습니다. 3) 외부 CSS 파일은 다음과 같은 절대 URL 링크를 사용합니다. 4) 파일 경로 및 CSS 파일로드 순서의 올바른 사용을 확인하고 성능을 최적화하면 CSS Preprocessor를 사용하여 파일을 병합 할 수 있습니다.

Flexbox 또는 그리드 선택은 레이아웃 요구 사항에 따라 다릅니다. 1) Flexbox는 탐색 표시 줄과 같은 1 차원 레이아웃에 적합합니다. 2) 그리드는 매거진 레이아웃과 같은 2 차원 레이아웃에 적합합니다. 두 사람은 프로젝트에 사용하여 레이아웃 효과를 향상시킬 수 있습니다.

CSS 파일을 포함시키는 가장 좋은 방법은 태그를 사용하여 HTML 부분에 외부 CSS 파일을 소개하는 것입니다. 1. 태그를 사용하여 외부 CSS 파일을 소개합니다. 2. 작은 조정의 경우 인라인 CSS를 사용할 수 있지만주의해서 사용해야합니다. 3. 대규모 프로젝트는 SASS와 같은 CSS 전 처리기를 사용하여 @Import를 통해 다른 CSS 파일을 가져올 수 있습니다. 4. 성능의 경우 CSS 파일을 병합하고 CDN을 사용해야하고 CSSNANO와 같은 도구를 사용하여 압축해야합니다.

예, YoushouldLearnbothflexBoxAndgrid.1) FlexBoxisIdealforone-Dimensional, FlexiblelayoutSlikenavigationMenus.2) GridexCelsIntwo-Dimensional, ComplexDesignsSuchasmagazinElayouts.3) 결합 된 BothenSlayoutFlexibility 및 HeartingFortructur

자신의 코드를 리팩터링하는 것은 어떤 모습입니까? John Rhea는 자신이 쓴 오래된 CSS 애니메이션을 선택하고 최적화하는 사고 과정을 살펴 봅니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경