목차
방법 1: JSON 사용
방법 2: serialize() 및 unserialize() 사용
메서드 3: HTML5 데이터-* 속성을 사용하세요
방법 4 : AjaxTransport 사용
백엔드 개발 PHP 문제 PHP 배열을 js에 전달하는 방법

PHP 배열을 js에 전달하는 방법

May 19, 2023 pm 05:45 PM

프런트엔드와 백엔드 분리 추세가 계속 강화되면서 프런트엔드가 백엔드 데이터와 상호 작용해야 하는 경우가 점점 더 많아지고 있습니다. 이 경우 프런트엔드는 백엔드에서 처리한 데이터를 가져올 수 있어야 하며, 백엔드는 일반적으로 배열 형식으로 데이터를 반환합니다. 따라서 PHP 배열을 JS에 어떻게 전달하는가가 매우 중요한 문제가 되었습니다.

이 기사에서는 독자가 프런트엔드 및 백엔드 데이터와 상호 작용할 때 백엔드에서 반환된 데이터를 더 편리하게 얻고 처리할 수 있도록 PHP 배열을 전송하는 몇 가지 일반적인 방법을 소개합니다. 구체적인 방법은 다음과 같습니다.

방법 1: JSON 사용

현재 프론트엔드와 백엔드 데이터 상호작용을 위한 가장 일반적인 솔루션은 JSON을 사용하는 것입니다. JSON(JavaScript Object Notation)은 읽고 쓰기 쉽고 기계에서 쉽게 구문 분석하고 생성할 수 있는 경량 데이터 교환 형식이므로 데이터 교환에 매우 적합합니다. PHP에는 PHP 배열을 JSON 형식으로 변환한 다음 AJAX 기술을 사용하여 프런트 엔드로 전송하고 JSON.parse()를 사용하여 JavaScript가 직접 조작할 수 있는 객체로 변환할 수 있는 json_encode() 함수가 내장되어 있습니다. .

PHP 코드를 사용하여 배열을 JSON으로 변환:

$myArray = array("name" => "Tom", "age" => "18", "gender" => "male");
$json = json_encode($myArray);
로그인 후 복사
로그인 후 복사

프런트 엔드에서 AJAX를 사용하여 JSON 데이터 가져오기:

var request = new XMLHttpRequest();
request.open('GET', 'my_array.php', true);

request.onload = function() {
  if (request.status >= 200 && request.status < 400) {
    var data = JSON.parse(request.responseText);
    console.log(data);
  } else {
    console.log("Error!");
  }
};

request.send();
로그인 후 복사

위 코드에서는 XMLHttpRequest 개체를 사용하여 서버에서 데이터를 요청하고 JSON을 사용합니다. .parse() 데이터를 가져오는 메서드 JSON 형식 문자열을 JavaScript 개체로 변환합니다.

방법 2: serialize() 및 unserialize() 사용

데이터를 전송할 때 데이터 구조를 고려할 필요가 없다면 serialize() 및 unserialize() 함수를 사용하는 것이 좋습니다.

serialize() 함수는 변수를 문자열로 직렬화하고, unserialize() 함수는 문자열을 원래 데이터 유형으로 복원할 수 있습니다. PHP에서는 serialize()를 사용하여 배열을 문자열로 직렬화한 다음 AJAX를 사용하여 데이터를 가져온 다음 역직렬화할 수 있습니다.

PHP 코드를 사용하여 배열 직렬화:

$myArray = array("name" => "Tom", "age" => "18", "gender" => "male");
$serializedData = serialize($myArray);
로그인 후 복사

프런트 엔드에서 AJAX를 사용하여 직렬화된 문자열 가져오기:

var request = new XMLHttpRequest();
request.open('GET', 'my_array.php', true);

request.onload = function() {
  if (request.status >= 200 && request.status < 400) {
    var data = request.responseText;
    console.log(data);
  } else {
    console.log("Error!");
  }
};

request.send();
로그인 후 복사

다음으로 unserialize() 메서드를 사용하여 이를 PHP 개체로 역직렬화할 수 있습니다.

$unserializedData = unserialize($serializedData);
print_r($unserializedData);
로그인 후 복사

메서드 3: HTML5 데이터-* 속성을 사용하세요

간단한 데이터만 전송해야 하고 AJAX 요청을 사용할 필요가 없다면 HTML5 데이터- 속성을 통해 PHP 배열을 프런트엔드로 전달할 수 있습니다. data- 속성은 프런트 엔드에서 데이터 바인딩을 구현하기 위해 페이지 요소의 사용자 정의 데이터를 저장하는 데 사용할 수 있는 사용자 정의 속성입니다. 먼저 HTML 요소에 data-* 속성을 정의한 다음 데이터를 PHP에서 JSON 형식 문자열로 변환하고 마지막으로 PHP를 사용하여 이를 페이지에 출력할 수 있습니다.

PHP 코드를 사용하여 배열을 JSON으로 변환하고 이를 data-* 속성으로 출력합니다.

$myArray = array("name" => "Tom", "age" => "18", "gender" => "male");
$json = json_encode($myArray);

echo '
This is my div
';
로그인 후 복사

다음으로 JavaScript를 통해 이 요소를 가져오고 data-json 속성을 JavaScript 개체로 구문 분석할 수 있습니다.

var myDiv = document.getElementById("myDiv");
var jsonData = JSON.parse(myDiv.dataset.json);
console.log(jsonData);
로그인 후 복사

