简体   繁体   English

无法使用JavaScript选择最接近的h2元素

[英]Unable to select closest h2 element using JavaScript

I would like to be able to select the closest h2 heading to the fieldset that contains the pizza selection options and set the text for the heading using jQuery. 我希望能够选择最接近包含披萨选择选项的字段集的h2标题,并使用jQuery设置标题文本。 I have so far been unable to do it. 到目前为止,我一直做不到。

HTML: HTML:

   <div id="pizzaForm">
        <fieldset>
            <form class="pure-form">
            <legend>Pizza</legend>
            <label><b>Pizza Type: &nbsp;</b></label>
            <select id="pizza">
                <option name="margarita">Margarita</option>
                <option name="deep-pan">Deep Pan</option>
                <option name="stuffed-crust">Stuffed Crust</option>
            </select>
                <span style="float:right">
                <label><b>Pizza Size: &nbsp;</b></label>
                <select id="pizzaSize">
                    <option name="e-small" data-price="4.99">Extra Small - £4.99</option>
                    <option name="small" data-price="5.99">Small - £5.99</option>
                    <option name="medium" data-price="6.99">Medium - £6.99</option>
                    <option name="large" data-price="8.99">Large - £8.99</option>
                    <option name="e-large" data-price="9.99">Extra Large - £9.99</option>
                    <option name="f-size" data-price="10.99">Family Size - £10.99</option>
                </select>
                </span>
            </form>
        </fieldset>
        <fieldset style = "border-top:0px">
        <form class="pure-form">
        <legend><b>Toppings (99p Each): &nbsp;</b></legend>
        <input type="checkbox" name="onions">Onions</input>
        <input type="checkbox" name="mushrooms">Mushrooms</input>
        <input type="checkbox" name="peppers" >Peppers</input>
        <input type="checkbox" name="olives" >Olives</input>
        <input type="checkbox" name="garlic" >Garlic</input>
        <input type="checkbox" name="peperoni" >Peperoni</input>
        <input type="checkbox" name="cheese" >Pesto</input>
        </form>
        </fieldset>
        <h2 id="cost" style= "float:left; margin-top:-3cm; margin-left: 9cm; border: solid black 2px; padding: 5px"> TEST </h2>
        <br>
    </div>

JS: JS:

$(document).on("change","#pizzaSize", function() {
    $("input[type='checkbox']").prop('disabled', false);
    var selectionPrice = $('option:selected', this).attr('data-price');
    var selectionInt = parseFloat(selectionPrice, 10);
    pizzaCost = selectionInt;
    $(this).closest('h2').text(pizzaCost);
    calculateCost(pizzaCost, toppingCost, sideCost, drinkCost, desertCost, desertSizeCost, drinkSizeCost, sideSizeCost);
});

closest() does only work to get the fieldset for your control. closest()只会为您的控件获取字段集。 If you know that the h2 comes after the fieldset on the same level, you could do: 如果您知道h2在相同级别的字段集之后,则可以执行以下操作:

$(this).closest('fieldset').nextAll('h2').first();

But it depends on what you mean with 'closest'. 但这取决于您对“最接近”的意思。 You might want to have a look at the jQuery tree traversal functions . 您可能想看看jQuery 树遍历函数

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM