免责声明:我是一名 iOS 开发人员,几乎没有 JQuery、PHP 或 MySQL 经验。
这是交易:我有一个包含电影信息(FilmTitle
、、、FilmGenre
等FilmDirector
)的 MySQL 数据库。
我的目标是:
- 从数据库中获取电影片名并将它们存储在
Array
.
我为此使用 PHP,并且工作正常。 - 将此 PHP
Array
传递给 JavaScriptArray
。
这也有效。 - 最后,使用 JavaScript
Array
,我想使用其内容填充下拉菜单createElement()
。
这不起作用。
我得到了各种愚蠢的东西:有些document.write()
命令正在工作,有些则没有;下拉菜单没有被填充;等等
第一个问题:这甚至是一个好的策略吗?我认为随着数据库中电影数量的变化,正确更新下拉菜单的唯一方法就是按照我的描述进行操作。
第二个问题:这应该都在 PHP 文件中,而不是 HTML 文件中,对吗?但是 PHP 甚至可以执行 JavaScript 函数吗?或者是否需要做一些特别的事情来完成这项工作?
编码
<?php
echo "<?xml version=\"1.0\" encoding=\"UTF-8\" ?>";
echo "<allFilms>";
$link = mysql_connect(" . . . . ");
$query = "select * from FilmsSmallTable";
$result = mysql_query($query);
// Declare array variable:
$allFilmTitles = array();
while($row = mysql_fetch_assoc($result))
{
echo "<film>";
echo "<FilmName>";
echo $row['FilmTitle'];
array_push($allFilmTitles, $row["FilmTitle"]);
echo "</FilmName>";
echo "</film>";
}
// Print array out to verify:
echo "Here is the array's full contents:<br/>";
print_r ($allFilmTitles);
//convert array to string using ":#:" as separator
$stringedArray = implode(":#:",$allFilmTitles);
echo "<br/><br/>";
echo "PHP Array converted to a PHP String (the 'stringedArray' variable) = <br/>";
print_r ($stringedArray);
echo "</allFilms>";
?>
<html>
<head>
<title>PHP & JS</title>
<script type="text/javascript">
function showArray() {
//Convert PHP string to JavaScript string
var JSArrayString = "<? print $stringedArray; ?>";
//Create JavaScript array
var JSarray = new Array();
var x;
//Fill JavaScript array from the converted string
JSarray = JSArrayString.split(":#:");
// And sort it:
JSarray.sort();
//document.write("JSarray's length = ", JSarray.length);
document.write("JSarray contains: ", JSarray);
// reset the Form's drop-down menu to contain no elements:
FilmsDropDownMenu.length = 0;
for (counter = 0; counter < JSarray.length; counter++) {
document.write("Counter = " + counter + "<br/>");
var newMenuItem=document.createElement("option");
newMenuItem.text = JSarray[counter];
try {
//currentMenu.add(newMenuItem, null); // standards compliant
FilmsDropDownMenu.add(newMenuItem, null); // standards compliant
}
catch(ex) {
//currentMenu.add(newMenuItem); // IE only
FilmsDropDownMenu.add(newMenuItem);
}
}
function displayUsersChoice() {
// Grab the INDEX number of the choice the user selected from that menu:
var tempMenu = document.getElementById("FilmsDropDownMenu").selectedIndex;
choice = tempMenu[choiceSelected].value;
alert ("You chose: " + choice);
}
</script>
</head>
<body onload="showArray()">
Hello!
<form id="myForm">
<select id="FilmsDropDownMenu" onChange="displayUsersChoice()">
<option>==Choose Film to Edit:==</option>
<option>Star Wars</option>
<option>Raiders</option>
<option>2001</option>
</select>
<input type="submit" value="Display Array" onclick="showArray()" />
</form>
<br/>
</body>
</html>