当前位置: 首页 > 面试题库 >

如何将变量和数据从PHP传递到JavaScript?

罗伟兆
2023-03-14
问题内容

我在PHP中有一个变量,我的JavaScript代码中需要它的值。如何将变量从PHP转换为JavaScript?

我有看起来像这样的代码:

<?php
     ...
     $val = $myService->getValue(); // Makes an API and database call
?>

我有需要val和看起来类似以下内容的JavaScript代码:

<script>
    myPlugin.start($val); // I tried this, but it didn't work
    <?php myPlugin.start($val); ?> // This didn't work either
    myPlugin.start(<?=$val?> // This works sometimes, but sometimes it fails
</script>

问题答案:

实际上,有几种方法可以做到这一点。有些需要比其他更多的开销,有些被认为比其他更好。

没有特别的顺序:

  1. 使用AJAX从服务器获取所需的数据。
  2. 将数据回显到页面中的某个位置,然后使用JavaScript从DOM获取信息。
  3. 将数据直接回显到JavaScript。

在本文中,我们将研究上述每种方法,并了解每种方法的优缺点以及如何实现它们。

这种方法被认为是最佳方法,因为 服务器端脚本和客户端脚本是完全分开的

优点

  • 更好地分隔各层 -如果明天您停止使用PHP,并希望移至servlet,REST API或某些其他服务,则无需更改很多JavaScript代码。
  • 更具可读性 -JavaScript是JavaScript,PHP是PHP。如果不将两者混在一起,则可以在两种语言上获得更具可读性的代码。
  • 允许异步数据传输 -从PHP获取信息可能很耗时间/资源。有时,您只是不想等待信息,加载页面以及随时获取信息。
  • 不能在标记上直接找到数据 -这意味着标记不会包含任何其他数据,只有JavaScript可以看到。

缺点

  • 延迟 -AJAX创建一个HTTP请求,并且HTTP请求通过网络承载并具有网络延迟。
  • 状态 -通过单独的HTTP请求获取的数据将不包含来自获取HTML文档的HTTP请求的任何信息。您可能需要此信息(例如,如果HTML文档是为响应表单提交而生成的),并且,如果需要,则必须以某种方式进行传递。如果您排除了将数据嵌入页面的能力(如果使用此技术,则必须具有该能力),那么这会将您限制为cookie /会话,这可能会受到竞争条件的影响。

实施实例

使用AJAX,您需要两个页面,一个页面是PHP生成输出的位置,第二个页面是JavaScript获取该输出的位置:

get-data.php

/* Do some operation here, like talk to the database, the file-session
 * The world beyond, limbo, the city of shimmers, and Canada.
 *
 * AJAX generally uses strings, but you can output JSON, HTML and XML as well.
 * It all depends on the Content-type header that you send with your AJAX
 * request. */

echo json_encode(42); // In the end, you need to **echo** the result.
                      // All data should be _json_encode()_ d.

                      // You can json_encode() any value in PHP, arrays, strings,
                      //even objects.

index.php(或任何实际的页面都这样命名)

<!-- snip -->
<script>
    function reqListener () {
      console.log(this.responseText);
    }

    var oReq = new XMLHttpRequest(); // New request object
    oReq.onload = function() {
        // This is where you handle what to do with the response.
        // The actual data is found on this.responseText
        alert(this.responseText); // Will alert: 42
    };
    oReq.open("get", "get-data.php", true);
    //                               ^ Don't block the rest of the execution.
    //                                 Don't wait until the request finishes to
    //                                 continue.
    oReq.send();
</script>
<!-- snip -->

42当文件完成加载时,两个文件的上述组合将发出警报。

2.将数据回显到页面中的某个位置,然后使用JavaScript从DOM获取信息。

这种方法不如AJAX更好,但仍具有其优点。它仍然 比较 PHP和JavaScript之间的感觉,有没有直接PHP在JavaScript中分离出来。

优点

  • 快速 -DOM操作通常很快,因此您可以相对快速地存储和访问许多数据。

缺点

  • 潜在的非语义标记 -通常,发生的事情是您使用某种方式<input type=hidden>来存储信息,因为从中获取信息更加容易inputNode.value,但是这样做意味着您在HTML中具有无意义的元素。HTML具有<meta>用于有关文档的数据的元素,而HTML 5引入data-*了专门用于可与特定元素相关联的JavaScript读取的数据属性。
  • 使源代码变脏-PHP 生成的数据直接输出到HTML源代码,这意味着您将获得更大,更集中的HTML源代码。
  • 很难获得结构化数据 -结构化数据必须是有效的HTML,否则您必须自己转义和转换字符串。
  • 将PHP与您的数据逻辑紧密结合 -因为在演示中使用了PHP,所以您不能将两者完全分开。

实施实例

这样做的想法是创建某种元素,该元素不会显示给用户,但对JavaScript可见。

index.php

<!-- snip -->
<div id="dom-target" style="display: none;">
    <?php
        $output = "42"; // Again, do some operation, get the output.
        echo htmlspecialchars($output); /* You have to escape because the result
                                           will not be valid HTML otherwise. */
    ?>
</div>
<script>
    var div = document.getElementById("dom-target");
    var myData = div.textContent;
</script>
<!-- snip -->

3.将数据直接回显到JavaScript

这可能是最容易理解的。

优点

  • 非常容易实现 -只需很少的时间即可实现并理解。
  • 不污染源 -变量直接输出到JavaScript,因此DOM不受影响。

缺点

  • 将PHP与您的数据逻辑紧密结合 -因为在演示中使用了PHP,所以您不能将两者完全分开。

实施实例

实施相对简单:

<!-- snip -->
<script>
    var data = <?php echo json_encode("42", JSON_HEX_TAG); ?>; // Don't forget the extra semicolon!
</script>
<!-- snip -->


 类似资料:
  • 问题内容: 我正在使用Google Maps制作可以加载数据库中包含经纬度数据的标记的地图。我希望用户可以通过单击按钮来加载三个不同的“图层”。单击该按钮时,将在服务器上执行php函数,从而根据数据库中的信息创建xml文件。然后调用AJAX函数提取此xml数据,然后将其用于创建地图标记。没有为每个“层”使用单独的PHP函数(除了SQL查询所在的行,这是相同的东西),有没有办法将AJAX中的java

  • 问题内容: 我似乎无法从php中将变量传递给我的bash脚本。无论我如何尝试,$ uaddress和$ upassword都变为空。 *_ __ _ __ __ * __ __ bash * __ __ * * ** *_ __ _ __ * PHP __ * __ __ * __ ** *_ __ _ _ _输出和调试 _ _ _ * *_ 问题答案: 您需要将变量作为参数传递给Shell脚本,

  • 问题内容: 我在将值从JS传递到PHP时遇到问题,以便可以将其用作PHP函数的参数。一旦单击链接,JS函数将由onclick事件触发。这是JS + HTML代码: PHP(insert.php): 感谢您能为我提供帮助的人。我对PHP和JS还是很陌生,所以请原谅我的愚蠢。 问题答案: 您将数据从浏览器传递到服务器。Javascript是一种用于操纵浏览器的语言。PHP是您的服务器端语言。 您可以在

  • 问题内容: 如何将值从javascript变量传递到razor变量,asp.net mvc razor视图引擎是否可能? 问题答案: 你不能 原因是他们不在同一时间“生活”。Razor变量是“服务器端变量”,在将页面发送到“客户端”后,它们不再存在。 当服务器收到视图请求时,它仅使用HTML,CSS和Javascript代码创建视图。没有C#代码,所有这些都被“翻译”为客户端语言。 当视图仍在服务

  • 本文向大家介绍如何将JavaScript变量传递给PHP?,包括了如何将JavaScript变量传递给PHP?的使用技巧和注意事项,需要的朋友参考一下 您可以在PHP的同一页面上轻松获取JavaScript变量值。尝试以下代码L。

  • 问题内容: 如何在不刷新页面的情况下将变量从jQuery传递到PHP?当我单击一个复选框时,我想将一个变量从jQuery传递到PHP。我也在使用formdialog。 我的PHP代码 我的JavaScript代码 问题答案: Ajax可以做到这一点。谷歌它,并检查api.jquery.com并查看ajax函数,.ajax(),.post(),.get(),.load()等。 关于您的特定问题,这是