我正在寻找在php代码中包含javascript函数的可能性。
代码应该从搜索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函数,而是应该重复的播放列表变量。
在PHP中,您可以创建一个数组,并用这些属性的数组填充它。类似于:
$results = array();
while ($dsatz = mysql_fetch_assoc($res)) {
$results[]=$dsatz; }
$printout = json_encode($results);
现在要将其放入JavaScript中,您需要执行以下操作:
var myPlaylist = <?php echo $printout; ?>;
如果我理解正确,您将需要AJAX来完成这项工作。这里有一些地方可以开始:
W3Schools AJAX教程
Tizag的AJAX教程
此外,由于您已经在使用JQuery,它可以让您的AJAX生活更加轻松。
浏览JQuery AJAX APIhttp://api.jquery.com/category/ajax/
这是相当可能的,但abt如何使用json。JSON编码的字符串可以通过json_encode($array)
在php中生成。然后,您可以(可能使用AJAX)将JSON加载到当前页面中。
另一个选项是,从php代码生成javascript数组,然后将javascript数组包含在网页中。