Я пытаюсь создать простой калькулятор на JS. Я использую тег абзаца в качестве отображения, и проблема в том, что текст может выходить за пределы строки.
Мой калькулятор:
Но когда я ввожу более 12 кнопок, происходит следующее:
То, как я складываю числа, выглядит так:
$('#5').click(function() {
$("#mainline").text(function(i, oldtext) {
return oldtext.replace(/^0$/, '') + '5';
});
});
Я попытался поместить все кнопки в цикл, который будет проверять длину тега абзаца, и если он больше 12, то:
document.getElementsByTagName("button").disabled = true
Но я не работал. Что мне делать?
HTML:
<div class='calculator'>
<div class='lines'><p id = "mainline">0</p></div>
<div id = "row1">
<button id='AC'>AC</button>
<button id='pm'><sup>+</sup>/<sub>-</sub></button>
<button>%</button>
<button id='dvd'>/</button>
</div>
CSS:
.calculator {
display: inline-block;
position: relative;
padding-left: 37%;
padding-top: 7%;
}
button {
width: 50px;
height: 40px;
margin-bottom: 1px;
}
#mainline {
border: 3px solid #FF9500;
text-align: right;
}
Можете ли вы добавить свой HTML / CSS, добавить фрагмент, спасибо
@SheshankS. Я хочу, чтобы кнопки были заблокированы
@Desiigner, а что, если результат слишком велик?
@ SheshankS. Ну, наверное, я об этом не подумал. Думаю, разумнее было бы уменьшить размер шрифта.



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


У вас есть пара вещей, о которых я читаю в комментариях.
Но вот предложение, которое может быть интересно: CSS direction:rtl и text-overflow:ellipsis ...
$("#test").on("keyup",function(){
$("#display").text($(this).val());
});#display{
/* Just for this demo */
height:1em;
width:8em;
border: 1px solid orange;
display:inline-block;
margin-top:0.4em;
/* suggestion */
direction: rtl;
overflow:hidden;
text-overflow: ellipsis;
}<script src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
Type in! <input id = "test"><br>
Result: <div id = "display"></div>да, я понял, что вы имеете в виду, но добавление этих свойств CSS в мой абзац не вносит никаких изменений. Это происходит из-за того, что мой дисплей не является div?
Не уверен ... Вы про <p id = "mainline">?
Да, точно. Должен сделать это div?
Конечно ... Надеюсь, вы сделали это сразу после этого комментария. Возможно, определенно widthp отличается от div. Зачем вообще этот p?
HTML и CSS - это очень близко, когда речь идет о тонком использовании дисплея. Ищите сценарий, когда участвует пользовательский ввод ... И вы можете сузить его, основываясь на событиях пользовательского интерфейса. ;)
Ну что вы хотите, чтобы он делал, если он идет слишком много? вы хотите, чтобы текст был меньше?