我想看看是否有办法在PHP中执行类似的任务。我使用javascript来更新'boldStuff'id中的字符串与另一个字符串,在这种情况下是用户的名字,当点击提交按钮时。重要的概念是包含'boldStuff'的页面或部分更新而不刷新页面。基本上,我想在PHP中执行类似的功能,而不会在每次有人点击提交按钮时刷新页面。 任何帮助,将不胜感激。
<script type="text/javascript">
function displayMessage(firstName, lastName) {
document.getElementById('boldStuff').innerHTML = firstName + " " + lastName; //prints
}
</script>
<p>Welcome to my website, <b id='boldStuff'>dude</b> </p>
</br>
<div id="hg">
<form>
First name:
<input type="input" name="yourName" /> </br>
First name:
<input type="input" name="yourLast" /> </br>
<input
type="button"
onclick="javascript:displayMessage(form.yourName.value, form.yourLast.value)"
value="Display Message" />
</form>
</div>
</body>
</html>
答案 0 :(得分:1)
PHP在服务器上运行,而不是在浏览器中运行。它无法直接与浏览器中加载的页面进行交互。 PHP可以生成一个页面并将其发送到浏览器进行显示,但这就是故事的结尾。如果您想在不重新加载的情况下操作页面,则需要客户端技术。这意味着99.9%的情况下使用Javascript。
如果您需要服务器上的某些内容,您可以使用Javascript获取PHP脚本的结果并将其插入页面而不重新加载,但即使可以涉及PHP,也将执行所有客户端操作通过Javascript。
答案 1 :(得分:0)
你的html文件应该类似于:
<html>
<head>
<script type="text/javascript" src="jquery-1.7.1.min.js"></script>
<script type="text/javascript" >
$(document).ready(function(){
$("form#submit").submit(function() {
// we want to store the values from the form input box, then send via ajax below
var fname = $('#fname').attr('value');
var lname = $('#lname').attr('value');
$.ajax({
type: "POST",
url: "ajax.php",
data: "fname="+ fname +"& lname="+ lname,
success: function(){
$('form#submit').hide(function(){$('div.success').fadeIn();});
}
});
return false;
});
});
</script>
<meta http-equiv="Content-Type" content="text/html; charset=windows-1255">
<title>Insert title here</title>
</head>
<body>
<form id="submit" method="post">
<fieldset><legend>Enter Information</legend>
<label for="fname">Client First Name:</label>
<input id="fname" class="text" type="text" name="fname" size="20" />
<label for="lname">Client Last Name:</label>
<input id="lname" class="text" type="text" name="lname" size="20" />
<button class="button positive"> Add Client </button>
</fieldset>
</form>
<div class="success" style="display: none;">Client has been added.</div>
</body>
</html>
和ajax.php
<?php
include ("../../inc/config.inc.php");
// CLIENT INFORMATION
$fname = htmlspecialchars(trim($_POST['fname']));
$lname = htmlspecialchars(trim($_POST['lname']));
$addClient = "INSERT INTO clients (fname,lname) VALUES ('$fname','$lname')";
mysql_query($addClient) or die(mysql_error());
?>
我从[在此输入链接描述] [1]
复制此代码[1]:http://www.ryancoughlin.com/2008/11/04/use-jquery-to-submit-form/我测试了。