我有一个较小的网络应用程序,可以将内容从一个社交源重新发布到另一个社交源。用户可以说有5个选项来过滤该内容。它们的首选项作为1或0标记存储在我的用户数据库中。
当我每小时执行主要的“发布”操作时,分解我的代码以实现这些首选项的最佳方法是什么?为了更清楚,我目前的实现是这样的:
mysql_query(SELECT * FROM users);
foreach ($user as $row){
get_json_data($userID);
if ($pref1 == 1){
/code that enacts preference 1, adds results to array $filtereddata
}
if ($pre2 == 1 ){
/code that filters out preference 2, adds results to $filtereddata
{
postfinalarray($filtereddata);
}
显然这是模拟代码,但这是我一直在使用的一般流程。有没有更好的方法来实现用户的偏好定制功能?我应该设计函数来接受这些首选项作为参数吗?这会节省处理时间还是更易于维护?
很抱歉,如果这种情况过于笼统,请提出问题,以便澄清。
答案 0 :(得分:1)
当然,有很多可能性来改进这种代码。试想一下,如果要添加其他首选项,则必须重写整个代码。 我总是尝试使用面向对象的方式,因此创建用户类总是有意义的:
<?php
class User
{
private $_data;
public function __construct($userdata, $preferences)
{
$this->_data = $userdata;
}
public function getPreferencesData($preferences)
{
$result = array();
$prefs = $this->_data['preferences'];
foreach($preferences as $key => $value)
{
if($value == "1")
$result[] = $this->_data[$key];
}
return $result;
}
}
$mypreferences = array("name" => 1, "birthdate" => 0); // show e.g. name and birthdate
$mydata = array("name" => "Gaius Julius Caesar", "birthdate" => "July 13th -100");
$testuser = new User($mydata);
print_r($test->getPreferencesData($mypreferences));
?>
然后,您可以轻松适应用户选择的whatefer首选项,而无需更改代码。
答案 1 :(得分:0)
根据您提供的有限信息,您的方法似乎很好。
我可能会做一些稍微不同的事情。我会有一个你的5个prefs的表(或者如果它们不太可能改变的话就会硬编码)。我将创建一个链接prefs和用户的交叉引用表。然后你可以做类似的事情:
foreach($users as $user)
{
$filtereddata = array();
foreach($user->getPreferences() as $pref)
{
$filtereddata += $this->getFilteredData($user, $pref);
}
}
这比您正在使用的开销更大,但是如果/当您添加首选项/功能时更容易扩展。