奇怪的换行字符出现在我的视野中


Strange linebreak characters showing up in my view

我正在使用codeigniter生成一个html表,以便插入到模板视图中。在"如何在生成的html代码中插入换行符"和一些实验的帮助下,我已经能够将代码更改为:

$string='<table id="myDataTable" class="table table-bordered table-striped" style="clear: both">'n <tbody>'n';
    foreach ($array as $key => $value) {
    $string=$string."'t'n<tr><td>$key</td>";  
    $element='<td><a href="#" id="'.$key.'" data-type="text" data-pk="'.$rowID.'" data-url="/post" data-title="'.$key.'">'.$value.'</a>'.'</td></tr>'n';
    $string=$string.$element;
    }
$string=$string.'</tbody>'n</table>';

然后,我将这个生成的html字符串注入到我的CI视图中,它看起来像:

<!DOCTYPE html>
<html lang="en">
<head>
   <base href="<?=base_url();?>">
    <meta charset="utf-8">
    <meta name="author" content="Vitaliy Potapov">
    <meta http-equiv="cache-control" content="max-age=0" />
    <meta http-equiv="cache-control" content="no-cache" />
   <link href="css/bootstrap.css" rel="stylesheet">
   <link href="//cdnjs.cloudflare.com/ajax/libs/x-editable/1.4.5/bootstrap-editable/css/bootstrap-editable.css" rel="stylesheet"/>

</head> 
<body> 

  <?=$html_string;?>  

  <script src='js/jquery.js'></script>
  <script src="js/bootstrap.js"></script>
  <script src="//cdnjs.cloudflare.com/ajax/libs/x-editable/1.4.5/bootstrap-editable/js/bootstrap-editable.min.js"></script>
<script language="javascript" type="text/javascript">
  $(document).ready(function() {
$('#myDataTable').editable();
$.fn.editable.defaults.mode = 'inline';
});
</script>
 </body> 
</html> 

我得到了预期的表,但由于某种原因,当我查看生成的HTML时,我在表之前看到了一堆生成的新行字符。

     'n 'n  
'n  
'n  
'n  
'n  
'n  
'n  
'n  
'n  
'n  
'n  
'n  
'n  
'n'n

为什么会发生这种情况,我该如何解决?

`EDIT

我可能和Orangepill同时给出了一个答案,然后编辑了我的答案,给Orangepile打分。


Original answer:

可能是因为$string='';

您需要在内部转义"(双引号),并使用:
$string="content with escaped double quotes etc";

在这种情况下,$string和所有其他变量必须用双引号括起来,才能被视为字符串。

根据Orangepill的答案,连接也是必须的。

  • 有关字符串的更多信息,请参阅PHP手册

  • 您也可以在连接此处上查阅PHP.net网站。

使用单引号时不插入转义字符。要解决此问题,请从字符串中删除或将您的代码更改为以下内容:

<?php
$string='<table id="myDataTable" class="table table-bordered table-striped" style="clear: both">'."'n".' <tbody>'."'n";
foreach ($array as $key => $value) {
    $string=$string."'t'n<tr><td>$key</td>";  
    $element='<td><a href="#" id="'.$key.'" data-type="text" data-pk="'.$rowID.'" data-url="/post" data-title="'.$key.'">'.$value.'</a>'.'</td></tr>'."'n";
    $string=$string.$element;
}
$string=$string."</tbody>'n</table>";