Тривиальным способом является переопределение 3 значений:
.box {
width:200px;
height:200px;
background-image: url(https://mdn.mozillademos.org/files/11305/firefox.png),
url(https://mdn.mozillademos.org/files/11307/bubbles.png),
linear-gradient(to right, rgba(30, 75, 115, 1), rgba(255, 255, 255, 0));
background-repeat: no-repeat,
no-repeat,
no-repeat;
background-position: bottom right,
left,
right;
}
.box:hover {
background-repeat: repeat,
no-repeat,
no-repeat;
background-position: bottom right,
bottom,
right;
}
<div class="box"></div>
Или вы можете использовать переменную CSS, чтобы определить нужные значения, и вы можете изменить их позже, не изменяя другие:
.box {
width:200px;
height:200px;
background-image: url(https://mdn.mozillademos.org/files/11305/firefox.png),
url(https://mdn.mozillademos.org/files/11307/bubbles.png),
linear-gradient(to right, rgba(30, 75, 115, 1), rgba(255, 255, 255, 0));
background-repeat: var(--r,no-repeat),
no-repeat,
no-repeat;
background-position: bottom right,
var(--p,left),
right;
}
.box:hover {
--r:repeat;
--p:right;
}
<div class="box"></div>
Вы также можете сделать то же самое, используя JS:
document.querySelector(".box").addEventListener('click',function(e) {
e.target.style.setProperty('--r','repeat');
e.target.style.setProperty('--p','right');
})
.box {
width:200px;
height:200px;
background-image: url(https://mdn.mozillademos.org/files/11305/firefox.png),
url(https://mdn.mozillademos.org/files/11307/bubbles.png),
linear-gradient(to right, rgba(30, 75, 115, 1), rgba(255, 255, 255, 0));
background-repeat: var(--r,no-repeat),
no-repeat,
no-repeat;
background-position: bottom right,
var(--p,left),
right;
}
<div class="box"></div>