我一直在网上寻找以下解决方案,希望有人能指出正确的方向。

我有一个在Codeigniter中构建的Web应用程序,主视图从模型的帖子流中加载。当前,用户必须刷新页面以获取最新内容,这并不理想,我要实现的是流div定期更新并加载新内容。

我是CI和Ajax的新手,我想知道是否有人可以提供解决方案。

一些代码...

模型

    function stream($uid, $updated, $limit) {
        $this->db->cache_on();
        $now = microtime(true);
        //$sql = "SELECT STATEMENT HERE";
        $query = $this->db->query($sql, array($uid, $uid, $updated, $limit));

        return $query->result();
    }


控制者

   function index() {
        if($this->session->userdata('logged_in')) {

            $session_data = $this->session->userdata('logged_in');
            $data['username'] = $session_data['username'];
            $data['first_name'] = $session_data['first_name'];
            $data['last_name'] = $session_data['last_name'];
            $data['avatar'] = $session_data['avatar'];
            $data['cover'] = $session_data['cover'];

            //Stream Data
            $updated = microtime(true);
            $limit = 100;
            $data['user_id'] = $session_data['id'];

            $this->load->library('pagination');

            $config['base_url'] = BASE_URL;
            $config['total_rows'] = $limit;
            $config['per_page'] = 10;
            $config['num_links'] = 20;

            $this->pagination->initialize($config);

            //$this->load->model('post');
            $data['results'] = $this->post->stream($data['user_id'], $updated, $limit);
            $data['notifications'] = $this->user->notifications($data['user_id']);
            $data['userStats'] = $this->user->getUserStats($data['user_id']);

            $this->load->view('home_view', $data);
            //$this->output->cache(1);
            //$this->output->enable_profiler(FALSE);
        } else {
            //If no session, redirect to login page
            redirect('/', 'refresh');
        }
    }


该视图很复杂,但从本质上讲,它对$results数组使用foreach循环,然后将键放入bootstrap div中,例如

<div class="row">
  <div class="col-sm-12">
    <div class="panel panel-default">
      <div class="panel-heading">
    <img src="<?php echo $user_avatar;?>" class="postAvatar">
    <h4><?php echo $user_full_name;?><br><small><i class="fa fa-map-marker"></i> <?php echo $relDate.' from '.$post_location ?></small></h4>
      </div>
      <div class="panel-body bodyText">
    <div class="postBody">
          <?php echo $formatted;?>
    </div>
      </div>
     </div>
   </div>
</div>

最佳答案

我强烈建议您看一下HTML5中引入的WebSocket technique。它是为诸如newsticker之类的东西而专门开发的。

还有一个用于支持跨浏览器的websocket库,称为socket-io

也许您也对this漂亮的jquery插件感兴趣。

HTML5 FTW!

09-17 02:50