Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/21: Рейтинг темы: голосов - 21, средняя оценка - 5.00
 Аватар для Raisin Zn
101 / 100 / 51
Регистрация: 19.04.2011
Сообщений: 965

Проверить наличие текста до и после элемента

14.01.2017, 11:08. Показов 4173. Ответов 13
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.
Не могу победить возникшую задачу. Мне необходимо перед и после блока с классом inline-attachment поставить тег <br />, но только в том случае, если перед блоком есть текст, если передо блоком нету текста, то не надо добавлять перенос строки. Так же и после блока, надо проверить наличие текста, если есть - добавить перенос. После блока может быть такой же блок, его переносить не надо...

Как поставить перенос я знаю:
JavaScript
1
2
    $('.inline-attachment').before('<br />');
    $('.inline-attachment').after('<br />');
А как проверить наличие текста, не могу сообразить... Подскажите, как проверяется наличие текста?
Спасибо.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.01.2017, 11:08
Ответы с готовыми решениями:

Проверить наличие класса у элемента
Добрый день , не могу понять почему не срабатывает alert &lt;a class=&quot;btn checked&quot; href=&quot;/&quot; &gt;в корзину&lt;/a&gt; var d =...

Проверить тэг на наличие контента в виде текста
Проверить тэг на наличие контента в виде текста или дерева внутренних тегов

Как проверить наличие у элемента класса CSS БЕЗ Jquery
Подскажите как проверить наличие у элемента класса CSS БЕЗ использования Jquery? хочу написать функцию аналогичную методу hasClass(), но...

13
 Аватар для sad67man
2600 / 1504 / 689
Регистрация: 23.08.2015
Сообщений: 3,804
15.01.2017, 01:03
Raisin Zn,
JavaScript
1
2
3
4
5
6
7
8
9
$('.inline-attachment').each(function(){
    var $this = $(this);
    if(!!this.previousSibling.textContent.trim()) {
     $this.before('<br />');
  }
  if(!!this.nextSibling.textContent.trim()) {
     $this.after('<br />');
  }
})
Добавлено через 29 секунд
https://jsfiddle.net/a2xL7be8/
1
 Аватар для Raisin Zn
101 / 100 / 51
Регистрация: 19.04.2011
Сообщений: 965
15.01.2017, 04:14  [ТС]
sad67man, большое спасибо, Ваш код работает!

Теперь тег переноса на новую строку добавляется, если перед или после блока следует текст, но если текст идет форматированным, выделен каким ни будь тегом, то перенос не добавляется. Я подумал, что тут лучше проверять не наличие текста, а наличие такого же блока рядом с этим блоком, то есть .inline-attachment перед или после .inline-attachment.
Как такое сделать?

Еще, если после блока ни чего нет, то в в консоли ошибка: Uncaught TypeError: Cannot read property 'textContent' of null и остальные JS не работают...
0
 Аватар для sad67man
2600 / 1504 / 689
Регистрация: 23.08.2015
Сообщений: 3,804
15.01.2017, 04:23
Raisin Zn, Вообще это делать лучше на стороне сервера при формирования вывода блоков.
0
 Аватар для Raisin Zn
101 / 100 / 51
Регистрация: 19.04.2011
Сообщений: 965
15.01.2017, 04:25  [ТС]
https://jsfiddle.net/a2xL7be8/ - тут без ошибок отрабатывает, а у меня на странице, с ошибкой, если после блока ни чего нет...

Добавлено через 1 минуту
Цитата Сообщение от sad67man Посмотреть сообщение
Вообще это делать лучше на стороне сервера при формирования вывода блоков.
Дело в том, что в код ядра залесть нельзя, пока нет официального расширения для решения моей задачи, я хочу использовать вот такой "костыль"...
0
 Аватар для sad67man
2600 / 1504 / 689
Регистрация: 23.08.2015
Сообщений: 3,804
15.01.2017, 04:27
Raisin Zn, чтоб избежать ошибки расширьте условие.
JavaScript
1
2
3
4
5
6
7
8
9
$('.inline-attachment').each(function(){
    var $this = $(this);
    if(this.previousSibling && !!this.previousSibling.textContent.trim()) {
     $this.before('<br />');
  }
  if(this.nextSibling && !!this.nextSibling.textContent.trim()) {
     $this.after('<br />');
  }
})
Добавлено через 1 минуту
Raisin Zn, на счет форматирования сейчас подумаю)
1
 Аватар для Raisin Zn
101 / 100 / 51
Регистрация: 19.04.2011
Сообщений: 965
15.01.2017, 04:30  [ТС]
sad67man, спасибо!
Ошибка пропала!
0
 Аватар для sad67man
