php:如何将数据库值传递给javascript / jquery函数

时间:2013-05-08 11:06:50

标签: php javascript jquery codeigniter

我正在我的项目中实现标签功能。 在我的演示标签中,我发现它们是在自动填充的javascript函数中传递名称。

这是我的演示项目中的一个功能,

   <script>
   $(function()
      {
          var sampleTags = ['c++', 'scala', 'groovy', 'haskell', 'perl', 'erlang', 'apl', 'cobol', 'go', 'lua'];
      ..................
      .................

所以,我想从我的php控制器传递值到这个函数,以便从我的数据库表中获取自动完成值

For example i am getting tags values from my db in my Controller like this:

 ` $data["query"] = $this->ordermodel->fetch_orderlist();`
   $this->load->view('tagpage', $data);  //loading my page tag page where above function exists

现在我如何将$data["query"]值传递给上面的javascript函数? 请帮忙

3 个答案:

答案 0 :(得分:2)

您可以使用PHP的json_encode将变量回显到页面上。此函数将PHP数组或对象转换为JavaScript可以使用的JSON对象:

<script>
$(function() {
      var sampleTags = <?php echo json_encode($query); ?>;
})();
</script>

但更好的方法是通过Ajax请求这些值。假设您有一个名为values.php的PHP脚本:

<?php
    #...
    #assign $query here
    #...
    echo json_encode($query);

然后,在JavaScript中(在您要使用sampleTags变量的页面上),您可以使用jQuery的.ajax函数来生成简单的Ajax请求:

<script>
var sampleTags;

$.ajax({
    url: 'values.php'
}).done(function(data) {
    if (data) {
       sampleTags = data;
    }
});
</script>

我没有测试过这个例子。显然,你会想要调整它以适应你的环境。

答案 1 :(得分:0)

您必须为此

编写ajax函数
$.ajax(
    url     :   "<?php echo site_url('controller/method')?>",
    type    :   'POST',
    data    :   'para=1',
    success :   function(data)
    {
        if(data){
            var sampleTags  =   data;
        }
    }
);

答案 2 :(得分:0)

只需回显你的php变量

 $(function()
      {
          var sampleTags = '<?php echo $data["query"]; ?>'