如何在js里引用php变量

JavaScript021

如何在js里引用php变量,第1张

类似这样:在JavaScript中放置php变量。

<?php 

    $h5course = 'h5course-com'

 ?>

 <!DOCTYPE html>

 <html>

 <head>

     <meta charset="UTF-8" />

     <title>PHP语言</title>

 </head>

 <body>

     <div class="wrap"></div>

     <script type="text/javascript">

        var h5course = "<?php echo $h5course ?>"

        alert(h5course)

     </script>

 </body>

 </html>

js仅在 浏览器中运行.

php 仅在服务器端运行.

2者交互, 通常通过 http get/post 协议进行交互.

因此, 要将 js 变量传输到 php, 需通过 get/post 将参数传入.

譬如:

<script>

function test(){

var x="abc"

$.ajax("test.php?x="+x)

}

</script>

而 test.php 中, 通过 $_REQUEST["x"] 即可拿到js 请求过来的变量.

追问

感觉你的答案最符合我的需求,只是我还是碰到了问题。

test.php文件中

onchange事件触发test()函数,并将赋值。

<script>

function test(){

var x="abc"

$.ajax("test.php?x="+x)

}

test.php文件中

echo $_REQUEST["x"]并未获取到有效值。echo没有输出。

请问,这到底是什么原因。

追答

是因为 <script>中并没有输出由 php 传回的结果.

改成这个试试看.

1

2

3

4

5

6

<script>

function test(){

var x="abc"

$.ajax("test.php?x="+x),null,function(data){alert(data)})

}

</script>

php和js是两码事!

php是服务器端脚本语言,

运行与服务器端(比如Apache、iis等)

js是客户端脚本,

运行于客户端(比如浏览器)

运行顺序也不同,

php先运行,js后运行!

js变量可以用php生成,

因为php先运行,

可以输出js变量到浏览器!

php变量必须由php本身生成,

js不能给php生成变量!