微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

angularjs – ng-bind-html – 如何在新窗口中打开链接?

我正在使用ng-bind-html在我的网站上放置一些 HTML内容.问题是如果内容链接,则单击时链接在同一窗口中打开.如何在新窗口中打开它?

<div ng-bind-html="currentElement.content"></div>

解决方法

currentElement.content中包含的链接应具有target =’_ blank’属性

<a href="open/me/in/new/window" target="_blank">MyLink</a>

如果html内容来自外部源,您可以添加一个过滤器来解析html内容并将目标属性添加链接

这是一个草图:

return angular.element(htmlContent).find('a').attr('target','_blank');

更详细的

<!DOCTYPE html>
<html>

  <head>
    <script data-require="jquery@*" data-semver="2.1.1" src="//cdnjs.cloudflare.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
    <script data-require="angular.js@*" data-semver="1.3.0-beta.5" src="https://code.angularjs.org/1.3.0-beta.5/angular.js"></script>
    <script data-require="angular-sanitize@*" data-semver="1.2.13" src="http://code.angularjs.org/1.2.13/angular-sanitize.js"></script>
    <link rel="stylesheet" href="style.css" />
    <script src="script.js"></script>
  </head>

  <body ng-app="test" ng-controller="HomeCtrl">
    <h1>Test </h1>
    <div ng-bind-html="myHtml | addTargetBlank"></div>
  </body>

</html>

//script.js

angular.module('test',['ngSanitize'])
.filter('addTargetBlank',function(){
  return function(x) {
    var tree = angular.element('<div>'+x+'</div>');//defensively wrap in a div to avoid 'invalid html' exception
    tree.find('a').attr('target','_blank'); //manipulate the parse tree
    return angular.element('<div>').append(tree).html(); //trick to have a string representation
  }
})

.controller('HomeCtrl',function($scope){
  $scope.myHtml = 'test html content 1 <a href="#">click here</a>,test html content 2 <a href="#">click here</a>,test html content 3 <a href="#">click here</a>';
})
;

http://plnkr.co/edit/tpl:JHcBgtJ75fVaqFYQlE4a

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