我正在製作一個標記系統,其中用逗號分隔數據庫中的用戶ID。我用詞語打電話給他們,然後打破他們並獲得這些ID的真實用戶名。我正在使用str_replace
來將狀態更新中的單詞替換爲其個人資料鏈接(如Facebook標記爲朋友)。問題是如何替換句子中的多個標籤?字符串替換多個單詞中的一個句子
function tags($final_message,$tag_id)
{
GLOBAL $con;
if ($tag_id!==0)
{
$tag_id_explode=explode(",",$tag_id);
foreach($tag_id_explode as $id)
{
$tag_friend_query=mysqli_query($con,"select f_name,l_name from users_profile where user_id='$id'");
$tag_friend_query_result=mysqli_fetch_assoc($tag_friend_query);
$fname=$tag_friend_query_result['f_name'];
$lname=$tag_friend_query_result['l_name'];
$final_name=$fname.' '.$lname;
$html="<a href='profile.php?id=".$id."'>".$final_name."</a>";
}
echo str_replace($final_name,$html,$final_message);
}
}
這隻會轉換一個用戶,如果有多個它不起作用。如果我把str_replace
放在循環內部,那麼它可以工作,但它會一次轉換並返回兩個不同的輸出,並且每個語句都有相同的句子和一個用戶。它應該是多個用戶只需一次轉換。
@zzlalani我使用mysqli。 – user1001176
啊..我的壞.. – zzlalani