Как исправить длину текста в абзаце?

Я пытаюсь создать простой калькулятор на 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;
}

Ну что вы хотите, чтобы он делал, если он идет слишком много? вы хотите, чтобы текст был меньше?

Sheshank S. 21.06.2018 00:37

Можете ли вы добавить свой HTML / CSS, добавить фрагмент, спасибо

sol 21.06.2018 00:37

@SheshankS. Я хочу, чтобы кнопки были заблокированы

Desiigner 21.06.2018 00:38

@Desiigner, а что, если результат слишком велик?

Sheshank S. 21.06.2018 00:39

@ SheshankS. Ну, наверное, я об этом не подумал. Думаю, разумнее было бы уменьшить размер шрифта.

Desiigner 21.06.2018 00:41
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
2
5
581
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

У вас есть пара вещей, о которых я читаю в комментариях.

Но вот предложение, которое может быть интересно: 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?

Desiigner 21.06.2018 01:05

Не уверен ... Вы про <p id = "mainline">?

Louys Patrice Bessette 21.06.2018 23:04

Да, точно. Должен сделать это div?

Desiigner 21.06.2018 23:13

Конечно ... Надеюсь, вы сделали это сразу после этого комментария. Возможно, определенно widthp отличается от div. Зачем вообще этот p?

Louys Patrice Bessette 22.06.2018 00:14

HTML и CSS - это очень близко, когда речь идет о тонком использовании дисплея. Ищите сценарий, когда участвует пользовательский ввод ... И вы можете сузить его, основываясь на событиях пользовательского интерфейса. ;)

Louys Patrice Bessette 22.06.2018 00:17

Другие вопросы по теме