Показать сообщение отдельно
  #1 (permalink)  
Старый 18.06.2017, 22:26
Аспирант
Отправить личное сообщение для Alessio18911 Посмотреть профиль Найти все сообщения от Alessio18911
 
Регистрация: 18.06.2017
Сообщений: 87

как сократить названия классов с общим началом в массиве
Привет! К JS только-только подступился, но кое-что уже знаю. Проблема такая. Есть кусочек кода:
<div class="page bg1">
      <div class="radio-controls">
        <label class="label" for="radio1"></label>
        <label class="label" for="radio2"></label>
        <label class="label" for="radio3"></label>
      </div>
</div>


и к нему CSS:
.page {
  position: relative;
  width: 400px;
  height: 250px;
  outline: 1px solid orange;
}

.bg1 {
  background-image: url("Gora-400x250.jpg");
}

.bg2 {
  background-image: url("IMG_0863m.jpg");
}

.bg3 {
  background-image: url("Torosskie-goryi-400x250.jpg");
}

.radio-controls {
  position: absolute;
  bottom: 0;
  left: 50%;
  margin-left: -55px;
  width: 110px;
  height: 50px;
  text-align: center;
  line-height: 65px;
  outline: 1px solid red;
}

label {
  display: inline-block;
  width: 20px;
  height: 20px;
  background-color: dodgerblue;
  background-clip: padding-box;
  border: 5px solid transparent;
  border-radius: 50%;
  box-shadow: 0 0 2px 1px dodgerblue;
}


Нужно сделать так, чтобы при клике по любому label у div.page удалялся бы любой класс, имя которого начинается с bg-, если вдруг он обнаружился. Всё, что удалось мне придумать, это длинные условия, вроде:
if(page[0].classList.contains("bg1") || page[0].classList.contains("bg2"))
и т.д... А можно ли как-то укоротить текст условия? Ну, например, как в CSS есть селекторы по атрибуту [class^='bg-'], есть ли что-то подобное в синтаксисе JS?

Последний раз редактировалось Alessio18911, 18.06.2017 в 22:50.
Ответить с цитированием