将JavaScript代码插入php

时间:2012-03-11 10:17:14

标签: php javascript phpmyadmin

我正在寻找将javascript函数包含到php代码中的可能性。

代码应该从搜索php文件中获取结果,然后以Javascript播放列表的形式打印出来。

这是javascript代码:

<script type="text/javascript"> 
$(document).ready(function(){

var description = ''; 
var myPlaylist = [ {

    mp3:'./../sounds/mysql-upload',
    title:'mysql-title',
    artist:'mysql-artist',
    subcategory:'mysql-subcategory',
    date:'mysql-date',
    rating:'mysql-rating',
    },

    /* var myPlaylist has to repeat */

]; 

$('#main').ttwMusicPlayer(myPlaylist, { 
autoPlay:false, 
description:description, }
);

}); 
</script>

这是php代码:

 <?php
    if (!empty($_POST['search'])) {

    /* Connect to database */
    $hostname = '';
    $database = '';
    $username = '';
    $password = '';
    if (!($mysql_link = mysql_connect($hostname, $username, $password))) {
    die('Could not connect');
    }

    /* Select databse */
    if (!($db_selected = mysql_select_db($database, $mysql_link))) {
        die('Could not find database');
    }

    /* Send mysql command */
    $sql_cmd = "SELECT * FROM sounds WHERE `keywords` LIKE '"
    . $_POST['search']."%'";
    if (!($res = mysql_query($sql_cmd))) {
        die('Invalid MySQL query');
    }

    /* Show results */
    while ($dsatz = mysql_fetch_assoc($res)) {

    $upload = $dsatz["upload"];
    $title = $dsatz["title"];
    $artist = $dsatz["artist"];
    $subcategory = $dsatz["subcategory"];
    $date = $dsatz["date"];
    $rating = $dsatz["rating"];

    /* Here should be the Javascript code */

    }

    /* Close database connection */
    mysql_close($mysql_link);
    }
?>

请注意,我不想在php代码的结果部分中包含完整的Javascript函数,但是应该重复的播放列表变量。

3 个答案:

答案 0 :(得分:2)

在PHP中,您可以创建一个数组,并用这些属性的数组填充它。 类似的东西:

$results = array();
while ($dsatz = mysql_fetch_assoc($res)) {
    $results[]=$dsatz; }
$printout = json_encode($results);

现在把它放到JavaScript中,你会这样做:

var myPlaylist = <?php echo $printout; ?>;

答案 1 :(得分:1)

如果我理解正确,你需要AJAX才能做到这一点。以下是一些开始的地方:

W3Schools AJAX Tutorial
Tizag's AJAX Tutorial

此外,由于您已经在使用JQuery,它可以让您更轻松地使用AJAX。

http://api.jquery.com/category/ajax/

查看JQuery AJAX API

答案 2 :(得分:0)

这是相当可能的,但是如何使用json替代。可以通过json_encode($array)在php中生成JSON编码的字符串。然后,您可以使用AJAX将json加载到当前页面。

另一种选择是,从php代码生成javascript数组,然后将javascript数组包含在网页上。