Как отобразить значок рядом с тем, чтобы показать / скрыть текст на кнопке?
Я хочу отобразить значок рядом с "больше" и "меньше" после нажатия "меньше / больше".
Как сделать несколько кнопок / идентификаторов, как это? Основываясь на проверенном решении. -
function showme(id) {
var divid = document.getElementById(id);
var clicky = document.getElementById("clicky");
if (divid.style.display == 'block') {
divid.style.display = 'none';
clicky.innerHTML = "MORE";
} else {
divid.style.display = 'block';
clicky.innerHTML = "LESS";
}
}
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">
</head>
<body>
<i>Click on more. I want to have two different icons one for more one for less always after click.</i><br>
<div class="tp-caption rev-btn rev-hiddenicon rs-hover-ready rev-mre-btn" onclick="showme('widget');" href="javascript:;" id="clicky">MORE <i class="fa fa-car"></i></div>
<div id="widget" style="display:none;">
This is a widget
</div>
</body>
</html>
3 ответа
Решение
Пожалуйста, измените код JS, как показано ниже:-
function showme(id) {
var divid = document.getElementById(id);
var clicky = document.getElementById("clicky");
if (divid.style.display == 'block') {
divid.style.display = 'none';
clicky.innerHTML = 'MORE <i class="fa fa-car"></i>';
} else {
divid.style.display = 'block';
clicky.innerHTML = 'LESS <i class="fa fa-car"></i>';
}
}
<head>
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">
</head>
<body>
<i>Click on more. I want to have two different icons one for more one for less always after click.</i><br>
<div class="tp-caption rev-btn rev-hiddenicon rs-hover-ready rev-mre-btn" onclick="showme('widget');" href="javascript:;" id="clicky">MORE <i class="fa fa-car"></i></div>
<div id="widget" style="display:none;">
This is a widget
</div>
</body>
Вы можете сделать что-то вроде этого....
function showme(id) {
var divid = document.getElementById(id);
var clicky = document.getElementById("clicky");
if (divid.style.display == 'block') {
divid.style.display = 'none';
clicky.innerHTML = "MORE <i class='fa fa-arrow-down'></i>";
} else {
divid.style.display = 'block';
clicky.innerHTML = "LESS <i class='fa fa-arrow-up'></i>";
}
}
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">
</head>
<body>
<i>Click on more. I want to have two different icons one for more one for less always after click.</i><br>
<div class="tp-caption rev-btn rev-hiddenicon rs-hover-ready rev-mre-btn" onclick="showme('widget');" href="javascript:;" id="clicky">MORE <i class="fa fa-car"></i></div>
<div id="widget" style="display:none;">
This is a widget
</div>
</body>
</html>
function showme(id) {
var car = document.createElement('i');
car.classList.add("fa");
var divid = document.getElementById(id);
var clicky = document.getElementById("clicky");
if (divid.style.display == 'block') {
divid.style.display = 'none';
clicky.innerHTML = "MORE";
car.classList.add("fa-arrow-down");
} else {
divid.style.display = 'block';
clicky.innerHTML = "LESS";
car.classList.add("fa-arrow-up");
}
clicky.appendChild(car);
}
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">
<i>Click on more. I want to have two different icons one for more one for less always after click.</i><br>
<div class="tp-caption rev-btn rev-hiddenicon rs-hover-ready rev-mre-btn" onclick="showme('widget');" href="javascript:;" id="clicky">MORE <i class="fa fa-car"></i></div>
<div id="widget" style="display:none;">
This is a widget
</div>