Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/29: Рейтинг темы: голосов - 29, средняя оценка - 4.69
0 / 0 / 0
Регистрация: 23.10.2017
Сообщений: 12

Требуется обрезать текст по размеру ячейки. По клику по этой ячейке, вывести текст полностью.

20.02.2018, 00:53. Показов 6192. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброй ночи!
Прошу помочь с такой задачей..
Нужно вывести текст из бд в таблицу, это как бы не проблема.. но загвоздка в том,
что требуется обрезать текст по размеру ячейки, а по клику по этой же ячейки, нужно вывести текст полностью..
(за границы таблицы можно как в excel). вообщем так и есть, нужно сделать как в excel..
Ребят, в JavaScript не очень.. прошу помочь.. буду очень благодарен!
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.02.2018, 00:53
Ответы с готовыми решениями:

При клике по ячейке вставить текст в другую ячейку этой же таблицы
Здравствуйте! У меня есть таблица: <table> <tbody> <tr> <td id="s1"...

Как в ячейке таблицы установить текст, начинающийся от верха ячейки?
У меня таблица из двух ячеек. Если текст в одной из ячеек длинный и расположен в несколько строк, то во второй ячейке более короткий текст...

Считать из файла текст; вывести на экран все слова текста, упорядочив их по размеру
Ребят, помогите с задачей пожалуйста. Нужно считать текст из файла, потом вывести все слова этого текста на экран, упорядочив их по...

8
Юзер с абсолютным слухом
 Аватар для Опан
709 / 489 / 195
Регистрация: 17.12.2010
Сообщений: 1,428
21.02.2018, 02:31
Лучший ответ Сообщение было отмечено buromax как решение

Решение

CSS
1
2
3
4
5
6
.clip{
    white-space: nowrap; /* По желанию запрещаем перенос строк */
    overflow: hidden; /* Обрезаем все, что не помещается в область */
    text-overflow: ellipsis; /* По желанию добавляем многоточие */
    width:300px;
}
HTML5
1
2
3
4
5
6
7
8
9
<table border=1>
    <tr>
        <td>
            <div class="clip" onclick="this.style.overflow='visible'">
                 это текст, который требуется обрезать по размеру ячейки, а по клику по этой же ячейки, нужно вывести текст полностью
            </div>
        </td>
    </tr>
</table>
1
0 / 0 / 0
Регистрация: 23.10.2017
Сообщений: 12
21.02.2018, 20:35  [ТС]
Спасибо, скажите, а можно что бы по второму клику, текст прятался обратно?
0
 Аватар для evikza
968 / 530 / 244
Регистрация: 20.05.2015
Сообщений: 776
21.02.2018, 22:02
buromax,

JavaScript
1
2
3
4
5
6
7
8
9
<table border=1>
    <tr>
        <td>
            <div class="clip" onclick="this.style.overflow = (window.getComputedStyle(this).overflow == 'hidden') ? 'visible' : 'hidden'">
                это текст, который требуется обрезать по размеру ячейки, а по клику по этой же ячейки, нужно вывести текст полностью
            </div>
        </td>
    </tr>
</table>
0
0 / 0 / 0
Регистрация: 23.10.2017
Сообщений: 12
21.02.2018, 23:42  [ТС]
А можно что бы текст не выходил за рамки, а с переносом вывод был?

Добавлено через 4 минуты
Вот еще ребята подсказали, но тут не возвращает текст обратно восвояси

HTML5
1
2
3
4
5
6
7
<table class="bigTable" border>
    <tr>
        <td><div class="cell" onclick="showCell(this)">lorem ipsum dolor sit amet. lorem ipsum dolor sit amet. lorem ipsum dolor sit amet</div></td>
        <td><div class="cell" onclick="showCell(this)">lorem ipsum dolor sit amet. lorem ipsum dolor sit amet. lorem ipsum dolor sit amet</div></td>
        <td><div class="cell" onclick="showCell(this)">lorem ipsum dolor sit amet. lorem ipsum dolor sit amet. lorem ipsum dolor sit amet</div></td>
    </tr>
</table>
CSS
1
2
3
4
5
6
7
8
9
10
11
12
.cell {
 white-space: nowrap;
 overflow: hidden;
 padding: 5px;
 text-overflow: ellipsis;
 color: #cfd0d2;
 width: 110px;
}
 
