javascript-如果未选择第一个下拉菜单,则禁用第二个下拉菜单
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript-如果未选择第一个下拉菜单,则禁用第二个下拉菜单,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含4648字,纯文字阅读大概需要7分钟。
内容图文
如果未选择第一个下拉菜单,我想禁用第二个下拉菜单,有没有办法用JavaScript做到这一点?因此,想法是:如果未选择第一个下拉菜单,则必须禁用第二个下拉菜单.我只是想说我不能在下拉列表中添加任何ID或任何类,所有类和ID都是动态生成的,因此html代码将保持不变,我使用的是Magento平台.
HTML结构:
<div id="product-options-wrapper" class="product-options">
<div class="opts-container">
<div class="counter">1</div>
<label class="required"><em>*</em>First Option</label>
<div class="input-box">
<select id="attribute1211" class="required-entry super-attribute-select" name="super_attribute[1211]">
<option value="">Choose an Option...</option>
<option value="1747" price="0" data-label="vinyl matt">Vinyl Matt</option>
<option value="1748" price="0" data-label="vinyl silk">Vinyl Silk</option>
<option value="1749" price="0" data-label="vinyl soft sheen">Vinyl Soft Sheen</option>
<option value="1746" price="0" data-label="high gloss">High Gloss</option>
<option value="1745" price="0" data-label="eggshell">Eggshell</option>
<option value="1740" price="0" data-label="diamond eggshell">Diamond Eggshell</option>
</select>
</div>
</div>
<div class="opts-container">
<div class="counter">2</div>
<label class="required"><em>*</em>Size</label>
<div class="input-box">
<select id="attribute1219" class="required-entry super-attribute-select" name="super_attribute[1219]">
<option value="">Choose an Option...</option>
<option value="1718" price="0" data-label="5 litre">5 Litre</option>
<option value="1719" price="0" data-label="2.5 litre">2.5 Litre</option>
<option value="1714" price="0" data-label="1 litre">1 Litre</option>
</select>
</div>
</div>
</div>
生成super属性的PHP代码:
<dl>
<?php foreach($_attributes as $_attribute): ?>
<?php
$_rendered = false;
foreach ($_renderers as $_rendererName):
$_renderer = $this->getChild('attr_renderers')->getChild($_rendererName);
if (method_exists($_renderer, 'shouldRender') && $_renderer->shouldRender($_attribute, $_jsonConfig)):
$_renderer->setProduct($_product);
$_renderer->setAttributeObj($_attribute);
echo $_renderer->toHtml();
$_rendered = true;
break;
endif;
endforeach;
if (!$_rendered):
?>
<dt><label class="required"><em>*</em><?php echo $_attribute->getLabel() ?></label></dt>
<dd<?php if ($_attribute->decoratedIsLast){?> class="last"<?php }?>>
<div class="input-box">
<select name="super_attribute[<?php echo $_attribute->getAttributeId() ?>]" id="attribute<?php echo $_attribute->getAttributeId() ?>" class="required-entry super-attribute-select">
<option><?php echo $this->__('Choose an Option...') ?></option>
</select>
</div>
</dd>
<?php endif; ?>
<?php endforeach; ?>
</dl>
解决方法:
如果可以使用属性“名称”,我的建议是:
$(function () {
$('select[name="super_attribute[1219]"]').hide().parents().slice(0,2).hide()
$('select[name="super_attribute[1211]"]').on('change', function (e) {
if ($(this).find('option:selected').index() === 0) {
$('select[name="super_attribute[1219]"]').hide().parents().slice(0,2).hide();
} else {
$('select[name="super_attribute[1219]"]').show().parents().slice(0,2).show();
}
});
});
<script src="https://code.jquery.com/jquery-1.12.3.min.js"></script>
<div id="product-options-wrapper" class="product-options">
<div class="opts-container">
<div class="counter">1</div>
<label class="required"><em>*</em>First Option</label>
<div class="input-box">
<select id="attribute1211" class="required-entry super-attribute-select" name="super_attribute[1211]">
<option value="">Choose an Option...</option>
<option value="1747" price="0" data-label="vinyl matt">Vinyl Matt</option>
<option value="1748" price="0" data-label="vinyl silk">Vinyl Silk</option>
<option value="1749" price="0" data-label="vinyl soft sheen">Vinyl Soft Sheen</option>
<option value="1746" price="0" data-label="high gloss">High Gloss</option>
<option value="1745" price="0" data-label="eggshell">Eggshell</option>
<option value="1740" price="0" data-label="diamond eggshell">Diamond Eggshell</option>
</select>
</div>
</div>
<div class="opts-container">
<div class="counter">2</div>
<label class="required"><em>*</em>Size</label>
<div class="input-box">
<select id="attribute1219" class="required-entry super-attribute-select" name="super_attribute[1219]">
<option value="">Choose an Option...</option>
<option value="1718" price="0" data-label="5 litre">5 Litre</option>
<option value="1719" price="0" data-label="2.5 litre">2.5 Litre</option>
<option value="1714" price="0" data-label="1 litre">1 Litre</option>
</select>
</div>
</div>
</div>
如果无法使用ID和属性“名称”,则可能的解决方案可能仅基于HTML结构.如果这样的结构始终相同,则可以选择第一个选择:
$('div div div select').eq(0)
对于第二个选择:
$('div div div select').eq(1)
另一种替代方法是将jQuery filter应用到具有特殊属性的元素中,这些元素包含数字…
内容总结
以上是互联网集市为您收集整理的javascript-如果未选择第一个下拉菜单,则禁用第二个下拉菜单全部内容,希望文章能够帮你解决javascript-如果未选择第一个下拉菜单,则禁用第二个下拉菜单所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。