php - Endless scrolling and using the GET method to filter content -


i'm developing mobile site endless scrolling display content. endless scrolling achieved this script (my implementation of below). script works it's supposed to.

but of content categorized different types. on desktop version without endless scrolling, types filtered using method. however, since actual php connecting database stored on separate "ajax.php", filter parameters contained in not being passed it, resulting in ajax.php returning nothing. there way fix this? in advance

page displaying every:

<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <script src="javascript.js"></script> <script> $(document).ready(function() { $('#content').scrollpagination({ nop     : 5, // number of posts per scroll loaded offset  : 0, // initial offset, begins @ 0 in case error   : ' ', // when user reaches end message                             // displayed. can change if want. delay   : 500, // when scroll down posts load after delayed amount of time.                // usability concerns. can alter see fit scroll  : true // main bit, if set false posts not load user scrolls.                 // still load if user clicks.  }); }); </script> </head> <body>     <div id="content">         <!-- infinite scroll content here -->     </div> </body> </html> 

javascript.js:

(function($) {  $.fn.scrollpagination = function(options) {      var settings = {          nop     : 10, // number of posts per scroll loaded         offset  : 0, // initial offset, begins @ 0 in case         error   : ' ', // when user reaches end message                                     // displayed. can change if want.         delay   : 500, // when scroll down posts load after delayed amount of time.                        // usability concerns. can alter see fit         scroll  : true // main bit, if set false posts not load user scrolls.                         // still load if user clicks.     }      // extend options work plugin     if(options) {         $.extend(settings, options);     }      // each keep chainability.     return this.each(function() {                 // variables          $this = $(this);         $settings = settings;         var offset = $settings.offset;         var busy = false; // checks if scroll action happening                            // don't run multiple times          // custom messages based on settings         if($settings.scroll == true) $initmessage = '顯示更多';         else $initmessage = '顯示更多';          // append custom messages , ui         $this.append('<div class="content"></div><div class="loading-bar">'+$initmessage+'</div>');          function getdata() {              // post data ajax.php             $.post('ajax.php', {                  action        : 'scrollpagination',                 number        : $settings.nop,                 offset        : offset,              }, function(data) {                  // change loading bar content (it may have been altered)                 $this.find('.loading-bar').html($initmessage);                  // if there no data returned, there no more posts shown. show error                 if(data == "") {                      $this.find('.loading-bar').html($settings.error);                    }                 else {                      // offset increases                     offset = offset+$settings.nop;                       // append data content div                     $this.find('.content').append(data);                      // no longer busy!                       busy = false;                 }                 });          }             getdata(); // run function          // if scrolling enabled         if($settings.scroll == true) {             // .. , user scrolling             $(window).scroll(function() {                  // check user @ bottom of element                 if($(window).scrolltop() + $(window).height() > $this.height() && !busy) {                      // working, busy true                     busy = true;                      // tell user we're loading posts                     $this.find('.loading-bar').html('載入中...');                      // run function fetch data inside delay                     // useful if have content in footer                     // want user see.                     settimeout(function() {                          getdata();                      }, $settings.delay);                  }                });         }          // content can loaded clicking loading bar/         $this.find('.loading-bar').click(function() {              if(busy == false) {                 busy = true;                 getdata();             }          });      }); } })(jquery); 

ajax.php:

<?php mysql_connect('host', 'username', 'password') or die(); mysql_select_db('database');  #start enable chinese encoding mysql_query("set character_set_results=utf8"); #end enable chinese encoding  $offset = is_numeric($_post['offset']) ? $_post['offset'] : die(); $postnumbers = is_numeric($_post['number']) ? $_post['number'] : die();  $category = mysql_real_escape_string($_get['category']);   $run = mysql_query("select * table category='$category' order date desc limit ".$postnumbers." offset ".$offset);       while($row = mysql_fetch_array($run)) {          echo '             <a href="/video/video.php?id=' . $row['id'] . '&relatedgroup=' . $row['relatedgroup'] . '">             <div id="contentitemwrap">                 <div id="videostripe">&nbsp;</div>                 <div id="contentitemtitle">                     <h2>' . $row['name'] . ' <span class="relatedtype">(' . $row['relatedtype'] . ')</span></h2>                     於' . $row['date'] . '發表                     <p class="contenttext">' . $row['fbdescription'] . '</p>                 </div>                 <div id="widescreenimagewrap">                     <div id="widescreenimageratio">                     </div>                     <div id="widescreenimage">                         <img id="img100" src="' . $row['thumbnail'] . '" />                     </div>                 </div>             </div>             </a>         ';      } ?> 

assuming getting parameters want passed hosting page via query string should able change $.post call in getdata to:

        $.post('ajax.php'+window.location.search, {             action        : 'scrollpagination',             number        : $settings.nop,             offset        : offset,          }, function(data) {            ..... rest of code 

Comments

Popular posts from this blog

jquery - How can I dynamically add a browser tab? -

keyboard - C++ GetAsyncKeyState alternative -

android - java.net.UnknownHostException(Unable to resolve host “URL”: No address associated with hostname) -