>웹 프론트엔드 >JS 튜토리얼 >JQuery에서 serialize(), serializeArray() 및 param()의 차이점과 사용법 비교

JQuery에서 serialize(), serializeArray() 및 param()의 차이점과 사용법 비교

巴扎黑
巴扎黑원래의
2017-07-03 13:54:261156검색

serialize() 메서드는 DOM 요소의 내용을 문자열으로 직렬화할 수 있는 JQuery 개체에서도 작동합니다. serializeArray() 메서드는 문자열을 반환하지 않지만 DOM 요소를 직렬화하고 JSON을 반환합니다. 데이터 형식 지정

다음은 서버 측 JSP 코드입니다.


<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> 
<% 
request.setCharacterEncoding("UTF-8"); 
String username = request.getParameter("username"); 
String content = request.getParameter("content"); 
out.println("<p class=&#39;comment&#39;><h6> "+username+" :</h6><p class=&#39;para&#39;> "+content+" 
</p></p>"); 
%>

JQuery의 다른 메서드와 마찬가지로 serialize() 메서드도 JQuery 객체에 대해 작동합니다. 이 메서드는 DOM 요소 콘텐츠를 ajax용 문자열로 직렬화할 수 있습니다. 요구. serialize() 메소드를 사용하면 이 페이지의 모든 필드를 제출할 수 있습니다. 코드는 다음과 같습니다.


$("#send").click(function(){ 
$.get("get1.jsp", $("#form1").serialize(), function(data, textStatus) 
$("#resText").html(data); 
});
});

"제출" 버튼을 클릭하면 form1에 속한 모든 양식 요소를 백그라운드로 제출할 수 있습니다. , 필드 추가 양식에서 다시 사용되지 않더라도 스크립트는 계속 작동하며 추가 작업이 필요하지 않습니다.

문자열 모드를 사용할 때 문자 인코딩(중국어 문제)에 주의해야 합니다. 인코딩으로 인해 문제가 발생하지 않도록 하려면 자동으로 인코딩되는 serialize() 메서드를 사용하면 됩니다.

serialize() 메소드는 JQuery 객체에 작용하기 때문에 폼에서 사용할 수 있을 뿐만 아니라 다음 JQuery 코드와 같이 다른 선택기에 의해 선택된 요소에서도 사용할 수 있습니다.


$(":checkbox,:radio").serialize();

checkbox 및 라디오버튼 박스의 값이 문자열 형식으로 직렬화되며, 선택된 값만 직렬화됩니다.

JQuery에는 serialize()와 유사한 메서드인 serializeArray()도 있습니다. 이 메서드는 문자열을 반환하지 않지만 DOM 요소를 직렬화하고 데이터를 JSON 형식으로 반환합니다. JQuery 코드는 다음과 같습니다.


var fields = $(":checkbox,:radio").serializeArray();
console.log(fields); //用FireBug输出

$.param() 메소드는 키/값에 따라 배열이나 객체를 직렬화하는 데 사용되는 serialize() 메소드의 핵심입니다.

예를 들어 일반 객체를 직렬화합니다.


var obj = {a:1,b:2,c:3};
var k = $.param(obj);
alert(k); //输出a=1&b=2&c=3

위 내용은 JQuery에서 serialize(), serializeArray() 및 param()의 차이점과 사용법 비교의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.