国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

AngularJS中取消對HTML片段轉義的方法例子

2024-05-06 16:13:37
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了AngularJS中取消對HTML片段轉義的方法例子,在一些需要顯示HTML的地方,就要取消AngularJS的轉義,本文就介紹了這種方法,需要的朋友可以參考下
 
 

今天嘗試用 Rails 做后端提供 JSON 格式的數據, AngularJS 做前端處理 JSON 數據,其中碰到 AngularJS 獲取的是一段 HTML 文本,如果直接使用 data-ng-bind 的話是被轉義過的,使用 data-ng-bind-html 則可以取消轉義。

但是直接使用 data-ng-bind-html 的話會提示錯誤

復制代碼代碼如下:

Error: [$sce:unsafe] Attempting to use an unsafe value in a safe context.

HTML 片段需要先使用 $sce.trustAsHtml(html_in_string) 將標記為信任,然后才可以使用 data-ng-bind-html="html_in_string" 取消轉義。

 

在我這里 Angular 通過 API 或取的所有文章中,每篇文章有個 html_body 屬性是經過 Markdown 或者 Org 渲染過的 HTML 片段。

在通過 API 獲取 JSON 數據后,使用 AngularJS 提供的 angular.forEach 方法對每個 post 的 html_body 進行標記,并將結果保存為 trustedBody, 然后在 HTML 中使用 data-ng-bind-html="post.trustedBody" 即可以取消轉義。

AngularJS 部分

復制代碼代碼如下:

Blog.controller('PostsController', function ($scope, $http, $sce) {
  $scope.posts = [];

 

  $scope.syncPosts = function () {
    var request = $http.get('http:/localhost:3000/posts.json');
    request.success(function (response) {
      $scope.posts = angular.forEach(angular.fromJson(response), function (post) {
        post.trustedBody = $sce.trustAsHtml(post.html_body);
      });
    });
  };

  $scope.syncPosts();
});


HTML 部分
復制代碼代碼如下:

<div class="post-body markup-body" data-ng-bind-html="post.trustedBody"></div>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 那曲县| 红原县| 富蕴县| 外汇| 斗六市| 福贡县| 洪湖市| 繁昌县| 那曲县| 综艺| 交城县| 龙江县| 鱼台县| 正安县| 靖边县| 改则县| 鄂尔多斯市| 乐清市| 锦州市| 介休市| 彝良县| 巢湖市| 临邑县| 邮箱| 鹰潭市| 正安县| 旬阳县| 美姑县| 城步| 米脂县| 裕民县| 禹城市| 湘阴县| 西峡县| 樟树市| 青神县| 手游| 中宁县| 定州市| 久治县| 界首市|