0

我目前正在开发一个 chrome 扩展,它允许在用户发送单词时显示图片。我使用 AJAX 和 JQUERY 来获取图片。

在弹出窗口中显示图片时遇到问题。事实上,它适用于普通的 html 页面,但不适用于弹出窗口。

如果你想测试:http ://algec.iut-blagnac.fr/~groupe6pjt/testAjax/pageHTML.html 。

当我尝试在弹出窗口中显示图片时,JavaScript 控制台中出现此错误:

无法加载资源 chrome-extension://pmbnmemdpheopedlikgmdeegebojkoji/chamoix.png

我有一个带有裂缝的小图像图标,而不是图片。

我认为这不是图片路径的问题,因为它在我们的页面上工作(上面的链接)。

这是我的代码:

1. more_com.php(服务器上的php文件)

<?php

    print "<p>Je suis un fichier php 2.0 !</p>";

        $conn = mysql_connect("localhost", "groupe6pjt", "bfjrs2012") or die ("Connexion impossible");
        $base="groupe6pjt";
        mysql_select_db("$base") or die ("base inconnue"); 

        $requete2 = "select imgSigne from signe where idSigne=10;";
        $resultat2 = mysql_query($requete2) or die ("requete2 impossible");
        while($tab = mysql_fetch_array($resultat2))
        {
            echo $tab[0];
            echo "<br/><img  src=\"chamoix.png\" />";
        }
?>

2.popup.html

<!DOCTYPE html PUBLIC>
<html>
<head>
<link rel="stylesheet" href="css/bootstrap.css" type="text/css" media="screen">
<title>Techniques AJAX - XMLHttpRequest</title>
<script src="popup.js"></script>
</head>
<body>

<div id="bandeau">
<h4 style="color : white;">AIPS - Traduction LSF</h4>
</div>

<div id="obtenirTexte" class="well well-large">
<p><b>1)</b> Obtenir le texte surligné sur la page : </p>
    <form class="form-search">
    <div class="input-append">
        <input class="span2 search-query" name="text" style="height : 30px; width : 175px;" type="text" id="text"/><button id="effacer" class="btn btn-primary" name="effacer" style="height : 30px;" title="Effacer le mot"><img src="effacer.png" alt="Erreur"/></button>
    </div><br/><br/>
        <button id="submit" class="btn" title="1) Texte">Obtenir le texte</button>
    </form>
</div>

<div id="obtenirImage" class="well well-large">

    <div id="commentaires">
    <p><b>2)</b> Obtenir l'image correspondante : </p>
    </div>

    <form>
        <input id="more_com" class="btn" type="button" value="Obtenir l'image" title="2) Image"/>
    </form>

    <div id="message">
        <!-- PHP return here ! -->
    </div>

</div>
<!-- As you can see with Chrome you can't put script directly in the htlm code so I create a file with my function : fonction.js -->
<script language="JavaScript" type="text/javascript" src="jquery.js"></script>
<script language="JavaScript" type="text/javascript" src="fonction.js"></script>
<script language="JavaScript" type="text/javascript" src="fonction2.js"></script>
<script language="JavaScript" type="text/javascript" src="popup.js"></script>
</body>
</html>

3.函数.js

$(document).ready(function(){

        $("#more_com").click(function(){                                                                      //Cette fonction se déclenche quand on clique sur le bouton d'id "more_com" (ici "Obtenir l'image")
            var variableTest=$.ajax({
                 url : "http://algec.iut-blagnac.fr/~groupe6pjt/testAjax/more_com.php",      //Ca c'est la page PHP qu'on va devoir modifier pour qu'à la reception du mot elle affiche l'image correspondante (Ne pas changer !)
                 type : "GET",                                                                                                                                                                                           //On garde GET car on veut récupérer une donnée en envoyant des infos ( != POST )
                 //data : 'motRecher=' + COUCOU;      // *****A MODIFIER*****                  //On va devoir utiliser ce champ pour envoyer le mot surligné vers la page PHP "more_com.php" 
                 dataType : "html",                                                                                                                                                                              //Le type de données renvoyé par la page PHP (ici : c'est du html que la page renvoie)
            });

            variableTest.done(function(data, textStatus, jqXHR){                             //Si on atteind le fichier alors on affiche ce que retourne "more_com.php" (ici il retourne "Je suis un fichier PHP !")
              $("#message").html(data);                                                                                                                                     //Permet l'affichage du fichier PHP
            });

            variableTest.fail(function(jqXHR, textStatus){                                            //Si on atteind pas le fichier ...
                $("#message").html("<p>Erreur</p>");                                                   //...erreur
            });
        });
    });

我认为 Chrome 会阻止在弹出窗口中显示图片或类似的东西!

4

1 回答 1

0

您遇到的问题是图像是这样定义的

<img src="./chamoix.png"> 

此相对路径解析为

http://algec.iut-blagnac.fr/~groupe6pjt/testAjax/chamoix.png

在网页上,但尝试解析为

chrome-extension://pmbnmemdpheopedlikgmdeegebojkoji/chamoix.png

在扩展中。尝试使用绝对路径或 areplace()将其指向正确的地址。

于 2013-03-14T18:07:55.440 回答