0
$(function(){
$(".product-item").click(function(){
var sku = $(this).attr("name");
var dataString = "sku="+sku;
$.ajax({
type: "POST",
url: "data.php",
data: dataString,
dataType: 'html',
success: function(){
$("#product").load("shop4.php #product > *", function(){
$("#product").delay(200).fadeOut(400);
$("#product").delay(601).fadeIn();
$(".img-wrap img").delay(500).fadeIn(300);
$(".img-wrap img").delay(300).animate({paddingBottom: "15%"});
$(".img-wrap img").hover(function(){
$(this).animate({
paddingTop: "5%", paddingBottom: "25%"
});
}, function(){
$(this).animate({
paddingTop: "15%", paddingBottom: "15%"
});
});
});
}
});
});
});
當我點擊產品項目後,產品部分淡出,然後淡入所有正確的信息,但PHP不讀取發佈數據,需要注意的是,要獲得點擊功能工作我不得不把這個腳本放在div id產品後面。ajax沒有發佈到php onclick
PHP是簡單的(這是data.php):
<?php
global $sku;
if (isset($_POST['sku'])) {
$sku = $_POST['sku'];
echo $sku;
}
?>
XHR響應
XHR finished loading: "mysite.com/shop4.php". jquery.min.js:4
f.support.ajax.f.ajaxTransport.send jquery.min.js:4
f.extend.ajax jquery.min.js:4
(anonymous function) shop4.php:238
f.event.dispatch jquery.min.js:3
f.event.add.h.handle.i jquery.min.js:3
XHR finished loading: "mysite.com/shop4.php". jquery.min.js:4
f.support.ajax.f.ajaxTransport.send jquery.min.js:4
f.extend.ajax jquery.min.js:4
f.fn.extend.load jquery.min.js:4
$.ajax.success shop4.php:243
f.Callbacks.o jquery.min.js:2
f.Callbacks.p.fireWith jquery.min.js:2
w jquery.min.js:4
f.support.ajax.f.ajaxTransport.send.d
我想指出你有dataType設置爲「html」,但你似乎只是簡單地返回文本。 – TheZ 2012-07-10 17:15:37
shop4.php是什麼樣的?它有一個id產品的元素,什麼是'> *'好處? – 2012-07-10 17:18:27
@Jørgen''*'是爲了確保它不會將div產品加載到div產品中,而只是加載一次。 – kqlambert 2012-07-10 17:30:11