0

我有一个 T 恤页面,用户需要在其中选择颜色和尺寸(请参见此处的示例

当用户单击颜色(带有链接的图像)时,我需要填充“尺寸”下拉列表。

将用于填充外观的彩色图像/链接的代码如下所示:

<a  onclick="document.getElementById('productColor10474717').value='120';" class="colorlink" href="https://www.ni-dieu-ni-maitre.com/tshirt_image.php?a=10474717&color=120" target="tshirt_image">

(在此链接中,颜色代码为 120)

我已经制作了一个 php 脚本来获取必须在下拉列表中填充的结果: https ://ni-dieu-ni-maitre.com/_test/tshirt_ajax.php?checkshop=266497&checkproducttype=210&stockcolor=2

"&stockcolor" 是颜色代码的变量。其他 2 个变量必须保持不变

php 页面将返回如下内容:

[{"optionValue":2, "optionDisplay": "2"},{"optionValue":3, "optionDisplay": "3"},{"optionValue":4, "optionDisplay": "4"},{"optionValue":5, "optionDisplay": "5"},{"optionValue":6, "optionDisplay": "6"}]

我真的是 AJAX 的新手,我不知道如何在 tshirt 页面上实现 AJAX 以使用颜色代码变量从 php 页面获取结果,然后将其填充到下拉框中,我需要帮助它

非常感谢!

4

1 回答 1

1

使php文件打印结果如

<option value="optionValue">optionResult</option>
<option>.......</option>
<option>.......</option>

将 id="stockcolor" 添加到每个 (a) 元素并删除超链接和 onclick javascript,例如:

<a id="63" class="colorlink" href="#">
    <img src="https://image.spreadshirt.com/image-server/v1/appearances/63" width="24" height="24" class="cnormal">
</a>

安装 jquery(将此行添加到文档的开头):

<script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>

然后使用ajax

$(document).ready(function(){
    $.ajax({
        type: "post",
        url: "Untitled-3.php?checkshop=266497&checkproducttype=210&stockcolor=" + $('#productColor10474717').val(),
        success: function(data){
            $('select#size').html(data);
    }
    });


    $('a.colorlink').click(function(){
    var stockcolor = $(this).attr('id'),
        checkshop = 266497,
        checkproducttype = 210;

    $.ajax({
        type: "post",
        url: "tshirt_ajax.php?checkshop=" + checkshop + "&checkproducttype=" + checkproducttype + "&stockcolor=" + stockcolor,
        beforeSend: function(){
            $('#productColor10474717').val(stockcolor);
        },
        success: function(data){
            $('select#size').html(data);
            $('#tshirt_image').attr('src', 'https://www.ni-dieu-ni-maitre.com/tshirt_image.php?a=10474717&color=' + stockcolor)
        }
    });

    });
});
于 2013-03-03T19:07:41.000 回答