Home > Web Front-end > Front-end Q&A > How to assign javascript value to PHP

How to assign javascript value to PHP

王林
Release: 2023-05-16 11:39:37
Original
1725 people have browsed it

With the development of front-end technology, JavaScript is used more and more widely. In web applications, it is often necessary to pass some values ​​​​from the front-end page to the back-end PHP for processing, which involves the transfer problem between JavaScript values ​​​​and PHP. This article will introduce several methods of assigning JavaScript values ​​​​to PHP.

1. Use form submission

The most common way to pass JavaScript values ​​to PHP is through form submission. In JavaScript, we can obtain the values ​​of form elements through DOM operations, then assign these values ​​​​to hidden input elements, and finally submit the form to the back-end PHP for processing. The sample code is as follows:

<form action="handle.php" method="post">
  <input type="hidden" name="username" id="username">
  <input type="hidden" name="age" id="age">
  <button type="submit" onclick="submitForm()">提交</button>
</form>

<script>
  function submitForm() {
    var username = document.getElementById("username").value;
    var age = document.getElementById("age").value;
    document.getElementById("username").value = username;
    document.getElementById("age").value = age;
  }
</script>
Copy after login

In this example, we define a form containing two hidden input elements. The values ​​of these two elements are the username and age values ​​obtained in JavaScript. When the submit button is clicked, the submitForm() function is called, the obtained values ​​are assigned to the two hidden elements, and then the form is submitted to the back-end PHP for processing.

When processing the values ​​passed by the form, you can use the $_POST array in PHP to obtain these values. The sample code is as follows:

$username = $_POST['username'];
$age = $_POST['age'];
Copy after login
Copy after login

2. Use AJAX technology

In addition to passing JavaScript values ​​through form submission, another common method is to use AJAX technology. AJAX can send a request to the backend PHP without refreshing the page, thereby passing JavaScript values ​​to PHP for processing. The sample code is as follows:

<script>
  var username = '张三';
  var age = 18;

  var xhr = new XMLHttpRequest();
  xhr.open('POST', 'handle.php', true);
  xhr.setRequestHeader('Content-type', 'application/x-www-form-urlencoded');
  xhr.onreadystatechange = function () {
    if(xhr.readyState == 4 && xhr.status == 200) {
      console.log(xhr.responseText);
    }
  };
  xhr.send('username=' + username + '&age=' + age);
</script>
Copy after login

In this example, we define a JavaScript object containing two variables: username and age. Then an XMLHttpRequest object is created, and the request type and address are specified through the open() method. The Content-type is set to application/x-www-form-urlencoded in the request header. This is because we are going to use the POST method to send the request to the back-end PHP and need to put the data in the request body. Finally, use the send() method to send the data to the backend PHP for processing.

In PHP, we can get these values ​​through the $_POST array. The sample code is as follows:

$username = $_POST['username'];
$age = $_POST['age'];
Copy after login
Copy after login

3. Use Cookie to pass

In addition to form submission and AJAX technology, Cookies can also be used to pass JavaScript values. Cookies are a mechanism for storing data on the client side and passing data between the front-end and back-end. The sample code is as follows:

<script>
  var username = '张三';
  var age = 18;

  document.cookie = 'username=' + username;
  document.cookie = 'age=' + age;
</script>
Copy after login

In this example, we use JavaScript's document.cookie attribute to set the Cookie value. The way to set a cookie is to connect the value and name with an equal sign, and then use semicolons and spaces to separate multiple key-value pairs. In this example, we set the username and age values ​​as cookie values.

In PHP, we can use the $_COOKIE array to get these values. The sample code is as follows:

$username = $_COOKIE['username'];
$age = $_COOKIE['age'];
Copy after login

It should be noted that when using Cookie to transfer values, you need to ensure that the Cookie can be transferred correctly between the front end and the back end. Especially when crossing requests, you may encounter some security issues, and you need to use cookie attributes such as HttpOnly to ensure the security of cookie delivery.

Summary:

This article introduces three methods of assigning JavaScript values ​​​​to PHP: form submission, AJAX technology and Cookie delivery. In actual development, according to different needs, different methods can be selected for data transfer to achieve front-end and back-end data interaction.

The above is the detailed content of How to assign javascript value to PHP. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template