PHP包含包含相对路径的html文件

阿帕达纳(Apadana)

我有一个本身可以正常工作的html文件。html文件包含一些相对路径。

当我在php中包含html文件时,我遇到了相对路径问题。

chart.html文件的脚本src如下所示:

<script src="./data/data.js"></script>

和index.php include看起来像这样:

include('./chart/chart.html');

我在浏览器中遇到的错误在此失败:

X GET http://localhost/project/data/data.js 

显然data.js的路径缺少图表文件夹。应该是这样的:http://localhost/project/chart/data/data.js

这是我的文件夹层次结构:

Sites/
  project/
    index.php
    chart/
        chart.html
        data/
           data.js

我知道我可以修改html文件并将图表添加到路径,但这将使html文件本身不可见。基本上,html文件假定该路径基于当前chart.html相对路径。那么,使php包含此html文件而不弄乱相对路径的正确方法是什么?

佳美

这里的问题是绝对路径和相对路径之间的差异。通过将其包含在其他路径中,有效地更改的路径chart.html,但不更改相关文件的相对路径,则会破坏代码。

您可以将基本标记https://developer.mozilla.org/en/docs/Web/HTML/Element/base放在首位。但是,这可能会使情况变得更糟,因为您index.php可能包括的其他内容将不再起作用,除非这些内容使用绝对路径。如果您仍然不这样做,这可能是一个很好的解决方案。

第二种解决方案可能是(以编程方式)在您的html中搜索相对路径,并在运行中将这些路径替换为正确的路径。在某些奇怪的情况下,在html中使用了javascript,并且可能存在一些“防复制”保护js代码,这可能会对此造成窒息。

第三种解决方案(当然取决于您的用例)将是,不包括html,而是iframe在输出中放置一个,指向正确的路径。由于它是从正确的路径加载的,因此相对路径应该可以再次使用。(我更喜欢那个,特别是如果您要使用某种“预览”功能时)。

另一个解决方案可能是将另一个index.php放入chart文件夹,通过包含(并使原始index.phps代码足够灵活)–可以执行与原始index.php相同的工作,但是由于它是从不同路径请求的,因此很好

URL重写是一种不同的方法,您可以在其中使它看起来像index.php在图表目录中(可能需要从原始调用进行重定向)。URL重写可能很困难,具体取决于您的整体设置。

这些是我的建议,但是,根据您实际对项目执行的操作,可能会有更合适的解决方案。

更新到额外的index.php解决方案:

请注意,这仅适用于一次显示一个项目,而不能同时显示多个项目。而且,这在很大程度上取决于您的index.php工作或工作方式。让我假设它看起来像这样:

<?php
$project = !empty($_POST['project']) ? $_POST['project'] : '';
$projects = array('chart', 'otherproject');
if(in_array($project, $projects)) {
    include $project.'/'.$project.'.html';
}
foreach($projects as $p) {
    echo '<a href="?project='.$p.'">'.$p.'</a>';
}

现在,新版本chart/index.php将执行以下操作:

<?php $project='chart'; include '../index.php';

并且您需要将原件更改/index.php为:

<?php
$project = !empty($project) ? $project : '';                   // <-- changed
$projects = array('chart', 'otherproject');
if(in_array($project, $projects)) {
    include $project.'/'.$project.'.html';
}
foreach($projects as $p) {
    echo '<a href="/URL/TO/ROOT/'.$p.'/index.php">'.$p.'</a>'; // <-- changed
}

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章