Using knockout.js, how do I include a carriage return in the text that is bound to the text attribute of a paragraph <p>
element.
In my ViewModel I generated a string of text that is bound to the <p>
in the View. I want to include carriage returns in the string which the browser displays with the line breaks.
Including <br />
or Environment.NewLine
in the string does not seem to work.
You can use the html binding.
JS:
function AppViewModel() {
this.firstName = "Bert<br\>Test";
this.lastName = "Bertington";
}
// Activates knockout.js
ko.applyBindings(new AppViewModel());
View :
<p>First name: <strong data-bind="html: firstName">todo</strong></p>
<p>Last name: <strong>todo</strong></p>
See fiddle
You need to set a css property in your element. white-space: pre-wrap
<p style="white-space: pre-wrap">First name: <strong data-bind="text: firstName">todo</strong></p>
<p>Last name: <strong>todo</strong></p>
function AppViewModel() {
this.firstName = "Bert" + " \n " + "Test";
this.lastName = "Bertington";
}
// Activates knockout.js
ko.applyBindings(new AppViewModel());
Then the code works. with \n
You could also use spans to get your bindings and then the html will be as usual.
<span data-bind="text: firstName"></span><br /><span data-bind="text: lastName"></span>