2017-02-17 209 views
0

我有一个可供我的产品配置器下拉菜单的选择产品的地方。所选产品具有附加信息(是或否),在选择适当的产品时显示。产品配置器有几种可供选择的产品。更新下拉菜单后更改值

如果其中一个产品具有附加信息“否”,则最终消息为“否”。

如果我现在选择信息从No更改为Yes的产品,那么在没有页面刷新的情况下,最终消息也应更改为“Yes”。

的选择框代码如下:

 <select name="<?php echo $ot['option_type']; ?>"> 
     <?php foreach ($ot['gp_child'] as $key => $child) { $child_id = $child['child_id']; ?> 
     <option value="<?php echo $child_id; ?>" id="<?php echo $ot['option_type'] . '-' . $child_id; ?>" data-hide="<?php echo $child['child_to_hide']; ?>"><?php echo $child['name']; ?></option> 
     <?php } ?> 
     </select> 

我要显示的最后消息是:

<?php if ($child['info'][$field_name] == 'No') { ?> 
     <h5>Diese Produktekonfiguration ist für den CH-Strassenverkehr Zugelassen: <span class="red">No</span></h5> 
    <?php } else { ?> 
     <h5>Diese Produktekonfiguration ist für den CH-Strassenverkehr Zugelassen: <span class="green">Yes</span></h5> 
    <?php } ?> 

这对初始选择的产品能正常工作,但当然没有按”当我在下拉菜单中更改数值时不会改变。我需要添加什么才能使其工作?

附加信息 - 如果我选择在选择框不同的值,那么同样在下面的字段中的值被更新:

 <?php foreach ($gp_child_info as $field_name => $field_text) if($child['info'][$field_name]) { ?> 
     <div><?php echo $field_text; ?>: <?php echo $child['info'][$field_name]; ?></div> 
     <?php } ?> 

此字段$孩子[“信息”] [$ FIELD_NAME]含有是/否应该触发最终消息的值。

有多达5行用于选择产品的下拉菜单,并且它们中的每个在字段$ child ['info'] [$ field_name]中都有Yes/No值。因此,只要其中一行的值为“否”,最后的消息也是“否”。

print_r($ ot ['gp_child']);数组([53] => Array([child_id] => 53 [info] =>数组([product_id] => 53 [gp_parent_id] => 0 [name] => abart [description] => [数组] meta_title] => test [meta_description] => [meta_keyword] => [tag] => 1234ZV [model] => test [sku] =>是 [upc] => [ean] => [jan] => [isbn] => [mpn] => [location] => [quantity] => -1 [delivery_days] => 14 [stock_status] => Nicht an Lager [image] => catalog/car-logo/abarth.png [manufacturer_id] => [manufacturer] => [price] => 100.0000 [special] => [reward] => [points] => 0 [tax_class_id] => 0 [date_available] => 2017-02-10 [weight ] => 0.00kg [weight_class_id] => 1 [length] => 0.00cm [width] => 0.00cm [height] => 0.00cm [length_class_id] => 1 [minus] => 1 [rating] => 0 [reviews] => 0 [minimum] => 1 [sort_order] => 1 [status] => 1 [date_added] => 2017-02-15 14:30:33 [date_modifi编辑] => 2017-02-17 17:17:22 [已观看] => 42 [股票] => Nicht an Lager)[image] =>阵列([popup] =>http://2302.speedone.ch/image/cache/catalog/car-logo/abarth-600x400.png [thumb] =>http://2302.speedone.ch/image/cache/catalog/car-logo/abarth-50x50.png [swap ] =>http://2302.speedone.ch/image/cache/catalog/car-logo/abarth-50x50.png)[name] => abart [attributes] => Array()[price] => CHF 100.00 [special] => [tax] => CHF 100.00 [nocart] => [child_to_hide] =>))

在其触发是结束时的值/无消息是[SKU]

+0

你尝试过这方面的任何JavaScript或jQuery的? – Aarrbee

回答

0

PHP是服务器端脚本语言和根本无法做到这一点。你需要的是客户端站点编程。

其中之一是jQuery的这将是更加得心应手:

HTML:

<select class="select-name" name="<?php echo $ot['option_type']; ?>"> 
    <?php foreach ($ot['gp_child'] as $key => $child) { $child_id = $child['child_id']; ?> 
    <option data-sku="<?php echo $child['info']['sku']; ?>" value="<?php echo $child_id; ?>" id="<?php echo $ot['option_type'] . '-' . $child_id; ?>" data-hide="<?php echo $child['child_to_hide']; ?>"><?php echo $child['name']; ?></option> 
    <?php } ?> 
</select> 

<div class="message"> 
<?php if ($child['info'][$field_name] == 'No') { ?> 
    <h5>Diese Produktekonfiguration ist für den CH-Strassenverkehr Zugelassen: <span class="red">No</span></h5> 
<?php } else { ?> 
    <h5>Diese Produktekonfiguration ist für den CH-Strassenverkehr Zugelassen: <span class="green">Yes</span></h5> 
<?php } ?> 
</div> 

JQUERY:

<script> 
$(".select-name").on("change",function(){ 
var length = $(".select-name option:selected[data-sku=No]").length; 
if(length > 0) { // at least one is no 
    $(".message").html("<h5>Diese Produktekonfiguration ist für den CH-Strassenverkehr Zugelassen: <span class='red'>No</span></h5>"); 
} else { 
    $(".message").html("<h5>Diese Produktekonfiguration ist für den CH-Strassenverkehr Zugelassen: <span class='green'>Yes</span></h5>"); 
} 
}); 
</script> 

工作的代码片段在这里:

$(".select-name").on("change",function(){ 
 
    var value = $(this).find("option:selected").text(); 
 
    if(value == "No") { 
 
     $(".message").html("<h5>Diese Produktekonfiguration ist für den CH-Strassenverkehr Zugelassen: <span class='red'>No</span></h5>"); 
 
    } else { 
 
     $(".message").html("<h5>Diese Produktekonfiguration ist für den CH-Strassenverkehr Zugelassen: <span class='green'>Yes</span></h5>"); 
 
    } 
 
    });
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<select class="select-name" name=""> 
 
    <option selected>No</option> 
 
    <option>Yes</option> 
 
</select> 
 

 
<div class="message"> 
 
    <h5>Diese Produktekonfiguration ist für den CH-Strassenverkehr Zugelassen: <span class="red">No</span></h5> 
 
</div>

+0

我试过了你的建议,但这还没有起作用。我已经添加了一些额外的信息在我最初的帖子....谢谢 – Chris

+0

你有没有在你的文件中添加像http://code.jquery.com/jquery-latest.js这样的jquery文件? –

+0

是的...... jquery在那里 – Chris