Передача значения из PHP в JavaScript [дубликат]
-
23-08-2019 - |
Вопрос
На этот вопрос уже есть ответ здесь:
У меня есть PHP-код, как показано ниже.
<?php
echo "<SCRIPT LANGUAGE='javascript'>add dd_Employee('".$id1."','".$fname1."',".$sal1.");</SCRIPT>";
echo "<SCRIPT LANGUAGE='javascript'>add dd_Employee('".$id2."','".$fname2."',".$sal2.");</SCRIPT>";
....
?>
...
И мой код JavaScript содержит
var details=new Array();
function addEmployee(id,fname,salary){
var temp=new Array(id,fname,salary);
details[details.length]=temp;
alert(temp);
}
function displayEmployee(){
for (var i=0;i<details.length;i++)
var temp_details=details[i];
//Display the id,name,sal
var id=temp_details[0];
var name=temp_details[1];
var sal=temp_details[2];
alert(id);
alert(name);
alert(sal);
}
Теперь проблема в том, что все, что назначено PHP, будет видно только в AddEmployee
.Это означает, что он работает нормально.Но внутри displayEmployee
значение, присвоенное PHP, не будет работать.Есть ли ошибка в моей логике?
Решение
Просто заполните свою глобальную структуру данных напрямую, а не передавайте ее через функцию JavaScript.Вероятно, вы столкнулись с проблемой области переменных, поскольку вы выделяете память в addEmployee.
Пример:
<?php
print "details[details.length] = new Array('$id1', '$name1', '$salary1');\n";
?>
Другие советы
Похоже, вам не хватает фигурных скобок в цикле for.Прямо сейчас у вас есть 1-линия for
цикл, который ничего не делает, а присваивает значение вашей временной переменной, которая переобъявляется на каждой итерации.Я не могу вспомнить, каковы правила области действия JavaScript в этой ситуации, но обычно это плохая практика (если это намеренно).Попробуйте что-то подобное для своего displayEmployee()
метод.
function displayEmployee(){
for(var i=0; i<details.length; i++) {
var temp_details = details[i];
//Display the id, name, and sal.
var id = temp_details[0];
var name = temp_details[1];
var sal = temp_details[2];
alert(id);
alert(name);
alert(sal);
}
}
Это должно решить вашу непосредственную проблему.Если у вас есть контроль над всем вашим кодом, я бы рекомендовал превратить данные о сотрудниках в объект, чтобы ими было легче управлять.Для этого вам следует использовать этот PHP-код:
<?php
echo '<script>
addEmployee('.json_encode(array(
'id' => 'id1',
'name' => 'fname1',
'salary' => 1024,
)).');
addEmployee('.json_encode(array(
'id' => 'id2',
'name' => 'fname2',
'salary' => 2048,
)).');
</script>';
?>
А затем измените свой код JavaScript, чтобы он выглядел следующим образом:
var details = [];
function addEmployee(employeeObj){
details[details.length] = employeeObj;
alert(employeeObj);
}
function displayEmployee(){
for(var i=0; i<details.length; i++) {
alert(details[i].id);
alert(details[i].name);
alert(details[i].salary);
}
}
Я не тестировал этот код, но он должен работать.
У вас есть ошибка в вызове JavaScript, сгенерированном PHP.
echo "<SCRIPT LANGUAGE='javascript'>add dd_Employee('".$id1."','".$fname1."',".$sal1.");</SCRIPT>";
должно быть
echo "<SCRIPT LANGUAGE='javascript'>addEmployee('".$id1."','".$fname1."',".$sal1.");</SCRIPT>";
А если вы хотите изменить это на ООП?
<?php
$employeeList[] = array('sdf3434', 'Bob', 123.34);
$employeeList[] = array('wer335dg', 'Joe', 223);
?>
<html>
<head>
<script>
function Employees() {
this.list = new Array();
}
Employees.prototype.add = function (id, fname, sal) {
this.list.push(new Array(id, fname, sal));
};
Employees.prototype.display = function () {
for(var i=0, t = this.list.length;i<t;i++) {
var emp = this.list[i];
alert(emp[0]);
alert(emp[1]);
alert(emp[2]);
}
};
var employees = new Employees();
<?php
foreach ($employeeList as $employee) {
list($id, $fname, $sal) = $employee;
printf("employees.add('%s', '%s', %f);\n", $id, $fname, $sal);
}
?>
</script>
</head>
<body>
<a href="#" onclick="employees.display();">click</a>
</body>
</html>
Сообщение в блоге Обмен значениями со страницы JavaScript/HTML на PHP и со страницы PHP на JavaScript может быть полезно для некоторых.