Я хочу избежать текста заголовка в div. Но при подаче экранированного текста в вызов html() он снова не экранируется. Вот код
const title = $('<div/>').text('test <script>').html(); // test &lt;script&gt;
const span = `<span title="${title}">Hello world</span>`; // still correct
$('#test').html(span);
но теперь сгенерированный html внутри #span снова имеет 'test ‹script'; проверьте демо здесь:
// find elements
var banner = $("#banner-message")
var button = $("button")
// handle click and add class
button.on("click", () => {
const title = $('<div/>').text('test <script>').html();
const span = `<span title="${title}">Hello world</span>`;
$('#test').html(span);
})
body {
background: #20262E;
padding: 20px;
font-family: Helvetica;
}
#banner-message {
background: #fff;
border-radius: 4px;
padding: 20px;
font-size: 25px;
text-align: center;
transition: all 0.2s;
margin: 0 auto;
width: 300px;
}
button {
background: #0084ff;
border: none;
border-radius: 5px;
padding: 8px 14px;
font-size: 15px;
color: #fff;
}
#banner-message.alt {
background: #0084ff;
color: #fff;
margin-top: 40px;
width: 200px;
}
#banner-message.alt button {
background: #fff;
color: #000;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div id="banner-message">
<p id="test">Hello World</p>
<button>Add title</button>
</div>
- Нажмите кнопку добавить заголовок
- Наведите курсор на элемент, чтобы проверить заголовок
Ожидается: показывать заголовок как тестовый скрипт.
Фактически: заголовок отображается как тест