admin管理员组文章数量:1131234
I am using SweetAlert plugin to display an alert. With a classical config (defaults), everything goes OK. But when I want to add a HTML tag into the TEXT, it display <b>...</b>
without making it bold. After searching for the answer, it looks like I don't have the right search word...
How to make SweetAlert display the text also with HTML code?
var hh = "<b>test</b>";
swal({
title: "" + txt + "",
text: "Testno sporocilo za objekt " + hh + "",
confirmButtonText: "V redu",
allowOutsideClick: "true"
});
I am using SweetAlert plugin to display an alert. With a classical config (defaults), everything goes OK. But when I want to add a HTML tag into the TEXT, it display <b>...</b>
without making it bold. After searching for the answer, it looks like I don't have the right search word...
How to make SweetAlert display the text also with HTML code?
var hh = "<b>test</b>";
swal({
title: "" + txt + "",
text: "Testno sporocilo za objekt " + hh + "",
confirmButtonText: "V redu",
allowOutsideClick: "true"
});
Share
Improve this question
edited Apr 17, 2024 at 16:12
informatik01
16.4k11 gold badges78 silver badges108 bronze badges
asked Nov 10, 2014 at 7:42
PeterPeter
1,6692 gold badges21 silver badges27 bronze badges
3
|
13 Answers
Reset to default 234The SweetAlert repo seems to be unmaintained. There's a bunch of Pull Requests without any replies, the last merged pull request was on Nov 9, 2014.
I created SweetAlert2 with HTML support in modal and some other options for customization modal window - width, padding, Esc button behavior, etc.
Swal.fire({
title: "<i>Title</i>",
html: "Testno sporocilo za objekt: <b>test</b>",
confirmButtonText: "V <u>redu</u>",
});
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
A feature to allow HTML for title and text parameters has been added with a recent merge into the master branch on GitHub https://github.com/t4t5/sweetalert/commit/9c3bcc5cb75e598d6faaa37353ecd84937770f3d
Simply use JSON configuration and set 'html' to true, eg:
swal({ html:true, title:'<i>TITLE</i>', text:'<b>TEXT</b>'});
This was merged less than a week ago and is hinted at in the README.md (html is set to false in one of the examples although not explicitly described) however it is not yet documented on the marketing page http://tristanedwards.me/sweetalert
I was upgrading from old sweetalert and found out how to do it in the new Version (official Docs):
// this is a Node object
var span = document.createElement("span");
span.innerHTML = "Testno sporocilo za objekt <b>test</b>";
swal({
title: "" + txt + "",
content: span,
confirmButtonText: "V redu",
allowOutsideClick: "true"
});
Sweet alerts also has an 'html' option, set it to true.
var hh = "<b>test</b>";
swal({
title: "" + txt + "",
html: true,
text: "Testno sporocilo za objekt " + hh + "",
confirmButtonText: "V redu",
allowOutsideClick: "true"
});
I just struggled with this. I upgraded from sweetalert 1 -> 2. This library: https://sweetalert.js.org/guides/
The example from documentation "string" doesn't work as I expected. You just can't put it like this.
content: `my es6 string <strong>template</strong>`
How I solved it:
const template = (`my es6 string <strong'>${variable}</strong>`);
content: {
element: 'p',
attributes: {
innerHTML: `${template}`,
},
}
There is no documentation how to do this, it was pure trial and error, but at least seems to work.
As of 2018, the accepted answer is out-of-date:
Sweetalert is maintained, and you can solve the original question's issue with use of the content option.
Use SweetAlert's html
setting.
You can set output html direct to this option:
var hh = "<b>test</b>";
swal({
title: "" + txt + "",
html: "Testno sporocilo za objekt " + hh + "",
confirmButtonText: "V redu",
allowOutsideClick: "true"
});
Or
swal({
title: "" + txt + "",
html: "Testno sporocilo za objekt <b>teste</b>",
confirmButtonText: "V redu",
allowOutsideClick: "true"
});
There's sweet Alert version 1 and 2. Actual version 2 works with HTML nodes.
I have a Sweet Alert 2 with a data form that looks this way:
<script>
var form = document.createElement("div");
form.innerHTML = `
<span id="tfHours">0</span> hours<br>
<input style="width:90%;" type="range" name="tfHours" value=0 step=1 min=0 max=25
onchange="window.changeHours(this.value)"
oninput="window.changeHours(this.value)"
><br>
<span id="tfMinutes">0</span> min<br>
<input style="width:60%;" type="range" name="tfMinutes" value=0 step=5 min=0 max=60
onchange="window.changeMinutes(this.value)"
oninput="window.changeMinutes(this.value)"
>`;
swal({
title: 'Request time to XXX',
text: 'Select time to send / request',
content: form,
buttons: {
cancel: "Cancel",
catch: {
text: "Create",
value: 5,
},
}
}).then((value) => {
console.log(value);
});
window.changeHours = function (value){
var tfHours = document.getElementById("tfHours");
tfHours.innerHTML = value;
}
window.changeMinutes = function (value){
var tfMinutes = document.getElementById("tfMinutes");
tfMinutes.innerHTML = value;
}
Have a go to the Codepen Example!
I know that my answer may come in too late, but i found a fix that works for me.
- Create an object to hold in your html content
var html_element = '<p><code>This</code> is an error</p>';
- Then proceed on to create your sweet alert element
swal({ title: "My Title", text: "", html: true, confirmButtonText: "Okay" });
Use javascript setTimeout function to append your html into the sweet alert. I found that setting the timeout to 210 works well
setTimeout(function(){ $('.sweet-alert p:eq(0)').html(html_element) },210);
And You have done it!
All you have to do is enable the html variable to true.. I had same issue, all i had to do was html : true ,
var hh = "<b>test</b>";
swal({
title: "" + txt + "",
text: "Testno sporocilo za objekt " + hh + "",
html: true,
confirmButtonText: "V redu",
allowOutsideClick: "true"
});
Note: html : "Testno sporocilo za objekt " + hh + "",
may not work as html porperty is only use to active this feature by assign true / false value in the Sweetalert.
this html : "Testno sporocilo za objekt " + hh + "",
is used in SweetAlert2
You can use compiled elements at hidden div and get the div by id and put like this:
var wrapper = document.getElementById('yourdiv');
swal({
icon: "sucess",
text: "Your Content",
content: wrapper
})
This is reaaally old, but it may help someone. With SweetAlert you can do it this way (This is an example implementation for a confirmation modal using SweetAlert with html content):
// Confirmation modal (with Sweet Alert)
async function sw_confirm(msg = undefined, title = undefined, showIcon = true, danger = true) {
const spanContent = document.createElement("span");
spanContent.style.textAlign = "left";
spanContent.innerHTML = msg || '';
return resp = await swal({
title: title || "Are you sure?",
content: spanContent,
icon: showIcon ? "warning" : '',
buttons: true,
dangerMode: danger,
})
.then((resp) => {
console.log(resp)
return resp ? true : false;
});
}
Also, include css formatting on the page, so the span text can be aligned.
.swal-content {
display: flex;
}
I assume that </
is not accepted inside the string.
Try to escape the forward slash "/" by preceding it with a backward slash "\" for example:
var hh = "<b>test<\/b>";
本文标签: javascriptSweetAlert how to display HTML code in textStack Overflow
版权声明:本文标题:javascript - SweetAlert: how to display HTML code in text? - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1736768824a1951970.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
text()
to insert content, therefore HTML is encoded. Unless there is an option to change this behaviour you will most likely have to find a different plugin. – Rory McCrossan Commented Nov 10, 2014 at 7:48