- vừa được xem lúc

[React JS] Xử lý form đơn giản hơn với React-hook-form

0 0 33

Người đăng: Tuấn Lê

Theo Viblo Asia

Quản lý form state form trong react js luôn là 1 vấn đề phức tạp, trước đây xử lý form với formilk trong react khá phổ biến nhưng trong thời gian gần đây, React-hook-form nổi lên khá mạnh mẽ với 1 số ưu điểm: cách viết đơn giản, linh động do sử dụng hook, dung lượng rất nhẹ, ngoài ra vấn đề Performance của react-hook-form cũng là tốt hơn rất nhiều, tham khảo tại đây.

Tạo form với react-hook-form

Cài đặt react-hook-form

npm install react-hook-form

Để tạo 1 đối tượng quản lý state trong react-hook-form ta dùng hook useForm. Có 1 số thuộc tính cần lưu ý:

  • register: hàm nhận vào name của field và trả về object bao gồm các thuộc tính name, onChange, onBlur, max/minLenght, required... dùng để đăng ký cho form lắng nghe các thay đổi của element.
  • handleSubmit: xử lý việc submit form, ngăn form submit khi chưa validate, nhận vào callback xử lý logic submit form với data từ các field.
  • formState: trạng thái khi có sự kiện thay đổi, bao gồm các thuộc tính errors, isValid, touchedFields,...
const form = useForm(); const { register, handleSubmit, formState: { errors },
} = form;

Gắn các thuộc tính form vào các field tương ứng.

 <FormControl isInvalid={errors.email}> <FormLabel htmlFor="email">Email</FormLabel> <Input {...register("email")} /> {errors.email && ( <FormErrorMessage> {errors.email.message} </FormErrorMessage> )}
</FormControl> <FormControl isInvalid={errors.phone}> <FormLabel htmlFor="phone">Số điện thoại</FormLabel> <Input {...register("phone")} /> {errors.phone && ( <FormErrorMessage> {errors.phone.message} </FormErrorMessage> )}
</FormControl>

Validate react-hook-form với yup

Thay vì tự tạo các schema để validate form thì mình thường sử dụng yup, nó sẽ khá nhanh chóng và dễ sử dụng. Cài đặt resolver của react-hoom-form và yup:

npm install @hookform/resolvers yup

Tạo schema và gắn resolver vào form

const phoneRegExp = /^((\\+[1-9]{1,4}[ \\-]*)|(\\([0-9]{2,3}\\)[ \\-]*)|([0-9]{2,4})[ \\-]*)*?[0-9]{3,4}?[ \\-]*[0-9]{3,4}?$/; const schema = yup.object().shape({ email: yup .string() .email("Vui lòng nhập đúng định dạng email.") .required("Vui lòng nhập email."), phone: yup .string() .required("Vui lòng nhập số điện thoại.") .matches( phoneRegExp, "Vui lòng nhập đúng định dạng số điện thoại." ),
}); const form = useForm({ resolver: yupResolver(schema),
});

Code toàn bộ form hoàn chỉnh, mình có dùng thêm thư viện chakra-ui cho đẹp 😅

import { Box, Button, Flex, FormControl, FormErrorMessage, FormLabel, Heading, Input,
} from "@chakra-ui/react";
import { yupResolver } from "@hookform/resolvers/yup";
import React from "react";
import { useForm } from "react-hook-form";
import * as yup from "yup"; FormPage.propTypes = {}; function FormPage(props) { const phoneRegExp = /^((\\+[1-9]{1,4}[ \\-]*)|(\\([0-9]{2,3}\\)[ \\-]*)|([0-9]{2,4})[ \\-]*)*?[0-9]{3,4}?[ \\-]*[0-9]{3,4}?$/; const schema = yup.object().shape({ email: yup .string() .email("Vui lòng nhập đúng định dạng email.") .required("Vui lòng nhập email."), phone: yup .string() .required("Vui lòng nhập số điện thoại.") .matches( phoneRegExp, "Vui lòng nhập đúng định dạng số điện thoại." ), }); const form = useForm({ resolver: yupResolver(schema), }); const { register, handleSubmit, formState: { errors }, } = form; const handleSubmitForm = (data) => { console.log(data); console.log("Handle submit...."); }; return ( <Flex justify={"center"} direction={"column"} align={"center"}> <Heading>Form</Heading> <Box w={"600px"}> <form onSubmit={handleSubmit(handleSubmitForm)}> <Flex direction={"column"} gap={5}> <FormControl isInvalid={errors.email}> <FormLabel htmlFor="email">Email</FormLabel> <Input {...register("email")} /> {errors.email && ( <FormErrorMessage> {errors.email.message} </FormErrorMessage> )} </FormControl> <FormControl isInvalid={errors.phone}> <FormLabel htmlFor="phone">Số điện thoại</FormLabel> <Input {...register("phone")} /> {errors.phone && ( <FormErrorMessage> {errors.phone.message} </FormErrorMessage> )} </FormControl> <Box> <Button type="submit">Submit</Button> </Box> </Flex> </form> </Box> </Flex> );
} export default FormPage;

Preview:

Bài viết này mình có đề cập qua cách đơn giản để sử dụng react-hook-form trong react, nhìn chung nếu so sánh với các thư viện khác thì đây là một thư viện khá tốt, nhược điểm duy nhất chắc là nó là hook nên không dùng được trong class component, còn lại thì không có gì để chê 🤗.

Bình luận

Bài viết tương tự

- vừa được xem lúc

Ssr react app với express.js và next.js (phần 2)

Tiếp tục với post Ssr react app với express.js và next.js đã viết ở post https://viblo.asia/p/ssr-react-app-voi-expressjs-va-nextjs-bWrZnyqYKxw.

0 0 94

- vừa được xem lúc

Sử dụng Context trong React theo cách đơn giản nhất

Sử dụng Context trong React theo cách đơn giản nhất. Bạn đã bao giờ gặp trường hợp một Prop được yêu cầu bởi một component ở mọi nơi trong hierarchy tree.

0 0 54

- vừa được xem lúc

React Hook router

Giới thiệu chung. React Router là một thư viện nhẹ cho phép bạn quản lý và xử lý việc định tuyến cho ứng dụng React của mình.

0 0 223

- vừa được xem lúc

Ssr react app với express.js và next.js

Chúng ta phải khẳng định rằng React là một sự lựa chọn tuyệt vời để xây dựng nên các ứng dụng web chất lượng cao. Tuy nhiên, mọi thứ sẽ trở nên phức tạp hơn, bạn cần tìm hiểu về client-side routing, page layout...Tại một số điểm bạn sẽ cần trang của mình load nhanh hơn, như thế mọi thứ sẽ trở nên ph

0 0 44

- vừa được xem lúc

[Node JS + React JS] - Phần 1 - Cài đặt cơ bản

Chào mọi người, lại là mình đây, sau chuỗi ngày vọc về server với hàng tá các command line khó nhớ thì hãy cùng mình đổi gió một xíu với series này nhé =]]. . . Node JS + React JS - Cài đặt cơ bản.

0 0 119

- vừa được xem lúc

Một số thư viện hỗ trợ Animation cho ReactJS

Why. Bạn đang dạo quanh Internet và thi thoảng bắt gặp những giao diện website cực kì sáng tạo và mượt mà, những slider, button, animation như Mobile App vậy.

0 0 141