2600 / 1504 / 689
Регистрация: 23.08.2015
Сообщений: 3,804
15.01.2017, 05:01
Raisin Zn, https://jsfiddle.net/a2xL7be8/1/
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
$('.inline-attachment').each(function(){
    var $this = $(this);
  var isPrevHasClass = $this.prev().length && !$this.prev().hasClass('inline-attachment');
  var isNextHasClass = $this.next().length && !$this.next().hasClass('inline-attachment');
  var isPrevText = this.previousSibling && !!this.previousSibling.textContent.trim();
  var isNextText = this.nextSibling && !!this.nextSibling.textContent.trim();
  if(isPrevHasClass || isPrevText) {
    $this.before('<br />');
  }
  if(isNextHasClass || isNextText) {
    $this.after('<br />');
  }
})
0
 Аватар для sad67man
2600 / 1504 / 689
Регистрация: 23.08.2015
Сообщений: 3,804
15.01.2017, 05:03
Лучший ответ Сообщение было отмечено Raisin Zn как решение

Решение

Raisin Zn, https://jsfiddle.net/a2xL7be8/1/
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
$('.inline-attachment').each(function(){
    var $this = $(this);
  var isPrevHasClass = $this.prev().length && !$this.prev().hasClass('inline-attachment');
  var isNextHasClass = $this.next().length && !$this.next().hasClass('inline-attachment');
  var isPrevText = this.previousSibling && !!this.previousSibling.textContent.trim();
  var isNextText = this.nextSibling && !!this.nextSibling.textContent.trim();
  if(isPrevHasClass || isPrevText) {
    $this.before('<br />');
  }
  if(isNextHasClass || isNextText) {
    $this.after('<br />');
  }
})
1
 Аватар для Raisin Zn
101 / 100 / 51
Регистрация: 19.04.2011
Сообщений: 965
15.01.2017, 05:16  [ТС]
sad67man, круто! Вы волшебник!
Большое Вам спасибо! Вы меня спасли!
0
 Аватар для sad67man
2600 / 1504 / 689
Регистрация: 23.08.2015
Сообщений: 3,804
15.01.2017, 05:42
Raisin Zn, Принципиальный момент) Немножечко по семантике ошибся) судя по названию переменный isNextHasClass и isPrevHasClass должны возвращать true в случае, если класс имеется. Однако тут идет от обратного. Стоит их переименовать на isNextHasNoClass ну или что-то подобное)
1
 Аватар для Raisin Zn
101 / 100 / 51
Регистрация: 19.04.2011
Сообщений: 965
15.01.2017, 05:49  [ТС]
sad67man, это уже мелочи!
Но слово is из переменных уберу, сделать на совесть!

Добавлено через 2 минуты
Цитата Сообщение от sad67man Посмотреть сообщение
Стоит их переименовать на isNextHasNoClass
Ну или так сделаю.
0
 Аватар для sad67man
2600 / 1504 / 689
Регистрация: 23.08.2015
Сообщений: 3,804
15.01.2017, 05:52
Raisin Zn, Кстати это общепринятое правило именования переменных типа boolean во всех языках программирования. Имя переменной должна указывать на то, что там лежит в том числе и тип. Здесь добавляя слово is мы как бы задаем вопрос "имеется класс?", а значение переменной возвращает ответ. Если переменная начитается на is, значит тип переменной boolean и возвращает true/false.
1
 Аватар для Raisin Zn
101 / 100 / 51
Регистрация: 19.04.2011
Сообщений: 965
15.01.2017, 05:58  [ТС]
Не знал, теперь буду знать...

Вот что получилось и как было раньше (сейчас все на своих местах, раньше картинки могли стоять в одной линии с текстом):
Миниатюры
Проверить наличие текста до и после элемента   Проверить наличие текста до и после элемента  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
15.01.2017, 05:58
Помогаю со студенческими работами здесь

Как проверить наличие элемента и если он есть удалить его по клику
Приветствую, у меня есть код: var modalbtn=document.querySelectorAll(&quot;.modal__btn&quot;); for (var i = 0; i &lt; modalbtn.length; i++) { ...

Как проверить на существование элемента, после элемента input
У меня если поля input пустые - создается в js div.error с ошибкой. Как можно проверить на существование div.error после определенного...

Проверить наличие текста в richTextBox
Как проверить все строки в richtextbox на наличие определенного текста? Например нужно искать текст &quot;search&quot; и даны строки ...

Проверить наличие текста в TextBox
есть два текстбокса в которых вводятся числа int sum = Convert.ToInt32(textBox2.Text); int t_s = Convert.ToInt32(textBox3.Text); ...

Как проверить в Ls наличие текста в строке?
В @ есть @Like, а в LS аналогов найти не могу (((


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

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru