如何将使用php变量的javascript代码注入php页面

时间:2013-07-12 11:49:08

标签: php javascript jquery ajax

我创建了一个php页面和javascript代码,其中包含PHP页面中的一些变量,这是一个使用Javascript将php变量插入数据库的代码:

<?php
     $id = "Kevin";
     $user = "Calvin";
?>
<!-- include jquery library file-->
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
<!-- The ajax/jquery stuff -->
<script type="text/javascript">
    function send(e){
        if(e.keyCode == 13 && !e.shiftKey){

$(document).ready(function(){
   //Get the input data using the post method when Push into mysql is clicked .. we       pull it using the id fields of ID, Name and Email respectively...

//Get values of the input fields and store it into the variables.
    var msg=$("#reply").val();
    clear();
//here you start PHP->>
//here we put the PHP Variables ^^^^^^^^^///\\\

//use the $.post() method to call insert.php file.. this is the ajax request
   $.post('full.php', {msgg: msg, from: <?php echo json_encode($id); ?>, to: <?php echo json_encode($user); ?>},
    function(data){
        $("#message").html(data);
        $("#message").hide();
        $("#message").fadeIn(200); 
    });
    function clear() {
        $("#myre :input").each(  function() {
        $(this) .val('');
    });
    }
    }); 

   }
 } 
</script>

并在full.php页面中

<?php
     mysql_connect("localhost","root","");
     mysql_select_db("db");
     $to=mysql_real_escape_string($_POST['to']);
     $from=mysql_real_escape_string($_POST['from']);
     $msg=mysql_real_escape_string($_POST['msgg']);
     $to = mysql_real_escape_string($to);
     $from = mysql_real_escape_string($from);
     $msg = mysql_real_escape_string($msg);     
     if(empty($msg)){
        exit();
     }
    $query=mysql_query("INSERT INTO `message`(`user`,`who`,`message`) VALUES ('$to','$from','$msg')");
    if($query){
        echo "Perfect!";
    }else{
        echo "Failed!!";
?>

那么有没有办法将Javascript代码放入另一个页面并使用ajax注入它?

1 个答案:

答案 0 :(得分:0)

将PHP变量的值分配给java脚本变量:

<script type="text/javascript">
    var json{
    "id":<?php echo $id;?>,
    "user" : "<?php echo $user;?>"
    };
</script>

从您的代码中更改此行:

 $.post('full.php', {msgg: msg, from: json.id, to: json.user}

现在你将拥有单独的js文件,如:

      function send(e){
        if(e.keyCode == 13 && !e.shiftKey){

$(document).ready(function(){
//Get the input data using the post method when Push into mysql is clicked .. we pull it using the id fields of ID, Name and Email respectively...

//Get values of the input fields and store it into the variables.
var msg=$("#reply").val();
clear();
//here you start PHP->>
//here we put the PHP Variables ^^^^^^^^^///\\\

//use the $.post() method to call insert.php file.. this is the ajax request
$.post('full.php', {msgg: msg, from: json.id, to: json.user},
function(data){
$("#message").html(data);
$("#message").hide();
$("#message").fadeIn(200); 
});
function clear() {
$("#myre :input").each(  function() {
    $(this) .val('');
    });
}
}); 

   }
    } 

说这个文件是myjs.js现在包含在php文件中:

<script type="text/javascript" src="myjs.js" />