Developerzzz
Developerzzz

Reputation: 1126

angular Scope variable is not binding in to iframe

i am creating hidden iframe for printing some data, but my code is not working properly, i want to show some data in that iframe by using angular scope variable bellow is my code.

        // print attached contract documnet
    function print(imageData) {
        var hiddenFrame = $('<iframe style="display: none"></iframe>').appendTo('body')[0];
        hiddenFrame.contentWindow.printAndRemove = function () {
            hiddenFrame.contentWindow.print();
            $(hiddenFrame).remove();
        };

        $scope.testObj = 'testing';
        var element = $compile('<div> {{testObj}} </div>')($scope);
        // var element = $compile($('<div> <img ng-src="{{ vm.contractDetails.contractAttachment.imageSRC }}" class="img-thumbnail img-responsive img-height " style="height:500px;cursor:pointer;" /> </div>'))(printScope);


        var htmlDocument = "<!doctype html>" +
            "<html>" +
            '<body onload="printAndRemove();">' +
            element.html() +
            '</body>' +
            "</html>";
        var doc = hiddenFrame.contentWindow.document.open("text/html", "replace");
        doc.write(htmlDocument);
        doc.close();
    }

then output is not proper print output

$scope.testObj is not binding properly.

Upvotes: 0

Views: 856

Answers (2)

Maxim Shoustin
Maxim Shoustin

Reputation: 77904

i want to show some data in that iframe by using angular scope variable

Short answer

You cannot pass $scope to iframe regards to your configuration.

From image, angular didn't load inside iframe

[EDIT 1]

If you want to pass base64 image to iframe you don't need angular.

Just call:

<iframe src="data:application/pdf;base64,BINARY_DATA"></iframe> 

If you want to use ng-src instead, to get rid of cross domain problem use $sce service:

<iframe  ng-src="{{someStuff}}"></iframe>

$scope.someFrame= $sce.trustAsResourceUrl("http://www.yourURL.com");

[EDIT 2]

 <iframe src="{{value}}"> </iframe>

Controller

app.controller('ctrlRead', function ($scope, $sce) {
    $scope.value= $sce.trustAsResourceUrl("");    
});

DEMO Fiddle

Upvotes: 1

RIYAJ KHAN
RIYAJ KHAN

Reputation: 15292

instead writing

var doc = hiddenFrame.contentWindow.document.open("text/html", "replace");
doc.write(htmlDocument);
doc.close();

Use ngBindHtml

$scope.myHtml  = $sce.trustAsHtml(data.html);

In the hiddenFrame,add one placeHolder variable {{myHtml}}.

It will Worke.

Upvotes: 0

Related Questions