Compiling dynamic HTML strings from database

前端 未结 5 1303
花落未央
花落未央 2020-11-22 02:14

The Situation

Nested within our Angular app is a directive called Page, backed by a controller, which contains a div with an ng-bind-html-unsafe attribute. This is

相关标签:
5条回答
  • 2020-11-22 02:51

    Found in a google discussion group. Works for me.

    var $injector = angular.injector(['ng', 'myApp']);
    $injector.invoke(function($rootScope, $compile) {
      $compile(element)($rootScope);
    });
    
    0 讨论(0)
  • 2020-11-22 02:52

    You can use

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

    directive to bind html dynamically. However you have to get the data via $sce service.

    Please see the live demo at http://plnkr.co/edit/k4s3Bx

    var app = angular.module('plunker', []);
    app.controller('MainCtrl', function($scope,$sce) {
        $scope.getHtml=function(){
       return $sce.trustAsHtml("<b>Hi Rupesh hi <u>dfdfdfdf</u>!</b>sdafsdfsdf<button>dfdfasdf</button>");
       }
    });
    
      <body ng-controller="MainCtrl">
    <span ng-bind-html="getHtml()"></span>
      </body>
    
    0 讨论(0)
  • 2020-11-22 03:00

    In angular 1.2.10 the line scope.$watch(attrs.dynamic, function(html) { was returning an invalid character error because it was trying to watch the value of attrs.dynamic which was html text.

    I fixed that by fetching the attribute from the scope property

     scope: { dynamic: '=dynamic'}, 
    

    My example

    angular.module('app')
      .directive('dynamic', function ($compile) {
        return {
          restrict: 'A',
          replace: true,
          scope: { dynamic: '=dynamic'},
          link: function postLink(scope, element, attrs) {
            scope.$watch( 'dynamic' , function(html){
              element.html(html);
              $compile(element.contents())(scope);
            });
          }
        };
      });
    
    0 讨论(0)
  • 2020-11-22 03:12

    Try this below code for binding html through attr

    .directive('dynamic', function ($compile) {
        return {
          restrict: 'A',
          replace: true,
          scope: { dynamic: '=dynamic'},
          link: function postLink(scope, element, attrs) {
            scope.$watch( 'attrs.dynamic' , function(html){
              element.html(scope.dynamic);
              $compile(element.contents())(scope);
            });
          }
        };
      });
    

    Try this element.html(scope.dynamic); than element.html(attr.dynamic);

    0 讨论(0)
  • 2020-11-22 03:13

    ng-bind-html-unsafe only renders the content as HTML. It doesn't bind Angular scope to the resulted DOM. You have to use $compile service for that purpose. I created this plunker to demonstrate how to use $compile to create a directive rendering dynamic HTML entered by users and binding to the controller's scope. The source is posted below.

    demo.html

    <!DOCTYPE html>
    <html ng-app="app">
    
      <head>
        <script data-require="angular.js@1.0.7" data-semver="1.0.7" src="https://ajax.googleapis.com/ajax/libs/angularjs/1.0.7/angular.js"></script>
        <script src="script.js"></script>
      </head>
    
      <body>
        <h1>Compile dynamic HTML</h1>
        <div ng-controller="MyController">
          <textarea ng-model="html"></textarea>
          <div dynamic="html"></div>
        </div>
      </body>
    
    </html>
    

    script.js

    var app = angular.module('app', []);
    
    app.directive('dynamic', function ($compile) {
      return {
        restrict: 'A',
        replace: true,
        link: function (scope, ele, attrs) {
          scope.$watch(attrs.dynamic, function(html) {
            ele.html(html);
            $compile(ele.contents())(scope);
          });
        }
      };
    });
    
    function MyController($scope) {
      $scope.click = function(arg) {
        alert('Clicked ' + arg);
      }
      $scope.html = '<a ng-click="click(1)" href="#">Click me</a>';
    }
    
    0 讨论(0)
提交回复
热议问题