Chase W.
Chase W.

Reputation: 1413

Angularjs html tag is showing

I am trying to add the following code.

$scope.journals = [
   {title: "Journal", content: "This is content <br>"}
]

The HTML that I have is:

<div ng-repeat="journal in journals">
   <h1>{{journal.title}}</h1>
   <span>{{journal.content}}</span>
</div>

However the "br" Tag is showing as just plain text and not html. How can I fix that?

Upvotes: 1

Views: 88

Answers (3)

Sericaia
Sericaia

Reputation: 450

You just need to use ng-bind-html directive, provided by angularjs

<span ng-bind-html="journal.content"></span>

Upvotes: 0

btm1
btm1

Reputation: 3856

if you don't want to mess with $sce and you just want to get er done:

lrApp.directive('bindHtml', function () {
return {
    restrict: 'A',
    link: function (scope, elem, attrs) {
        scope.$watch(attrs.bindHtml,function(nv,ov){
            elem.html(nv);
        });
    }
};
});

Upvotes: 1

brianmarco
brianmarco

Reputation: 353

Not sure if this can work for you but you can use a combination of ng-bind-html with $sce.trustAsHtml() to mark your content as trusted. Note that you'll only want to do this if you can truly consider the content as safe.

Here's a plunk as an example:

http://plnkr.co/edit/L51T4OxdF8AFF5lRQdQW

Here's the $sce documentation. Worth a read IMHO to understand the impact of trustAs.

https://docs.angularjs.org/api/ng/service/$sce

Upvotes: 0

Related Questions