首页 > 解决方案 > Magento2 - 添加一个在升级前运行良好的小 jquery

问题描述

我正在使用的代码是这样的:

jQuery(document).ready(function($){
    if(window.location.href =='https://mysite/csproduct/vproducts/new/set/4/type/simple/'){
    console.log('ready');
    $("[name='product[vendor_price]']").keyup(function() {
    $("[name='product[price]']").val($(this).val()).change();
    });
    }
});

如果我将代码粘贴到控制台中,它可以工作。即使没有粘贴我正在准备的代码 console.log- 准备好了。除此之外,控制台中没有错误。

这里使用的 HTML 是这样的:

<div class="admin__field _required" data-bind="css: $data.additionalClasses, attr: {'data-index': index}, visible: visible" data-index="vendor_price">       
<label class="admin__field-label" data-bind="attr: {for: uid}, visible: $data.labelVisible" for="CTK9J41">

<span data-bind="attr: {'data-config-scope': $data.scopeLabel}, text: label" data-config-scope="[STORE VIEW]">Vendor Price</span>
</label>   

<div class="admin__field-control" data-bind="css: {'_with-tooltip': $data.tooltip, '_with-reset': $data.showFallbackReset &amp;&amp; $data.isDifferedFromDefault}">
<input class="admin__control-text" type="text" data-bind="
        event: {change: userChanges},
        value: value,
        hasFocus: focused,
        valueUpdate: valueUpdate,
        attr: {
            name: inputName,
            placeholder: placeholder,
            'aria-describedby': noticeId,
            id: uid,
            disabled: disabled
    }" name="product[vendor_price]" aria-describedby="notice-CTK9J41" id="CTK9J41">
    </div>
</div>


<div class="admin__field admin__field-small _required" data-bind="css: $data.additionalClasses, attr: {'data-index': index}, visible: visible" data-index="price">

<span data-bind="attr: {'data-config-scope': $data.scopeLabel}, text: label" data-config-scope="[STORE VIEW]">Price</span>
    </label>

<div class="admin__field-control" data-bind="css: {'_with-tooltip': $data.tooltip, '_with-reset': $data.showFallbackReset &amp;&amp; $data.isDifferedFromDefault}">

<div class="admin__control-addon">                

<input class="admin__control-text" type="text" data-bind="
        event: {change: userChanges},
        value: value,
        hasFocus: focused,
        valueUpdate: valueUpdate,
        attr: {
            name: inputName,
            placeholder: placeholder,
            'aria-describedby': noticeId,
            id: uid,
            disabled: disabled
    }" name="product[price]" aria-describedby="notice-JHLHU2O" id="JHLHU2O">   

<label class="admin__addon-prefix" data-bind="attr: {for: uid}" for="JHLHU2O">

<span data-bind="text: addbefore">₹&lt;/span>
</label>
    </div>
</div>

标签: jquerymagento2

解决方案


Magento 2 使用 Knockout.js 框架来动态构建其前端的某些部分。这个构建也将在 jQueryready事件触发后发生。因此,name='product[vendor_price]'当您查找它时,可能在 DOM 中尚不可用该元素。

使您的事件侦听器工作的一种方法是使用事件委托on

$(document).on("keyup", "[name='product[vendor_price]']", function() {
    $("[name='product[price]']").val($(this).val()).change();
});

注意:与您的问题无关,但尝试使用“input”事件而不是“keyup”:这也将响应通过拖放、上下文菜单(清除、剪切、粘贴)或其他输入所做的更改设备,或者当一个键被按下并重复时。


推荐阅读