방법 4 : AjaxTransport 사용

때때로 프런트엔드 및 백엔드 데이터와 상호 작용할 때 백엔드 처리를 용이하게 하기 위해 일부 매개변수를 사용자 정의해야 합니다. 이 경우 jQuery에서 AjaxTransport를 사용할 수 있습니다. AjaxTransport를 사용하면 AJAX 요청을 보내기 전에 PHP 배열의 백엔드 처리를 용이하게 하기 위해 요청 헤더에 사용자 정의 매개변수를 추가하는 등 일부 사용자 정의 작업을 수행할 수 있습니다.

PHP 코드를 사용하여 배열을 JSON으로 변환합니다.

$myArray = array("name" => "Tom", "age" => "18", "gender" => "male");
$json = json_encode($myArray);
로그인 후 복사
로그인 후 복사

사용자가 AJAX 요청을 보낼 때 요청 헤더에 이 JSON 데이터를 추가할 수 있습니다.

$.ajaxTransport("+json", function(options, originalOptions, xhr) {
  xhr.setRequestHeader("X-JSON", json);
});
로그인 후 복사

백엔드 PHP에서는 다음 위치에 사용자 정의 데이터를 추가할 수 있습니다. PHP 배열을 얻기 위해 매개변수 정의에 기반한 요청 헤더:

$myArray = json_decode($this->request->header('X-JSON'));
로그인 후 복사

요약하자면, 다양한 방법을 사용하여 PHP 배열을 JavaScript로 전송할 수 있으며 특정 상황에 따라 가장 적절한 솔루션을 선택해야 합니다. 전체적으로 이러한 방법을 익히면 개발자는 프런트엔드 및 백엔드 데이터와 보다 유연하게 상호 작용하고 개발 효율성을 향상시킬 수 있습니다.

위 내용은 PHP 배열을 js에 전달하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

OWASP Top 10 PHP : 일반적인 취약점을 설명하고 완화하십시오. OWASP Top 10 PHP : 일반적인 취약점을 설명하고 완화하십시오. Mar 26, 2025 pm 04:13 PM

이 기사는 PHP 및 완화 전략의 OWASP Top 10 취약점에 대해 설명합니다. 주요 문제에는 PHP 응용 프로그램을 모니터링하고 보호하기위한 권장 도구가 포함 된 주입, 인증 파손 및 XSS가 포함됩니다.

PHP 8 JIT (정시) 편집 : 성능 향상 방법. PHP 8 JIT (정시) 편집 : 성능 향상 방법. Mar 25, 2025 am 10:37 AM

PHP 8의 JIT 컴파일은 자주 실행되는 코드를 컴퓨터 코드로 컴파일하여 성능을 향상시켜 계산이 많은 응용 프로그램에 도움이되고 실행 시간을 줄입니다.

PHP 보안 파일 업로드 : 파일 관련 취약점 방지. PHP 보안 파일 업로드 : 파일 관련 취약점 방지. Mar 26, 2025 pm 04:18 PM

이 기사는 코드 주입과 같은 취약점을 방지하기 위해 PHP 파일 업로드 보안에 대해 설명합니다. 파일 유형 유효성 검증, 보안 저장 및 오류 처리에 중점을 두어 응용 프로그램 보안을 향상시킵니다.

PHP 암호화 : 대칭 대 비대칭 암호화. PHP 암호화 : 대칭 대 비대칭 암호화. Mar 25, 2025 pm 03:12 PM

이 기사는 PHP의 대칭 및 비대칭 암호화에 대해 논의하여 적합성, 성능 및 보안 차이를 비교합니다. 대칭 암호화는 더 빠르고 벌크 데이터에 적합하지만 안전한 키 교환에는 비대칭이 사용됩니다.

PHP 인증 & amp; 승인 : 보안 구현. PHP 인증 & amp; 승인 : 보안 구현. Mar 25, 2025 pm 03:06 PM

이 기사에서는 PHP에서 강력한 인증 및 승인을 구현하여 무단 액세스를 방지하고 모범 사례를 자세히 설명하고 보안 향상 도구를 권장합니다.

PHP API 요율 제한 : 구현 전략. PHP API 요율 제한 : 구현 전략. Mar 26, 2025 pm 04:16 PM

이 기사는 토큰 버킷 및 누출 된 버킷과 같은 알고리즘을 포함하여 PHP에서 API 요율 제한을 구현하고 Symfony/Rate-Limiter와 같은 라이브러리 사용 전략에 대해 설명합니다. 또한 모니터링, 동적 조정 요율 제한 및 손도 다룹니다.

PHP 입력 유효성 검증 : 모범 사례. PHP 입력 유효성 검증 : 모범 사례. Mar 26, 2025 pm 04:17 PM

기사는 내장 함수 사용, 화이트리스트 접근 방식 및 서버 측 유효성 검사와 같은 기술에 중점을 둔 보안을 향상시키기 위해 PHP 입력 유효성 검증에 대한 모범 사례를 논의합니다.

PHP CSRF 보호 : CSRF 공격 방지 방법. PHP CSRF 보호 : CSRF 공격 방지 방법. Mar 25, 2025 pm 03:05 PM

이 기사는 CSRF 토큰, 동일한 사이트 쿠키 및 적절한 세션 관리를 포함하여 PHP의 CSRF 공격을 방지하는 전략에 대해 설명합니다.

See all articles