在包含头文件后,有没有办法将样式表添加到标题?假设我们有这个代码:
class content {
public $stylesheets = array();
public function addStylesheets($stylesheets)
{
if(!empty($stylesheets))
{
if(!is_array($stylesheets))
$stylesheets = array($stylesheets);
$this->stylesheets = array_merge($this->stylesheets, $stylesheets);
}
}
public function getStylesheets()
{
$response = '';
foreach($this->stylesheets as $stylesheet)
$response .= '<link rel="stylesheet" type="text/css" href="' . $stylesheet . '" />' . Chr(13);
return $response;
}
}
这个标题:
<html>
<head>
<title>Title</title>
<link rel="stylesheet" type="text/css" href="default.css" />
<?php
print($content->getStylesheets());
?>
</head>
<bod...
然后在文件中我想添加样式表:
$content->addStylesheets(array('home.css', 'slider.css'));
有人能给我一个如何做到这一点的例子吗?
答案 0 :(得分:0)
最终的html代码总是在最后生成。这是一个如何继续使用纯php / html的示例。你的index.php看起来像这样:
<?php
// ...
// Define the stylesheets to use
$content = new content();
$content->addStylesheets(array('home.css', 'slider.css'));
// ...
// Print template at the end
ob_start();
include 'your_html_template.php';
print ob_get_clean();
your_html_template.php
是您的模板文件,如问题所示。
您可以在执行模板之前定义变量,以便更清楚分离php代码和HTML 。然后index.php可能如下所示:
<?php
// ...
// Define the stylesheets to use
$content = new content();
$content->addStylesheets(array('home.css', 'slider.css'));
$htmlStyleHeaderTags = $content->getStylesheets(); // Define variable with html header tags
// ...
// Print template at the end
ob_start();
include 'your_html_template.php';
print ob_get_clean();
然后您可以在模板中使用变量$htmlStyleHeaderTags
:
<html>
<head>
<title>Title</title>
<link rel="stylesheet" type="text/css" href="default.css" />
<?php print $htmlStyleHeaderTags; ?>
</head>
<bod...
答案 1 :(得分:0)
由于@szapio已经很伤心,最后构建HTML更有意义。
无论如何,一个“脏”的解决方案是使用jQuery来破解你的DOM
在</body>
- 标记之前跟随(<head>
中包含jQuery):
<script>
$(document).ready(function() {
$('head').append('<link rel="stylesheet" href="test.css" />');
});
</script>
你真的不应该考虑这样做,因为CSS文件将在其他所有内容之后加载,这意味着只要尚未加载CSS文件,你就会看到没有样式的元素......