Запустить функцию PHP на html нажмите кнопку

Мне нужно запустить некоторую функцию PHP при нажатии кнопки. Я знаю, что это не должно использоваться php, а js должен это делать, но что мои функции делают при сборе данных с сервера, когда пользователь спрашивает его. В частности, он получает некоторые пользовательские данные и записывает их в файл, и пользователь должен решить, какие данные будут собраны.
Как я могу это сделать? Я видел почту запустить PHP файл на кнопку нажмите но я все еще не уверен, как использовать его.
Я учусь, так что пожалуйста, не будьте слишком суровы

Я пробовал onclick() и всякие вещи, но это не привело ни к чему полезному

6 ответов


php-файл запускается всякий раз,когда вы обращаетесь к нему через HTTP-запрос, будь то GET, POST, PUT.

вы можете использовать JQuery / Ajax для отправки запроса нажатием кнопки или даже просто изменить URL-адрес браузера для перехода на php-адрес.

в зависимости от данных, отправленных в POST/GET, вы можете иметь оператор switch, выполняющий другую функцию.

указание функции через GET

вы можете использовать этот код: как вызовите функцию PHP из строки, хранящейся в переменной вместе с оператором switch для автоматического вызова соответствующей функции в зависимости от отправленных данных.

Итак, на стороне PHP вы можете иметь что-то вроде этого:

<?php

//see http://php.net/manual/en/function.call-user-func-array.php how to use extensively
if(isset($_GET['runFunction']) && function_exists($_GET['runFunction']))
call_user_func($_GET['runFunction']);
else
echo "Function not found or wrong input";

function test()
{
echo("test");
}

function hello()
{
echo("hello");
}

?>

и вы можете сделать самый простой запрос get, используя адресную строку в качестве тестирования:

http://127.0.0.1/test.php?runFunction=hellodddddd

результаты:

Function not found or wrong input

http://127.0.0.1/test.php?runFunction=hello

результаты:

hello

передача данных

GET запрос через В jQuery

см.:http://api.jquery.com/jQuery.get/

$.get("test.cgi", { name: "John"})
.done(function(data) {
  alert("Data Loaded: " + data);
});

отправить запрос через JQuery

см.:http://api.jquery.com/jQuery.post/

$.post("test.php", { name: "John"} );

получить запрос через Javascript location

см.:http://www.javascripter.net/faq/buttonli.htm

<input type=button 
value="insert button text here"
onClick="self.location='Your_URL_here.php?name=hello'">

чтение данных (PHP)

см. PHP Turotial для чтения пост и получить:http://www.tizag.com/phpT/postget.php

Полезные Ссылки

http://php.net/manual/en/function.call-user-func.php http://php.net/manual/en/function.function-exists.php


если вы хотите сделать запрос сервера, вы должны использовать AJAX, чтобы вы могли отправить нужные параметры на сервер, и он может запускать любой php с этими параметрами.

пример с чистым javascript:

<input type="text" id="name" value="..."/>
<input type="text" id="location" value="..."/>
<input type="button" onclick="ajaxFunction();" value="Submit" />
<div id="ajaxDiv"></div>
<script type="text/javascript">    
    function ajaxFunction(){
        var ajaxRequest;  // The variable that makes Ajax possible!

        try{
            // Opera 8.0+, Firefox, Safari
            ajaxRequest = new XMLHttpRequest();
        } catch (e){
            // Internet Explorer Browsers
            try{
                ajaxRequest = new ActiveXObject("Msxml2.XMLHTTP");
            } catch (e) {
                try{
                    ajaxRequest = new ActiveXObject("Microsoft.XMLHTTP");
                } catch (e){
                    // Something went wrong
                    alert("Your browser broke!");
                    return false;
                }
            }
        }
        // Create a function that will receive data sent from the server
        ajaxRequest.onreadystatechange = function(){
            if(ajaxRequest.readyState == 4){
                var ajaxDisplay = document.getElementById('ajaxDiv');
                ajaxDisplay.innerHTML = ajaxRequest.responseText;
            }
        }
        var name = document.getElementById('name').value;
        var location = document.getElementById('location').value;
        var queryString = "?name=" + name + "&location=" + location;
        ajaxRequest.open("POST", "some.php" + queryString, true);
        ajaxRequest.send(null); 
    }
</script>

пример с jQuery Ajax: http://api.jquery.com/jQuery.ajax/

$.ajax({
  type: "POST",
  url: "some.php",
  data: { name: "John", location: "Boston" }
}).done(function( msg ) {
  alert( "Data Saved: " + msg );
});

вы можете иметь один файл с функциями, вызываемыми, например функции.в PHP

функции.в PHP

<?php
  myFunction($Name, $Location) {
      // etc...
  }
  myFunction2() {
  }
  // ... many functions
?>

некоторые.в PHP

<?php include("functions.php");    
$Name = $_POST['name'];
$Location = $_POST['location'];

myFunction($Name, $Location);

// make what you want with these variables...?>

используйте ajax, простой пример,

HTML-код

<button id="button">Get Data</button>

в JavaScript

var button = document.getElementById("button");

button.addEventListener("click" ajaxFunction, false);

var ajaxFunction = function () {
    // ajax code here
}

альтернативно взглянуть в jquery ajax http://api.jquery.com/jQuery.ajax/


<?php
if (isset($_POST['str'])){
function printme($str){
echo $str;
}

printme("{$_POST['str']}");
}
?>
<form action="<?php $_PHP_SELF ?>" method="POST">
<input type="text" name="str" /> <input type="submit" value="Submit"/>
</form>

используйте запрос AJAX в своем PHP-файле, затем отобразите результат на своей странице без перезагрузки.

http://api.jquery.com/load/ Это простое решение, если вам не нужны данные.


Это зависит от того, какую функцию вы хотите запустить. Если вам нужно что-то сделать на стороне сервера, например, запросить базу данных или установить что-то в сеансе или что-то, что нельзя сделать на стороне клиента, вам нужен AJAX, иначе вы можете сделать это на стороне клиента с помощью JavaScript. Не заставляйте сервер работать, когда вы можете делать то, что вам нужно делать на стороне клиента.

jQuery предоставляет простой способ сделать ajax:http://api.jquery.com/jQuery.ajax/