添加其他用户?贴子
要将其他用户的贴子添加到一个用户的时间表(timeline)上,只需重用之前编写的一些代码。例如,现在已经知道如何获得当前用户正在追随的用户的列表。也知道如何获得某个用户发出的所有贴子。因此只需稍微修改后一个函数,使之能够接受一个用户列表,而不是单个用户。
现在只需在 index.php 文件中将第一个函数上移一点,以便马上使用它,然后使用通过该函数获得的用户 ID 列表,从他们的时间表中获取一定数量的贴子 — 这里不需要所有的贴子,只需 5 个左右。记住,要按日期倒序(最近的在上)排列那些用户的贴子。
首先,为 show_posts()
函数增加一个 limit 参数,将它的值默认为 0。如果 limit 大于 0,则将一个限制值添加到用于检索贴子的 SQL 语句中。另外要做的是将 $userid
参数放入到一个数组中,并将该数组解析到一个以逗号分隔的字段中,最后将该字段传递给 SQL 语句。这需要做一点额外工作,但是可以获得丰厚的回报,因为如您所见,所有贴子都将以倒序显示。
清单 18. 更新 show_posts()
,以接受一个用户数组
function show_posts($userid,$limit=0){ $posts = array();
$user_string = implode(",", $userid); $extra = " and id in ($user_string)";
if ($limit > 0){ $extra = "limit $limit"; }else{ $extra = ""; }
$sql = "select user_id,body, stamp from posts where user_id in ($user_string) order by stamp desc $extra"; echo $sql; $result = mysql_query($sql);
while($data = mysql_fetch_object($result)){ $posts[] = array( "stamp" => $data->stamp, "userid" => $data->user_id, "body" => $data->body ); } return $posts;
}
|
现在回到 index.php 文件,将不止一个用户 ID 传递给 show_posts()
,如下面的清单所示。这其实很简单,因为已经收集到了这些用户。现在只需使用 array_keys()
取出键值,将会话变量加到数组中。这样,传递的数组最少包含一个值(已登录的当前用户的 ID),最多则包含当前用户 ID 和该用户追随的每个用户的 ID。
清单 19. 将一个用户数组传递给 show_posts()
函数
$users = show_users(添加其他用户?贴子
要将其他用户的贴子添加到一个用户的时间表(timeline)上,只需重用之前编写的一些代码。例如,现在已经知道如何获得当前用户正在追随的用户的列表。也知道如何获得某个用户发出的所有贴子。因此只需稍微修改后一个函数,使之能够接受一个用户列表,而不是单个用户。
现在只需在 index.php 文件中将第一个函数上移一点,以便马上使用它,然后使用通过该函数获得的用户 ID 列表,从他们的时间表中获取一定数量的贴子 — 这里不需要所有的贴子,只需 5 个左右。记住,要按日期倒序(最近的在上)排列那些用户的贴子。
首先,为 show_posts() 函数增加一个 limit 参数,将它的值默认为 0。如果 limit 大于 0,则将一个限制值添加到用于检索贴子的 SQL 语句中。另外要做的是将 $userid 参数放入到一个数组中,并将该数组解析到一个以逗号分隔的字段中,最后将该字段传递给 SQL 语句。这需要做一点额外工作,但是可以获得丰厚的回报,因为如您所见,所有贴子都将以倒序显示。
清单 18. 更新 show_posts() ,以接受一个用户数组
function show_posts($userid,$limit=0){ $posts = array();
$user_string = implode(",", $userid); $extra = " and id in ($user_string)";
if ($limit > 0){ $extra = "limit $limit"; }else{ $extra = ""; }
$sql = "select user_id,body, stamp from posts where user_id in ($user_string) order by stamp desc $extra"; echo $sql; $result = mysql_query($sql);
while($data = mysql_fetch_object($result)){ $posts[] = array( "stamp" => $data->stamp, "userid" => $data->user_id, "body" => $data->body ); } return $posts;
}
|
现在回到 index.php 文件,将不止一个用户 ID 传递给 show_posts() ,如下面的清单所示。这其实很简单,因为已经收集到了这些用户。现在只需使用
免责声明: 本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
|