2017-10-16 89 views
0

解决此代码,但找不到错误。 下面的代码如下:将数据从PHP然后HTML然后jQuery然后回到PHP

$ _ POST从PHP填充属性

<button class="final-buy-now-btn" type="submit" 
book="<?php echo $_POST['book'];?>" 
productId="<?php echo $thisProductId?>" 
value="<?php echo $thisProductId ?>" 
<?php if($book === 'christmas'){ echo "country=\"".$thiscountry."\" "; 
echo "city=\"".$thiscity."\">";} ?> 
<?php if($book === 'birthday'){ echo "bday=\"".$bday."\" "; 
echo "month=\"".$month."\">";} ?> 

<a>Buy Now</a> 
</button> 

之后我打电话最终买-现在-BTN我期望能够使错误,但我无法找到它:

$('.final-buy-now-btn').click(function(event){ 
     var book = $(this).attr("book"); 
     var productId = $(this).attr("productId");      

     if(book === "christmas"){ 
      var country = $(this).attr("country"); 
      var city = $(this).attr("city"); 
      $.ajax({ 
       type: 'POST',    
       url: '../../wp-admin/admin-ajax.php', 
       data: { 'action' : 'add_item_meta_data_to_cart_item', 
        'book' : book, 'productId' : productId, 
        'country' : country,'city' : city}, 
       success: function (res) { 
        if (res) { 
         window.location = 'index.php/cart/'; 
        } 
       } 
      }) 
     } 
     if(book === "birthday"){ 
      var month = $(this).attr("month"); 
      var bday = $(this).attr("bday"); 
      $.ajax({ 
       type: 'POST',    
       url: '../../wp-admin/admin-ajax.php', 
       data: { 
        'action' : 'add_item_meta_data_to_cart_item', 
        'book' : book,'productId' : productId, 
        'month' : month,'bday' : bday}, 
       success: function (res) { 
        if (res) {      
         window.location = 'index.php/cart/'; 
        } 
       } 
      }) 
     } 
    }); 

然后终于从被调用的行动,这是我的PHP函数, 生日越来越返回值,但圣诞节没有什么是被退回。

function add_item_meta_data_to_cart_item($cart_item_data, $product_id, $variation_id) { 
    $item_meta_data = filter_input(INPUT_POST, 'item_meta_data'); 
    $item_meta_data = json_decode($item_meta_data); 

    echo "<pre>"; 
    print_r($item_meta_data); 
    echo "</pre>"; 
+0

你应该检查(和张贴)按钮的HTML(由你的第一块php呈现),并检查(和张贴)你的ajax成功函数中res的值。您应该使用开发人员工具F12控制台选项卡检查javascript错误,并使用网络选项卡检查ajax帖子以及您发送/接收的数据。 – James

+0

@詹姆斯,我跟着控制台和谷歌浏览器我可以看到,我的JavaScript中的所有变种都被填充,但当ajax调用所有var的重置为null – Hazo

+0

只有当第一个if语句为真,第二个if声明我没有得到这个问题,我得到我所有发布的值到最后一个PHP文件 – Hazo

回答

3

简短的回答是,你有错字:

if(book === "chritmas"){

您在JavaScript代码忘记字母s

其他的事情

您应该: 使用输入类型隐藏取代属性或将属性替换为数据城市,数据手册

删除属性<a>按钮

+0

虽然你是对的,并且我在我的代码中修复了这个问题,但我仍然遇到同样的问题 – Hazo

+0

尝试使用console.log()在JavaScript中查找问题 – Rafael

0

看着你的代码,它不会显示你正在关闭按钮标记。在月份属性之后尝试使用额外的>此片段。

<button class="final-buy-now-btn" type="submit" 
book="<?php echo $_POST['book'];?>" 
productId="<?php echo $thisProductId?>" 
value="<?php echo $thisProductId ?>" 
<?php if($book === 'christmas'){ echo "country=\"".$thiscountry."\" "; 
echo "city=\"".$thiscity."\">";} ?> 
<?php if($book === 'birthday'){ echo "bday=\"".$bday."\" "; 
echo "month=\"".$month."\">";} ?>> 

<a>Buy Now</a> 
</button> 

如果仍无法正常工作,通过https://validator.w3.org/运行页面看HTML输出,看看他们是其他任何语法错误。

as rafael mentioned:data-field是命名标签属性的最佳实践。

相关问题