Форум программистов, компьютерный форум, киберфорум
JavaScript для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/7: Рейтинг темы: голосов - 7, средняя оценка - 5.00
 Аватар для skapunker
-30 / 25 / 12
Регистрация: 13.12.2013
Сообщений: 1,465

Как выбрать часть текста и заключить ее в теги?

23.01.2020, 13:32. Показов 1534. Ответов 8
Метки html5, js (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет! Подскажите пожалуйста простенький скрипт, который будет делать следующее. Вот у нас есть такая конструкция

HTML5
1
2
3
4
5
6
<div class="vp_pop_chnl_filt_hd ">
        <h1 class="ptitle">
            <i class="fa fa-clock-o" aria-hidden="true"></i>
            Latest videos » Page 6
        </h1>
</div>
Нам нужно выбрать отсюда » Page 6 и заключить его в теги <span>
Стоит учитывать, что выбирать стоит внутри тега <h1> с классом .ptitle
Обратите внимание, что число можно быть многозначным и на пробел перед кавычкой.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.01.2020, 13:32
Ответы с готовыми решениями:

Запись в бд статей - Теги остаются как часть текста и не участвуют в разметке
Здравствуйте, у меня такая проблема возникла, я из админской формы, хочу добавлять статьи (с тегами для форматирования, а потом подгружать...

Как заключить в теги код программы (в сообщении)
Вот визуальный пример (кликни картинку)

Нужно выбрать часть текста..
ээээ.... не могу прально сформулировать :)) ну, вобщем объясню на примере: у меня есть строка 'asdf qwert kolobok uiop jkl' как мне...

8
19 / 14 / 5
Регистрация: 12.01.2020
Сообщений: 38
23.01.2020, 14:25
JavaScript
1
2
3
4
5
6
const textElem = document
  .getElementsByClassName("ptitle")[0]
  .textContent.trim()
  .replace(/((»)(.*))/g, "<span>»$3</span>");
 
console.log(textElem);
0
 Аватар для skapunker
-30 / 25 / 12
Регистрация: 13.12.2013
Сообщений: 1,465
23.01.2020, 14:31  [ТС]
MutusLiber, не прокатило
0
Эксперт JS
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
23.01.2020, 14:42
PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
</head>
<body>
    <div class="vp_pop_chnl_filt_hd ">
        <h1 class="ptitle">
            <i class="fa fa-clock-o" aria-hidden="true"></i>
            Latest videos » Page 6прочий отстой
        </h1>
    </div>
    <script>
        go();
 
        function go() {
            var ptitle = document.querySelector("h1.ptitle");
            var nodes = ptitle.childNodes;
            var regex = /»\sPage\s\d+/; // Здесь указать, что ищем
            for (var i = 0; i < nodes.length; i++) {
                if (nodes[i].nodeType === 3) {
                    var match = nodes[i].textContent.match(regex);
                    if (!match) continue;
 
                    var span = document.createElement("span");
                    span.textContent = match[0];
                    nodes[i].replaceWith(
                        match.input.slice(0, match.index),
                        span,
                        match.input.slice(match.index + match[0].length));
                }
            }
        }
    </script>
</body>
</html>
Добавлено через 2 минуты
----
Здесь скрипт в очень устаревшем синтаксисе ES5.
Поэтому имеет смысл скрипты писать в отдельном файле в современном синтаксисе ES2020 или TypeScript.
Транслятор TypeScript сам создаст скрипт в синтаксисе 2012 года, который нравится подавляющему большинству существующих на 2020 год браузеров.
0
 Аватар для skapunker
-30 / 25 / 12
Регистрация: 13.12.2013
Сообщений: 1,465
23.01.2020, 14:44  [ТС]
amr-now,

работает! Подскажите пожалуйста еще как кавычку выпилить оттуда, чтобы в <span> помещало без нее, тобишь так Page 6
0
Эксперт JS
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
23.01.2020, 14:45
skapunker,
JavaScript
1
var regex = /Page\s\d+/; // Здесь указать, что ищем
0
 Аватар для skapunker
-30 / 25 / 12
Регистрация: 13.12.2013
Сообщений: 1,465
23.01.2020, 14:47  [ТС]
Цитата Сообщение от amr-now Посмотреть сообщение
1
var regex = /Page\s\d+/; // Здесь указать, что ищем
так тогда она останется внутри <h1> а надо ее убрать совсем
0
Эксперт JS
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
23.01.2020, 14:51
Лучший ответ Сообщение было отмечено skapunker как решение

Решение

skapunker, прочитайте Ваши вопросы. В двух вопросах не было задачи уничтожить кавычку.
PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
</head>
<body>
    <div class="vp_pop_chnl_filt_hd ">
        <h1 class="ptitle">
            <i class="fa fa-clock-o" aria-hidden="true"></i>
            Latest videos » Page 6прочий отстой
        </h1>
    </div>
    <script>
        go();
 
        function go() {
            var ptitle = document.querySelector("h1.ptitle");
            var nodes = ptitle.childNodes;
            var regex = /»\s(Page\s\d+)/; // Здесь указать, что ищем
            for (var i = 0; i < nodes.length; i++) {
                if (nodes[i].nodeType === 3) {
                    var match = nodes[i].textContent.match(regex);
                    if (!match) continue;
 
                    var span = document.createElement("span");
                    span.textContent = match[1];
                    nodes[i].replaceWith(
                        match.input.slice(0, match.index),
                        span,
                        match.input.slice(match.index + match[0].length));
                }
            }
        }
    </script>
</body>
</html>
1
19 / 14 / 5
Регистрация: 12.01.2020
Сообщений: 38
23.01.2020, 15:07
skapunker, чего не прокатило? Внимательней просто посмотрите какой HTML спецсимвол используете для кавычек и все прокатит.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
23.01.2020, 15:07
Помогаю со студенческими работами здесь

Выбрать часть текста со страницы
Задача состоит в том что надо написать шаблон чтобы с сайта http://www.avito.ru/izhevsk/nedvizhimost из всего исходного кода страницы он...

Выбрать часть текста, исключая остальное
День добрый. К примеру html code https://www.anti-malware.ru/news/2018-05-18-1447/26297 html code Киберпреступники, отправившие твит с...

Как из xml выбрать теги вида <tag />, сохранив их как None?
Пишу парсер на питоне В xml-файле есть тег &lt;description&gt; testtest &lt;/description&gt; .py offer_description =...

Как удалить все теги из текста?
Всем привет. У меня есть сайт, на котором можно оставлять комментарии. Так вот: когда страница добавляет комментарий, нужно чтобы она...

Подскажите как выбрать часть содержимого из ячейки excel
Помогите пожалуйста. Есть ячейка содержимого - &quot;0100001987 - МИТЮШКИНА М.А. Д&quot; нач&quot;. Из этого содержимого нужно в отдельную ячейку...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
Контроль уникальности заводского номера - вариант №2
Maks 24.03.2026
В отличие от предыдущего варианта добавлено прерывание циклов, также добавлены новые переменные для сохранения контекста ошибки перед прерыванием цикла: Процедура ПередЗаписью(Отказ, РежимЗаписи,. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
Контроль уникальности заводского номера - вариант №1
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью в КА2. Данные берутся из регистра сведений, по которому настроено. . .
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа в КА2. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru