@Grisha4800

Как разделить строку на две и вывести их как два разных блока?

Имеется компонент:

function Product (props) {
    
        const {
            prod_id: id,
            prod_name : title,
            prod_status: status,
            prod_price: price,
            prod_oldprice : oldPrice,
        } = props;
    
    
        let oldPriceChecker = (oldPriceValue) => {
            if (oldPriceValue) {
                let oldPriceStr = oldPriceValue + ' zł';
                return(oldPriceStr);
            }else {
                return('');
            }
        }
    
    
        return (
        
        <div className="row">
          <div className="card">
            <div className="card-image">
              <img src="https://via.placeholder.com/150" />
            </div>
            <div className="card-content">
                <span className="card-title">{title}</span>
                <hr className="card_hr" />
                <p className="card_price" >{price} zł</p>
                <div className="card_price old_price">{oldPriceChecker(oldPrice)}</div>
                <div className="status">{status}</div>
            </div>
          </div>
      </div>
        ) 
    }

export {Product}

Данные приходят из этого файла.

Вопрос: переменная prod_status: status может содержать несколько значений (например "new,promotion"), если это так, нужно разделить это на два слова и создать для каждого отдельный блок, так как сейчас блок приходит вся строка.

Сейчас сайт выглядит так (new, saleout) в одном блоке:

6245671c21bfa575783180.png

Нужно так (new, saleout и прочее в отдельных блоках):

6245672e5fac3785714768.png
  • Вопрос задан
  • 112 просмотров
Решения вопроса 1
0xD34F
@0xD34F Куратор тега React
Вместо <div className="status">{status}</div> пусть будет

{status.split(',').map(n => <div className="status">{n}</div>)}
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

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

Войти через центр авторизации
Похожие вопросы