@suprascapularis69

Почему не срабатывает код в обработчике onclick?

<form class="form" novalidate>
                <div class="form-field">
                    <label for="name" class="form-label"><span>Наименование товара</span></label>
                    <input type="text" name="Product name" placeholder="Введите наименование товара" id="name" class="form-input required input-name">
                </div>
                <div class="form-field form-field-big">
                    <label for="description" class="form-label">Описание товара</label>
                    <textarea name="Product description" placeholder="Введите описание товара" id="description" class="form-input big-input input-description"></textarea>
                </div>
                <div class="form-field">
                    <label for="image" class="form-label"><span>Ссылка на изображение товара</span></label>
                    <input type="url" name="Product image link" placeholder="Введите ссылку" id="image" class="form-input required input-image">
                </div>
                <div class="form-field form-field-last">
                    <label for="price" class="form-label"><span>Цена товара</span></label>
                    <input type="number" name="Product price" placeholder="Введите цену" id="price" class="form-input required input-price">
                </div>
                <button class="form-button" type="submit">Добавить товар</button>
            </form>


let form = document.querySelector('.form'),
    formRequired = document.querySelectorAll('.required'),
    formButton = document.querySelector('.form-button'),
    inputName = document.querySelector('.input-name'),
    inputDescription = document.querySelector('.input-description'),
    inputImage = document.querySelector('.input-image'),
    inputPrice = document.querySelector('.input-price'),
    productList = document.querySelector('.product-list');



formButton.disabled = true;

form.onkeyup = function () {

    if (inputName.value !== '' && inputImage.value !== '' && inputPrice.value !== '') {
        formButton.style.background = '#7BAE73';
        formButton.style.color = '#FFFFFF';
        formButton.disabled = false;
    } else {
        formButton.style.background = '#EEEEEE';
        formButton.style.color = '#B4B4B4';
        formButton.disabled = true;
    }

    if (document.querySelector('.form-error')) {
        for (let x of document.querySelectorAll('.form-error')) {
            x.remove();
        }
    }

    formRequired.forEach(function (input) {
        if (input.value === '') {
            input.classList.add('error');
            var error = document.createElement('p');
            error.innerHTML = 'Поле является обязательным';
            error.classList.add('form-error');
            input.after(error);
        } else {
            input.classList.remove('error');
        }
    })

    return false;

}

formButton.onclick = function (event) {

    if (inputName.value !== '' && inputImage.value !== '' && inputPrice.value !== '') {

        var productCard = document.createElement('div');
        productCard.classList.add('product-card');
        productList.appendChild(productCard);

        var li = document.createElement('li');
        productCard.appendChild(li);

        var productCardPhotoWrapper = document.createElement('div');
        productCardPhotoWrapper.classList.add('product-card-photo-wrapper');
        li.appendChild(productCardPhotoWrapper);

        var img = document.createElement('img');
        productCardPhotoWrapper.appendChild(img);
        img.src = inputImage.value;
        img.style.width = "332px";
        img.style.height = "200px";

        var productCardProperty = document.createElement('div');
        li.appendChild(productCardProperty);
        productCardProperty.classList.add('product-card-property');

        var productName = document.createElement('p');
        productCardProperty.appendChild(productName);
        productName.classList.add('product-name');
        productName.innerHTML = inputName.value;

        var productDescription = document.createElement('p');
        productCardProperty.appendChild(productDescription);
        productDescription.classList.add('product-description');
        productDescription.innerHTML = inputDescription.value;
        
        var productPrice = document.createElement('p');
        productCardProperty.appendChild(productPrice);
        productPrice.classList.add('product-price');
        productPrice.innerHTML = inputPrice.value + ' руб.';

        inputName.value = '';
        inputDescription.value = '';
        inputImage.value = '';
        inputPrice.value = '';
        formButton.style.background = '#EEEEEE';
        formButton.style.color = '#B4B4B4';
    }


    return;

}
  • Вопрос задан
  • 74 просмотра
Пригласить эксперта
Ваш ответ на вопрос

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

Похожие вопросы