我如何才能抓住变量的前几个单词,例如$ data。我正在尝试创建文章预览部分,该变量是一篇文章。我当然试图只展示它的预览。
<?php
$sql = "SELECT author, data, postdate, Title, previewimg FROM articlepreview ORDER BY RAND() LIMIT 1";
$query = mysqli_query($db_conx,$sql);
$prev = "";
while ($row = mysqli_fetch_array($query, MYSQLI_ASSOC)) {
$a = $row["author"];
$data = $row["data"];
$postdate = $row["postdate"];
$title = $row["Title"];
$previewimg = $row["previewimg"];
$prev .= '
<div class="wrapPreviewArticle">
<div style="headerPreview"><h4>'.$title.'</h4></div>
<div class="wrapPreviewRow">
<div style="imagePreview"><img src="'.$previewimg.'" height="20%" width="20%" alt="'.$title.'" /></div>
<div clas="wordPreview">'.$data.'</div>
</div>
</div>
';
}
?>
一旦我得到了这个,我就会吐出变量
<body>
<div><?php echo $prev; ?></div> <!--with only the desired portion.-->
</body>
非常感谢任何帮助。
答案 0 :(得分:0)
您可以在查询中使用SUBSTRING_INDEX:
"SELECT author, SUBSTRING_INDEX(data, ' ', 5) data, ... FROM articlepreview ..."
这将仅从字段data
中提取前5个单词。
答案 1 :(得分:0)
您可以抓住前200个字符并仅将其显示为预览
$pos=strpos($data, ' ', 200);
$preview=substr($data,0,$pos );
这也将确保您将其分割到不在单词
中间的空间答案 2 :(得分:0)
你可以显示前X个字符(这里的X是20):
<div class="wordPreview">'.substr($data, 0, 20).'</div>