Запустить функцию 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/