我想知道是否有可能将文本分成两部分。
在我的网站上,我有一个产品描述(500-1000字),我想这样显示它:
<div class="text-col">
<?php echo nl2br($col1); ?>
</div>
<div class="text-col">
<?php echo nl2br($col2); ?>
</div>
像这样的东西?
$len = strlen($input);
$space = strrpos($input," ",-$len/2);
$col1 = substr($input,0,$space);
$col2 = substr($input,$space);
// now output it
恕
我直言,这是一个典型的问题,应该通过CSS来完成,因为它只影响它的显示方式。为什么不使用CSS3的column-count
:
div#multicolumn1 {
-moz-column-count: 3;
-moz-column-gap: 20px;
-webkit-column-count: 3;
-webkit-column-gap: 20px;
column-count: 3;
column-gap: 20px;
}
(摘自 http://www.quirksmode.org/css/multicolumn.html)
您可以在PHP中轻松地将文本分成两部分:
$text = "my very long text with a lot of words";
$length = strlen($text);
$middle = round($length/2, 0);
$col1 = substr($text, 0, $middle);
$col2 = substr($text, $middle);
但是这个mots经常在单词中间删掉短语。所以你需要更新代码以找到中间最近的空间:
for ($i = $middle; $i < $length; $i ++) {
if ( substr($text, $i, 1) == " " ) return;
}
$cut = $i;
$col1 = substr($text, 0, $cut);
$col2 = substr($text, $cut+1);
空间并不是唯一一个漂亮的文本剪切的地方。因此,您将不得不寻找行的末端。而且有些空间也不好。例如,空格刚好在分号之前。因此,您将添加以改进此代码以改善结果。
你也可以试试 css3 多列指令:http://www.css3.info/preview/multi-column-layout/但它是IE支持的注释。
它就像:
$text = "This should be a very long product description with some bold specs in it.";
$splitat = strpos($text," ",strlen($text)/2);
$col1 = substr($text, 0, $splitat);
$col2 = substr($text, $splitat);
但实际上您可能希望在客户端执行此操作,因为可能涉及其他因素,浅段落宽度、连字、文本块高度等。
在 CSS3 中,您已经支持多列文本。
你能用wordwrap()函数吗?