jquery에서 직렬화는 객체를 전송 가능한 바이트 시퀀스로 변환하는 프로세스를 의미합니다. 직렬화는 객체 스트림을 읽고 쓸 때 발생하는 문제를 해결하는 것입니다. 직렬화는 객체 스트림을 처리하는 데 사용되는 메커니즘입니다.
이 튜토리얼의 운영 환경: windows7 시스템, jquery3.6 버전, Dell G3 컴퓨터.
직렬화란 무엇을 의미하나요?
객체 스트림을 처리하는 데 사용되는 메커니즘입니다. 소위 객체 스트림은 객체의 콘텐츠를 스트리밍하는 것입니다. 스트리밍된 객체는 읽고 쓸 수 있으며, 스트리밍된 객체는 네트워크 간에 전송될 수도 있습니다. 직렬화는 객체 스트림을 읽고 쓸 때 발생하는 문제를 해결하는 것입니다.
직렬화: 객체를 전송 가능한 바이트 시퀀스로 변환하는 프로세스를 직렬화라고 합니다.
역직렬화: 바이트 시퀀스를 객체로 복원하는 프로세스를 역직렬화라고 합니다.
왜 직렬화하는가?
정의만 보면 직렬화의 의미를 단번에 이해하기 어려울 것 같은데요. 그러면 직렬화라는 것이 무엇인지 다른 각도에서 추론해 볼 수 있습니다.
사실 직렬화의 궁극적인 목적은 객체를 플랫폼 전반에 걸쳐 저장하고 네트워크를 통해 전송할 수 있도록 하는 것입니다. 우리가 크로스 플랫폼 저장과 네트워크 전송을 수행하는 방식은 IO이고, 우리 IO가 지원하는 데이터 형식은 바이트 배열입니다.
객체를 일방적으로 바이트 배열로 변환하는 것만으로는 충분하지 않고, 일반 바이트 배열이 없으면 객체의 원래 모양을 복원할 수 없기 때문에 객체를 바이트 배열로 변환해야 합니다. 그런 다음 규칙을 공식화합니다. (직렬화), IO 스트림에서 데이터를 읽을 때 이 규칙을 사용하여 객체를 다시 복원합니다(직렬화 해제).
집을 한 곳에서 다른 곳으로 옮기고 싶다면 집을 해체해서 차에 싣고 집의 원래 구조를 그린 그림을 남기고 순서를 바꾸는 것을 연재라고 합니다. 집을 목적지까지 운반한 후 벽돌을 도면에 따라 집의 원래 모습으로 복원하는 과정
jQuery 직렬화 방법
jQuery에는 serialize() 방법과 두 가지 직렬화 방법이 있습니다. serializeArray() 메서드.
1. serialize() 메서드:
serialize() 메서드는 양식 값을 직렬화하여 URL 인코딩된 텍스트 문자열을 생성합니다.
하나 이상의 양식 요소(예: 입력 및/또는 텍스트 상자) 또는 양식 요소 자체를 선택할 수 있습니다.
AJAX 요청을 생성할 때 직렬화된 값을 URL 쿼리 문자열에 사용할 수 있습니다. 이렇게 하면 ajax가 양식 데이터를 제출할 때 각 매개변수를 하나씩 나열할 필요가 없습니다. : $("양식").직렬화().
표준 쿼리 문자열 출력: a=1&b=2&c=3&d=4&e=5
참고: "성공적인 컨트롤"만 문자열로 직렬화됩니다. (즉, 비활성화되지 않은 요소) 버튼을 사용하여 양식을 제출하지 않으면 제출 버튼의 값이 직렬화되지 않습니다. 양식 요소의 값을 시퀀스 문자열에 포함하려면 해당 요소가 name 속성을 사용해야 합니다.
2. serializeArray() 메서드:
serializeArray() 메서드는 양식 값을 직렬화하여 객체 배열(이름 및 값)을 생성합니다.
하나 이상의 양식 요소(예: 입력 및/또는 텍스트 영역) 또는 양식 요소 자체를 선택할 수 있습니다.
이 메서드는 JSON 문자열 대신 JSON 개체를 반환합니다.
반환된 JSON 개체는 개체 배열로 구성되며, 각 개체에는 이름 매개변수와 값 매개변수(값이 비어 있지 않은 경우)라는 하나 또는 두 개의 이름-값 쌍이 포함되어 있습니다.
요소는 비활성화할 수 없으며(비활성화된 요소는 포함되지 않음) 요소에는 이름 속성이 있어야 합니다. 제출 버튼의 값도 직렬화되지 않습니다. 파일 선택 요소에 대한 데이터도 직렬화되지 않습니다.
참고: 1. 비활성화되지 않음, 2. 이름 속성 포함
[권장 학습: jQuery 비디오 튜토리얼, 웹 프론트엔드 비디오]
위 내용은 jquery에서 직렬화는 무엇을 의미합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!