Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 29.12.2021, 17:49
Новичок на форуме
Отправить личное сообщение для VladKireev Посмотреть профиль Найти все сообщения от VladKireev
 
Регистрация: 29.12.2021
Сообщений: 7

Замена хештегов на ссылки
Всем привет!

Подскажите, пожалуйста, по следующей задаче.

В тексте документа в div с определенным классом (или id) необходимо заменить хештеги на ссылки.
Нашел решение для замены с регулярными выражениями:
<div class="aaa">Lorem #hashtag</div>

var repl = $(".aaa");
repl.each(function() {
var string = $(this).text();
$(this).html(string.replace(/#(\S*)/g,'<a href="http://site.ru/$1">$1</a>'));
});


Но проблема в том, что ссылка с хештегов должны быть не однотипные, например:
#one -> site.ru/razdel_1/one
#two -> site.ru/razdel_2/two

Поэтому, видимо необходимо делать список в js файле с перечислением всех вариантов.
И здесь у меня, во-первых, не хватает знаний.
А во вторых, если в перечислении будет, например, 500 вариантов замен – насколько сильно это повлияет на работу сайта?

Заранее благодарю!

Последний раз редактировалось VladKireev, 29.12.2021 в 17:52.
Ответить с цитированием
  #2 (permalink)  
Старый 29.12.2021, 18:27
Аватар для ksa
ksa ksa вне форума
CacheVar
Отправить личное сообщение для ksa Посмотреть профиль Найти все сообщения от ksa
 
Регистрация: 19.08.2010
Сообщений: 14,123

Сообщение от VladKireev
500 вариантов замен – насколько сильно это повлияет на работу сайта?
Сейчас компы довольно шустрые... Но это же будет происходить при каждом обновлении страницы.
Ответить с цитированием
  #3 (permalink)  
Старый 29.12.2021, 18:43
Аватар для ksa
ksa ksa вне форума
CacheVar
Отправить личное сообщение для ksa Посмотреть профиль Найти все сообщения от ksa
 
Регистрация: 19.08.2010
Сообщений: 14,123

Сообщение от VladKireev
Но проблема в том, что ссылка с хештегов должны быть не однотипные, например:
#one -> site.ru/razdel_1/one
#two -> site.ru/razdel_2/two


Поэтому, видимо необходимо делать список в js файле с перечислением всех вариантов.
И здесь у меня, во-первых, не хватает знаний.
Такое можно реализовать как-то так...
<!DOCTYPE html>
<html>
<head>
<script src='https://code.jquery.com/jquery-latest.min.js'></script>
<!--
<script src="https://cdn.jsdelivr.net/npm/vue@2.6.14/dist/vue.js"></script>
<link rel="stylesheet" type="text/css" href="tmp.css" />
<script src='tmp.js'></script>
-->
<style>
</style>
<script>
$(_ => {
	const obj = {
		one: 1,
		two: 2
	}
	const re = /#(\S*)/g
	$('.aaa').each((i, o) => {
		o.innerHTML = o.textContent.replace(re, (str, e) => {
			return `<a href="http://site.ru/razdel_${obj[e]}/${e}">${e}</a>`
		})
	})
})
</script>
</head>
<body>
<div class="aaa">Lorem #one</div>
<div class="aaa">Lorem #two</div>
</body>
</html>
Ответить с цитированием
  #4 (permalink)  
Старый 30.12.2021, 19:20
Новичок на форуме
Отправить личное сообщение для VladKireev Посмотреть профиль Найти все сообщения от VladKireev
 
Регистрация: 29.12.2021
Сообщений: 7

ksa, благодарю! Код рабочий.

Пара уточнений:
1. Допустим заменять необходимо 500 тегов, но путей для ссылок всего 5 видов, например:
#one -> site.ru/razdel_1/one
#two -> site.ru/razdel_1/two
#three -> site.ru/razdel_2/three
#four -> site.ru/razdel_2/four
...

Получается, что код нужно записать так:
$(_ => {
	const obj = {
		one: 1,
		two: 1,
    		three: 2,
    		four: 2
	}


Можно ли как то оптимизировать эту часть, объединив хештеги для одного пути, или на скорость исполнения это не повлияет?

2. Насколько безопасно использование innerHTML в данном случае?
Ответить с цитированием
  #5 (permalink)  
Старый 30.12.2021, 19:29
Аватар для ksa
ksa ksa вне форума
CacheVar
Отправить личное сообщение для ksa Посмотреть профиль Найти все сообщения от ksa
 
Регистрация: 19.08.2010
Сообщений: 14,123

Сообщение от VladKireev
или на скорость исполнения это не повлияет?
На скорость не влияет.

Сообщение от VladKireev
Насколько безопасно использование innerHTML в данном случае?
Мы тут пропагандируем более "техничные" подходы.
Но, если правильно понимать как работает innerHTML, можно использовать и его.
Ответить с цитированием
  #6 (permalink)  
Старый 30.12.2021, 20:07
Новичок на форуме
Отправить личное сообщение для VladKireev Посмотреть профиль Найти все сообщения от VladKireev
 
Регистрация: 29.12.2021
Сообщений: 7

ksa, понял.

Прошу прощения, еще пара новичковских вопросов:

1. Как убрать чувствительность к регистру, то есть, чтобы во всех случаях получался один и тот же результат:
#one -> site.ru/razdel_1/one
#ONE -> site.ru/razdel_1/one
#oNe -> site.ru/razdel_1/one

2. Как сделать, чтобы отсутствующий в списке хештег игнорировался (не преобразовывался в ссылку).
Сейчас если в тексте встречает хештег не из списка, то он преобразуется в:
#hashtag -> site.ru/razdel_undefined/hashtag
Ответить с цитированием
  #7 (permalink)  
Старый 30.12.2021, 20:19
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,072

VladKireev,
Изменение регистра
let key = е.toLowerCase();

return obj[key] ? `<a href="http://site.ru/razdel_${obj[key]}/${key}">${e}</a>` :  str
Ответить с цитированием
  #8 (permalink)  
Старый 30.12.2021, 20:22
Аватар для ksa
ksa ksa вне форума
CacheVar
Отправить личное сообщение для ksa Посмотреть профиль Найти все сообщения от ksa
 
Регистрация: 19.08.2010
Сообщений: 14,123

Как вариант...
<!DOCTYPE html>
<html>
<head>
<script src='https://code.jquery.com/jquery-latest.min.js'></script>
<!--
<script src="https://cdn.jsdelivr.net/npm/vue@2.6.14/dist/vue.js"></script>
<link rel="stylesheet" type="text/css" href="tmp.css" />
<script src='tmp.js'></script>
-->
<style>
</style>
<script>
$(_ => {
	const obj = {
		one: 1,
		two: 2
	}
	const re = /#(\S*)/g
	$('.aaa').each((i, o) => {
		o.innerHTML = o.textContent.replace(re, (str, e) => {
			const key = e.toLocaleLowerCase()
			if (!obj[key]) return str
			return `<a href="http://site.ru/razdel_${obj[key]}/${key}">${e}</a>`
		})
	})
})
</script>
</head>
<body>
<div class="aaa">Lorem #one</div>
<div class="aaa">Lorem #oNe</div>
<div class="aaa">Lorem #two</div>
<div class="aaa">Lorem #Test</div>
</body>
</html>
Ответить с цитированием
  #9 (permalink)  
Старый 30.12.2021, 20:41
Новичок на форуме
Отправить личное сообщение для VladKireev Посмотреть профиль Найти все сообщения от VladKireev
 
Регистрация: 29.12.2021
Сообщений: 7

Сообщение от рони Посмотреть сообщение
VladKireev,
Изменение регистра
let key = е.toLowerCase();

return obj[key] ? `<a href="http://site.ru/razdel_${obj[key]}/${key}">${e}</a>` :  str
рони, спасибо, буду разбираться.
Ответить с цитированием
  #10 (permalink)  
Старый 30.12.2021, 20:46
Новичок на форуме
Отправить личное сообщение для VladKireev Посмотреть профиль Найти все сообщения от VladKireev
 
Регистрация: 29.12.2021
Сообщений: 7

ksa, огромное спасибо! Работает)

Единственное, так и не понял, безопасно ли использовать innerHTML или нет..
Планируется, что пользотели будут оставлять комментарии с хештегами, которые после отпарвки комментария должны преобразовываться в ссылки. В этом случае есть риск?

Последний раз редактировалось VladKireev, 30.12.2021 в 21:09.
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Замена адреса ссылки в зависимости от значения <select> GuyFox Javascript под браузер 1 12.05.2021 22:49
замена изображений в блоке на ссылки imediasun1 Элементы интерфейса 4 17.12.2013 15:27
Замена ссылки при нажатии на него kenzhik Общие вопросы Javascript 8 18.06.2013 11:20
Замена ссылки на текст. Возможно? Missxxx Общие вопросы Javascript 6 18.02.2013 20:49
Регулярное выражение, замена ссылки к файлу на имя файла libinstyle Events/DOM/Window 2 19.07.2010 17:50