2015-10-14 83 views
1

如何解码HTML实体我有一个使用PHP/jQuery来检索数据库中的信息自动完成脚本。使用jQuery/JavaScript的自动完成

<script type="text/javascript"> 
     $(function() { 
      var availableTags = <?php include('autocomplete.php'); ?>; 
      $("#artist_name").autocomplete({ 
       source: availableTags, 
       autoFocus:true 
      }); 
     }); 
    </script> 

我有正在显示HTML字符“E”,“&”,问题“O”被存储在数据库中&eacute;&amp;&eacute;

我不能让JavaScript代码显示用户选择的html字符。

如果我更改HTML实体特殊字符在数据库中,然后自动完成脚本停止工作完全。

我发现这个#1可能的解决方案,但我不知道是否如何,我有自动完成在JavaScript中实现,如果它会在所有解决我的问题。

<script> 
    function htmlDecode(input){ 
     var e = document.createElement('div'); 
     e.innerHTML = input; 
     return e.childNodes.length === 0 ? "" : e.childNodes[0].nodeValue; 
    } 
    htmlDecode("&lt;img src='myimage.jpg'&gt;"); 
    // returns "<img src='myimage.jpg'>" 
</script> 

我不擅长javascript编码。如何解码自动完成脚本中的html实体。请帮忙。谢谢。

Autocomplete.php代码:

<?php 
$connection = mysqli_connect("localhost","root","root","database_name") or die("Error " . mysqli_error($connection)); 

//fetch artist names from the artist table 
$sql = "select artist_name from artist_names"; 
$result = mysqli_query($connection, $sql) or die("Error " . mysqli_error($connection)); 

$dname_list = array(); 
while($row = mysqli_fetch_array($result)) 
{ 
    $dname_list[] = $row['artist_name']; 
} 
echo json_encode($dname_list); 
?> 
+0

请,提供的内容'autocomplete.php' – n00dl3

+0

@JuniusRendel对不起,延迟响应。我的互联网连线断开。无论如何,我已经添加了'autocomplete.php'脚本来结束我的问题。感谢您的回应。 – Soletwosole

+0

哦,我想我误解了你的问题,你的意思是,你的自动完成列表呈现为'

  • > div >
'其中ul和li是由jQueryUI的自动完成小部件创建的元素? – n00dl3

回答

0

请选择其中之一(但不能同时

PHP解决方案:如果要解码HTML实体你可以

第一次使用PHP的内置html_​entity_​decode()功能autocomplete.php

$dname_list = array(); 
while($row = mysqli_fetch_array($result)) 
{ 
    $dname_list[] = html_​entity_​decode($row['artist_name']); 
} 
echo json_encode($dname_list); 

JS解决方案:

jQueryUI's doc看看,你可以用它来建立自己的<li>元素,所以这将是这样的:

$("#artist_name").autocomplete({ 
    source: availableTags, 
    autoFocus: true, 
    _renderItem: function(ul, item) { 
     return $("<li>") 
      .attr("data-value", item.value) 
      //no need to unescape here 
      //because htmlentities will get interpreted 
      .append($("<a>").html(item.label)) 
      .appendTo(ul); 
    } 
}); 
+0

其实我觉得我错过了一些关于你的问题..? – n00dl3

+0

啊!从来不知道htmlentitiesdecode。我会试试这个。但因为是问题去,我想我试图找出是如何执行的自动完成脚本里面的'unescape' js函数。我在哪里可以将代码行放在自动完成脚本中? – Soletwosole

+0

我更新的JS只 – n00dl3