我正在寻找将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函数,但是应该重复的播放列表变量。
答案 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。
查看JQuery AJAX API答案 2 :(得分:0)
这是相当可能的,但是如何使用json替代。可以通过json_encode($array)
在php中生成JSON编码的字符串。然后,您可以使用AJAX将json加载到当前页面。
另一种选择是,从php代码生成javascript数组,然后将javascript数组包含在网页上。