Задать вопрос

Как исправить ошибку «Cannot read properties of undefined»?

https://codepen.io/pen/

На просторах гугла достаточно много различный решений данной ошибки, но то, что мне нужно так и нашлось. Проблема в том, что есть функция, которая должна переиспользоватся несколько раз с изменение аргументов для параметров функции, дабы избежать повторного написания одного и того же кода.
В качестве параметров выступают левое и правое значение input range, а так же диапозон между ними, который функция должна высчитывать автоматически, в следствии чего, он будет выделен синим, как в коде прописано.

Я передала параметры для функции по дефолту, куда будут переданы позже как аргументы значения sliderLeft, sliderRight, sliderRange. На сколько я понимаю, из-за чего возникает ошибка "Cannot read properties of undefined", так это из-за разных областей видимости, поскольку функция changeRangeWidth() вызывается в другой функции.
С другой стороны, когда я убираю параметры, а сразу в функцию передаю переменные, которые находятся в общей области видимости, то все работает без ошибок.
Дайте подсказку, пожалуйста, как можно адекватно решить такую проблему, тем самым не писать лишний код?

function changeRangeWidth() {
        let pointLeft = parseInt(sliderLeft.min) + parseInt(sliderLeft.value);
        let pointRight = parseInt(sliderRight.min) + parseInt(sliderRight.value);
        let width = parseInt(pointRight) - parseInt(pointLeft);
    
        sliderRange.style.width = width + '%';
        }
  • Вопрос задан
  • 470 просмотров
Подписаться 1 Простой Комментировать
Решения вопроса 1
ArsenyMatytsyn
@ArsenyMatytsyn Куратор тега JavaScript
Руководитель frontend направления, предприниматель
Задай параметры функции (неплохо бы ещё прикрутить TS к проекту), если актуально, задай базовые значения или тернарники на присваивание.
Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 1
Rsa97
@Rsa97
Для правильного вопроса надо знать половину ответа
как можно адекватно решить такую проблему

Нормально передавать параметры в функцию, а не надеяться на то, что её вызовут в нужной области видимости.
function changeRangeWidth(sliderLeft, sliderRight, sliderRange) {
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
Rocket Смоленск
от 80 000 до 130 000 ₽
div. Ставрополь
от 40 000 до 90 000 ₽
Wanted. Санкт-Петербург
До 220 000 ₽
18 дек. 2024, в 15:50
50000 руб./за проект
18 дек. 2024, в 15:41
3000 руб./за проект
18 дек. 2024, в 15:31
500 руб./за проект