我正在使用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>";