[英]Change select option based on attribute
我试图更改click
的select option
,但我不想使用option value
。 我的代码工作,如果我给我的按钮value='3'
,但我要的是选择一个与data-price="0"
这在我的情况下是一个与value='3'
。
JS:
jQuery(document).ready(function () {
jQuery('#sample-addtocart-button').click(function(){
jQuery('.product-custom-option').val(jQuery(this).attr('value'));
});
});
HTML:
<button value="0" id="sample-addtocart-button" type="button">Free</button>
<select class="product-custom-option">
<option value="">-- Please Select --</option>
<option data-price="10" value="1">£10.00</option>
<option data-price="20" value="2">£20.00</option>
<option data-price="0" value="3">FREE</option>
</select>
任何帮助将不胜感激
您可以使用属性等于选择器来获取选项,然后通过使用prop()
方法设置selected
属性来选择选项。
jQuery(document).ready(function() { jQuery('#sample-addtocart-button').click(function() { jQuery('.product-custom-option option[data-price="' + jQuery(this).attr('value') + '"]').prop('selected', true); }); });
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <button value="0" id="sample-addtocart-button" type="button">Free</button> <select class="product-custom-option"> <option value="">-- Please Select --</option> <option data-price="10" value="1">£10.00</option> <option data-price="20" value="2">£20.00</option> <option data-price="0" value="3">FREE</option> </select>
您可以按属性选择元素,然后在元素上设置selected
属性。
jQuery(document).ready(function () {
jQuery('#sample-addtocart-button').click(function(){
jQuery('.product-custom-option [data-price=' + this.value + ']').prop("selected", true);
});
});
这将选择data-price
属性等于this.value
的值的元素,此属性是.product-custom-option
的后代,并将其selected
属性设置为true
。
如果没有jQuery,它可能看起来像这样:
document.addEventListener("DOMContentLoaded", function () {
document.querySelector('#sample-addtocart-button').addEventListener("click", function(){
document.querySelector('.product-custom-option [data-price=' + this.value + ']').selected = true;
});
});
少数辅助方法总是可以帮助您提高详细程度:
function listen(el, typ, fn, cap) {
el && el.addEventListener(typ, fn, cap)
}
function query(el, sel) {
if (typeof el === "string") {
sel = el;
el = document;
}
return el.querySelector(sel)
}
listen(document, "DOMContentLoaded", function () {
listen(query('#sample-addtocart-button'), "click", function(){
query('.product-custom-option [data-price=' + this.value + ']').selected = true;
});
});
尝试这个:
jQuery('#sample-addtocart-button').click(function(){
var val= jQuery(this).attr('value');
jQuery('.product-custom-option option[data-price='+val+']').prop('selected', true); // it will find the select option with certain data-price and make it selected
});
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.