使用Safari显示SVG的Doctype问题

时间:2011-05-24 21:52:18

标签: php xhtml safari svg

我想在页面上布局几个SVG图像。 Firefox和Chrome没有给我任何问题,但当且仅当文档具有“.xhtml”扩展名时,Safari才会显示SVG图像。如果我尝试使用PHP代码(以及“.php”扩展名),我在“.xhtml”文档中使用的完全相同的标记将不再显示SVG图像。问题当然是,我必须使用PHP来完成手头的项目。有什么建议?这是源代码:

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:svg="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:lang="de" xmlns:xml="http://www.w3.org/XML/1998/namespace">
<head>
<title>SVG Safari Test</title>
</head>
<body>
<!-- Generator: Adobe Illustrator 15.0.2, SVG Export Plug-In . SVG Version: 6.00 Build 0)  -->
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" width="500px" height="500px" viewBox="0 0 500 500" enable-background="new 0 0 500 500" xml:space="preserve"><circle cx="250" cy="250" r="238.048"/></svg>
</body>
</html>

2 个答案:

答案 0 :(得分:9)

.xhtml在Safari和.html中工作的原因并不是Safari需要将文档视为XML以允许嵌入式SVG。最新版本的Firefox和Chrome使用HTML5 parser,它允许SVG嵌入纯HTML文档中,因此它们应该同时使用。

要在Safari中正确呈现,您需要将内容类型设置为application/xhtml+xml。在输出任何内容之前,请在PHP文件中使用它:

<?php
header('Content-type: application/xhtml+xml');
?>

答案 1 :(得分:0)

你可以设置你的php配置来处理xhtml文件。

在这个例子中,我假设你在debian / ubuntu上使用apache

你可以查看文件/etc/apache2/mods-enabled/php5.conf

<IfModule mod_php5.c>

<FilesMatch "\.xhtml$">
SetHandler application/x-httpd-php
</FilesMatch>

</IfModule>

如果您使用的是其他网络服务器或发行版或操作系统,则可能会在其他文件中使用此SetHandler指令...

假设您在unix框中,只需grep / etc / apache或/ etc / httpd目录

grep -Ri sethandler /etc/apache