0 / 0 / 0
Регистрация: 23.10.2017
Сообщений: 12

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

20.02.2018, 00:53. Показов 6213. Ответов 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
Ответ Создать тему
Опции темы

Новые блоги и статьи
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru