2013-11-23 98 views
1

我正在製作一個標記系統,其中用逗號分隔數據庫中的用戶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放在循環內部,那麼它可以工作,但它會一次轉換並返回兩個不同的輸出,並且每個語句都有相同的句子和一個用戶。它應該是多個用戶只需一次轉換。

+0

@zzlalani我使用mysqli。 – user1001176

+0

啊..我的壞.. – zzlalani

回答

1

這樣做

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>"; 
    $final_message = str_replace($final_name,$html,$final_message); 
} 
echo $final_message; 
+1

謝謝@zzlalani這幫助。它的工作就像我想的那樣 – user1001176

0

在str_replace()中使用$ final_name時,問題出現在這裏,它只有最後一個用戶的最終名稱。相反,把它的循環,並在$ HTML你收集的鏈接,所以你可能想要做的是這樣的:(。)
$html .=yourlink;

請嘗試變量後的字符串concatinator點

+0

我之前嘗試過,因爲你建議。但它沒有工作,它給錯誤未定義的變量$ html,然後把這些單詞替換在句子的結尾,而不是替換它們在哪裏 – user1001176

+0

在循環開始之前定義變量 $ html =''; –

相關問題