更新下拉菜单后更改值
我有一个可供我的产品配置器下拉菜单的选择产品的地方。所选产品具有附加信息(是或否),在选择适当的产品时显示。产品配置器有几种可供选择的产品。更新下拉菜单后更改值
如果其中一个产品具有附加信息“否”,则最终消息为“否”。
如果我现在选择信息从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]
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>
你尝试过这方面的任何JavaScript或jQuery的? – Aarrbee