I see developers getting confused on when to use the jQuery .text() vs .html() functions. So I thought of writing a simple demo to clear the confusion
.html() – gets or sets the HTML within a selected element. When you supply it a string with HTML, it renders the HTML. .html()
cannot be used in in XML documents
.text() – gets or sets the Text within a selected element. Unlike .html(),
.text()
cannot alter the HTML. So if you supply a string containing HTML inside .text()
, it will display the HTML (by converting elements with corresponding character entities) and not render it. However .text()
can be used in both XML and HTML documents
Here’s an example
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
<title>.text() and .html() in jQuery from DevCurry.com</title>
<style type="text/css">
.colorDiv { color:blue; }
</style>
<script type="text/javascript"
src="http://ajax.aspnetcdn.com/ajax/jQuery/jquery-1.5.min.js"></script>
<script type="text/javascript">
$(function () {
$("#btnHtml").click(function () {
$("#divOne")
.html('<span class="colorDiv">HTML and Content gets changed</span>');
});
$("#btnText").click(function () {
$("#divTwo").text('Only Content gets changed');
});
});
</script>
</head>
<body>
<div id="divOne">This is a simple looking DIV</div><br />
<div id="divTwo">This is another simple looking DIV</div><br />
<input id="btnHtml" type="button" value=".html()" />
<input id="btnText" type="button" value=".text()" />
</body>
</html>
As you can see, we are using two Div’s in our example. When the btnHtml is clicked, we use .html()
to add a <span> element with class colorDiv and some new text in it. So we are able to change both the HTML and the Content using .html()
.
When the btnText is clicked, we are able to change only the text, since it’s not possible to change the HTML using .text()
See a Live Demo
No comments:
Post a Comment