.bigTable{
  margin: 15px;
}
JavaScript
1
2
3
4
5
6
function showCell(e) {
 e.style.whiteSpace='normal';
 e.style.overflow='visible';
 e.style.textOverflow='clip';
 e.style.width='200px';
}
0
 Аватар для evikza
968 / 530 / 244
Регистрация: 20.05.2015
Сообщений: 776
22.02.2018, 00:26
buromax, можно просто добавлять дополнительный класс при клике на элемент. Есть 2 варианта так скажем «синтаксиса».:

Добавлять каждому классу функцию -> вызываем.:

HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
<table class="bigTable" border>
    <tr>
        <td>
            <div class="cell" onclick="expandCall(this)">lorem ipsum dolor sit amet. lorem ipsum dolor sit amet. lorem ipsum dolor sit amet</div>
        </td>
        <td>
            <div class="cell" onclick="expandCall(this)">lorem ipsum dolor sit amet. lorem ipsum dolor sit amet. lorem ipsum dolor sit amet</div>
        </td>
        <td>
            <div class="cell" onclick="expandCall(this)">lorem ipsum dolor sit amet. lorem ipsum dolor sit amet. lorem ipsum dolor sit amet</div>
        </td>
    </tr>
</table>
JavaScript
1
2
3
function expandCall(tl) {
  tl.classList.toggle('cell--expand');
}
Демонстрация


Второй вариант, при клике на ячейку -> через цикл находим ту — по которой нажали. Отпадает нужда прописывать инлайново JS:

HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
<table class="bigTable" border>
    <tr>
        <td>
            <div class="cell">lorem ipsum dolor sit amet. lorem ipsum dolor sit amet. lorem ipsum dolor sit amet</div>
        </td>
        <td>
            <div class="cell">lorem ipsum dolor sit amet. lorem ipsum dolor sit amet. lorem ipsum dolor sit amet</div>
        </td>
        <td>
            <div class="cell">lorem ipsum dolor sit amet. lorem ipsum dolor sit amet. lorem ipsum dolor sit amet</div>
        </td>
    </tr>
</table>
JavaScript
1
2
3
4
5
6
7
var callContainer = document.getElementsByClassName("cell");
 
[].forEach.call(callContainer, function(data) {
    data.addEventListener("click", function(e) {
        this.classList.toggle("cell--expand");
    });
});
Демонстрация

Единый стиль CSS для всех вариантов:

CSS
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
.bigTable {
  margin: 15px;
}
 
.cell {
  white-space: nowrap;
  overflow: hidden;
  padding: 5px;
  text-overflow: ellipsis;
  color: #cfd0d2;
  width: 110px;
}
 
.cell--expand {
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  width: 200px;
}
1
the hardway first
Эксперт JS
 Аватар для j2FunOnly
2475 / 1847 / 910
Регистрация: 05.06.2015
Сообщений: 3,610
22.02.2018, 08:39
Можно и без цикла - отслеживать клик по всей таблице
JavaScript
1
2
3
4
5
document.querySelector('table.bigTable').addEventListener('click', function (e) {
  if (!e.target.classList.contains('cell')) return;
    
  e.target.classList.toggle('cell--expand');
});
1
0 / 0 / 0
Регистрация: 23.10.2017
Сообщений: 12
26.02.2018, 11:40  [ТС]
отлично все.. но есть одно но. .текст скопировать не реально
0
Юзер с абсолютным слухом
 Аватар для Опан
709 / 489 / 195
Регистрация: 17.12.2010
Сообщений: 1,428
27.02.2018, 13:19
Сделайте не по обычному, а по двойному клику:
JavaScript
1
...addEventListener('dblclick', function (e) {};
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.02.2018, 13:19
Помогаю со студенческими работами здесь

вывести текст по клику на ссылке
Здравствуйте, мне нужна подсказка в решении вопроса. У меня есть цикл с каждым шагом создается ссылка при клике на ссылку должна...

Скопировать текст из лейбла радио кнопки в текстовое поле по клику на этой же радио кнопке
Привет всем. Помогите с jQuery : нужно скопировать значение из &lt;span class=&quot;priceIn&gt;&lt;/span&gt; в текстовое поле .priceValue по клику на...

По клику на текст передать другой текст в input
Подскажите, как реализовать задумку: Есть форма с полем ввода &lt;form method = post action = /index.php?search&gt; &lt;input type...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru