该文件是否应作为有效的.js文件加载?

时间:2013-10-22 23:32:21

标签: javascript php jquery content-type

我正在尝试创建一个浏览器将其视为js文件的PHP文件,并且正在使用内容类型标头。但即使如此,也有一些不起作用的东西。所以我的问题是,这应该被解释为一个有效的.js文件吗?:

<?php 

    header('Content-Type: application/javascript'); 

    $mysql_host = "localhost";
    $mysql_database = "lalalala";
    $mysql_user = "lalalalal";
    $mysql_password = "lalalallaala";

    if (!mysql_connect($mysql_host, $mysql_user, $mysql_password))
        die("Can't connect to database");

    if (!mysql_select_db($mysql_database))
            die("Can't select database");

    mysql_query("SET NAMES 'utf8'");

?>
jQuery(document).ready(function() { 
    var urlsFinal = [
    <?php
        $result = mysql_query("SELECT * FROM offer_data ORDER BY id_campo DESC");
        while($nt = mysql_fetch_array($result)) {
    ?>
    "<?php echo $nt['url']; ?>",
    <?php
        };
    ?>
    "oiasdoiajsdoiasdoiasjdioajsiodjaosdjiaoi.com"
    ];
    scriptLoaded();
});

1 个答案:

答案 0 :(得分:1)

为了让您的浏览器将您的PHP文件看作.js文件,echoprint将整个PHP页面转换为字符串,就不需要使用任何标题,就像这样:

// First let's make a secure page called database.php - put in a restricted folder
<?php
  function db(){
    return new mysqli('host', 'username', 'password', 'database');
  }
?>
// now let's go over a new technique you'll cherish in the future - page.php
<?php
include 'restricted/database.php'; $db = db();
if($db->connect_errort)die("Can't connect to database. Error:".$db->connect_errno);
$db->query("UPDATE tabelName SET names='utf8' WHERE column='value'");
$sel = $db->query('SELECT * FROM offer_data ORDER BY id_campo DESC');
if($sel->num_rows > 0){
  while($nt = $db->fetch_object()){
    $output[] = $nt->url;
  }
}
else{
  die('No records were returned.')
}
$sel->free(); $out = implode("', '", $output); $db->close();
echo "jQuery(document).ready(function(){
  var urlsFinal = ['$out'];
  // more jQuery here - you may want to escape some jQuery \$ symbols
}"
?>

现在只需确保您的script代码如下:

<script type='text/javascript' src='page.php'></script>