如何为同一页面上的不同输入和文本区域设置动态字符计数器,每个输入和文本区域的最大长度不同?

How do I set up a dynamic character counter for different inputs and textareas on the same page with different max lengths on each one?

我有一个包含多个文本输入和一个文本区域输入的产品页面。 3 个文本输入的最大长度为 18,1 个文本输入的最大长度为 5,1 个文本区域的最大长度为 255。如何在不编写多个函数的情况下为每个元素设置字符计数器?

我已经设置了一个基本功能,可以根据 .form-input 的值更改字符计数器 html,但显然它适用于所有计数器。我在将它指定给每个单独的输入和文本区域时遇到问题。

<div class="form-field text-lines" data-product-attribute="input-text">
    <label class="form-label form-label--inlineSmall" for="attribute_text_347">Text Line 1:</label>
    <p id="text-info">Type exactly as you want the text to appear, including upper/lower case.</p>

    <input class="form-input form-input--small" type="text" id="attribute_text_347" name="attribute[347]" maxlength="18">
    <span class="characters-left">Characters Left: <span class="counter">18</span></span>
</div>
$(document).ready(function() {
    let text_max = 18;
    $('.counter').html(text_max);

    $('.text-lines .form-input').keyup(function() {
        let text_length = $('.text-lines .form-input').val().length;
        let text_remaining = text_max - text_length;

        $('.counter').html(text_remaining);
    });
});

我希望每个 input/textarea 的字符计数器在输入特定 input/texarea 时更新。

你在哪里有这个:

let text_length = $('.text-lines .form-input').val().length;
let text_remaining = text_max - text_length;

我觉得你真正想要的是

let text_length = this.value.length;
let max_length = this.getAttribute("maxlength");
let text_remaining = max_length - text_length;

不要再jquery获取文本长度,并获取输入元素的最大长度属性

我使用了您的代码来提高功能。这是一个例子:

$(document).ready(function() {
  const inputs = $('.form-input');
  inputs.each(function(index, element){
    inputLengthCounter($(element).attr('id'));
  });
});

function inputLengthCounter(input_id) {
  const input = document.getElementById(input_id);
  const text_max = input.maxLength;
  const counter = $(input).next('.characters-left').find('.counter');
  $(counter).html(text_max);

  $(input).keyup(function() {
    let text_length = $(this).val().length;
    let text_remaining = text_max - text_length;

    $(counter).html(text_remaining);
  });
}

https://jsfiddle.net/o20q79n8/

它 运行 为每个具有 id 和 maxlength 属性的输入运行 inputLengthCounter。