ATIKON ATIKON - 1 year ago 211
HTML Question

Can't display retrieved data with raw html angularjs

i'm trying to display retrieved content by ajax in raw html.
Here's my code in one file:

<html ng-app="fetch">
<title>Вывод с базы</title>
<link rel="stylesheet" href="//">
<script src=""></script>
<script src=""></script>

<div class="row">
<div class="container">
<h1>С базы вывод</h1>
<div ng-controller="dbCtrl">
<input type="text" ng-model="searchFilter" class="form-control">
<table class="table table-hover">
<th>News title</th>
<th>News description</th>
<tr ng-repeat="news in data | filter:searchFilter">
<td ng-bind-html='data'>{{news.description}}</td>

angular.module('fetch', ['ngSanitize']).controller('dbCtrl', ['$scope', '$http', function ($scope, $http) {
$ = data;
.error(function() {
$ = "error in fetching data";


But output of
<td ng-bind-html='data'>{{news.description}}</td>
this part not accept html tags.
Output is: [Object, object] and etc.

Here's my ajax.php

//database settings
$conn=new mysqli("1", "1", "1", "1");
// Check connection
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
mysqli_query($conn, "SET NAMES utf8mb4");

$result = mysqli_query($conn, "select * from rss where source='' limit 20");

$data = array();

while ($row = mysqli_fetch_array($result)) {
$data[] = $row;
echo json_encode($data);

I've add the angular-sanitize and ngSanitize to my module, what is the problem?

Answer Source

You can't use ng-bind-html and interpolation {{}} together.

So if you want to show the description, you should change


<td ng-bind-html='data'>{{news.description}}</td>


<td ng-bind-html="news.description"></td>

Note: If you want to display the object data, you must use JSON filter(otherwise it'll be rendered as [object Object]) and create a new cell <td> to display it:

<td ng-bind="data | json"></td>