javascript - Zf2 布局 css 和 javascript 路径在子路由上不解析

标签 javascript php css zend-framework2

目前我正在尝试设置所有使用相同模板的分段路线。目前基本路线/my-dashboard View 使用布局。这适用于基本路线。但是在尝试添加子段路由后,布局 css 和 js 路径不正确。我希望/my-dashboard/ideas/my-dashboard/whatever/my-dashboard/whatever/update/777 下的任何部分都使用相同的布局,但 View 不同。以及为每个 View 提供正确的 css 和 js 路径的布局。

路由.config.php

'dashboard' => array(
        'type' => 'literal',
        'options' => array(
            'route'    => '/my-dashboard',
            'defaults' => array(
                'controller' => 'dashboard',
                'action'     => 'dashboard',
            ),
        ),
        'may_terminate' => true,
            'child_routes' => array(
                'wahtever' => array(
                    'type'    => 'Segment',
                    'options' => array(
                        'route'    => '/ideas',
                        'defaults' => array(
                            'controller' => 'ideas',
                            'action'     => 'ideas',
                        ),
                    ),
                ),
            ),
    ),

如果我转到/my-dashboard,它将显示正确的 View 以及我想用于任何这些路线的布局。如果我转到/my-dashboard/ideas,路由会解析,但是当在控制台中查看时,所有的 css 和 js 都被 404s 搞砸了,找不到这样的。如果我在布局中添加 ../它将在嵌套路由上工作,但随后会搞砸/my-dashboard 路由。

模块.config.php

'view_manager' => array(
    'template_map' => array(
        'layout/my-dashboard-layout' => __DIR__ . '/../view/layout/my-dashboard-layout.twig',
        'wmi/dashboard/dashboard'    => __DIR__ . '/../view/dashboard/dashboard.twig',
        'wmi/ideas/ideas'            => __DIR__ . '/../view/ideas/ideas.twig',
    )
),

编辑以添加布局和 View 。 布局/我的仪表板布局.twig

<!DOCTYPE html>
<html>

<head>
    <!-- Theme CSS -->
    <link rel="stylesheet" type="text/css" href="skin/default_skin/css/theme.css">

    <!-- Admin Panels CSS -->
    <link rel="stylesheet" type="text/css" href="admin-tools/admin-plugins/admin-panels/adminpanels.css">

    <!-- Admin Forms CSS -->
    <link rel="stylesheet" type="text/css" href="admin-tools/admin-forms/css/admin-forms.css">
    <!-- Favicon -->
    <link rel="shortcut icon" href="img/favicon.ico">
</head>
<body class="dashboard-page sb-l-o sb-r-c">
    <!-- Start: Content-Wrapper -->
    <section id="content_wrapper">
        {% block content %}{{ content|raw }}{% endblock content %}
    </section>
<!-- jQuery -->
<script type="text/javascript" src="js/jquery/jquery-1.11.1.min.js"></script>
<script type="text/javascript" src="js/jquery/jquery_ui/jquery-ui.min.js"></script>

<!-- Bootstrap -->
<script type="text/javascript" src="js/bootstrap/bootstrap.min.js"></script>
</body>
</html>

我指的是所有 css 和 javascript 路径。在基本文字路线/my-dashboard 上,布局和 View 显示正确。尽管当您转到段部分/my-dashboard/ideas 时,您会得到 404 无法在浏览器控制台中找到任何内容。

GET http://watch.dev/my-dashboard/skin/default_skin/css/theme.css 
GET http://watch.dev/my-dashboard/admin-tools/admin-plugins/admin-panels/adminpanels.css 
GET http://watch.dev/my-dashboard/admin-tools/admin-forms/css/admin-forms.css 
GET http://watch.dev/my-dashboard/img/avatars/2.jpg 
404 (Not Found) 
GET http://watch.dev/my-dashboard/js/jquery/jquery-1.11.1.min.js 
GET http://watch.dev/my-dashboard/js/bootstrap/holder.min.js
GET http://watch.dev/my-dashboard/components/circles/circles.js
GET http://watch.dev/my-dashboard/components/raphael/raphael.js
GET http://watch.dev/my-dashboard/js/jquery/jquery_ui/jquery-ui.min.js  
GET http://watch.dev/my-dashboard/components/highcharts/highcharts.js 
GET http://watch.dev/my-dashboard/js/bootstrap/bootstrap.min.js
GET http://watch.dev/my-dashboard/admin-tools/admin-plugins/admin-panels/adminpanels.css 
GET http://watch.dev/my-dashboard/admin-tools/admin-forms/css/admin-forms.css  
GET http://watch.dev/my-dashboard/img/avatars/2.jpg 
404 (Not Found) 
GET http://watch.dev/my-dashboard/js/jquery/jquery-1.11.1.min.js 
GET http://watch.dev/my-dashboard/js/bootstrap/holder.min.js  
GET http://watch.dev/my-dashboard/components/circles/circles.js  
GET http://watch.dev/my-dashboard/components/raphael/raphael.js  
GET http://watch.dev/my-dashboard/js/jquery/jquery_ui/jquery-ui.min.js  
GET http://watch.dev/my-dashboard/components/highcharts/highcharts.js  
GET http://watch.dev/my-dashboard/js/bootstrap/bootstrap.min.js 
404 (Not Found)

想法/我的想法.twig

{% extends "layout/my-dashboard-layout" %}

{% block content %}
{% endblock content %}

感谢任何帮助。 404(未找到)

想法/我的想法.twig

{% extends "layout/my-dashboard-layout" %}

{% block content %}
{% endblock content %}

感谢任何帮助。

最佳答案

这不是 ZF 问题,因为 CSS/JS 请求甚至不应该触及 PHP。因为您在布局中使用相对路径,所以浏览器会加载相对于当前 URL 的 CSS 和 JS 文件。例如。当你在 /my-dashboard/ideas 页面时,它正在尝试加载 /my-dashboard/skin/default_skin/css/theme.css (这不是正确的网址)。

要解决此问题,请始终在布局中使用绝对路径,例如:

<link rel="stylesheet" type="text/css" href="/skin/default_skin/css/theme.css">

(注意 href 路径开头的初始斜杠)。这可确保您的 Assets 始终从文档根目录加载。

关于javascript - Zf2 布局 css 和 javascript 路径在子路由上不解析,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28735016/

相关文章:

javascript - 单击缩略图不会更改 flexslider 幻灯片

javascript - 如果值存在,如何避免将字段设置为空字符串

javascript - 为什么这些 restify 函数以 "return next()"结尾?

php - 无需浏览器/用户即可定期更新数据库

php - 如何检查是否一个接一个地设置直到完成

php - pdo sqlite 找不到驱动程序...未处理 php 文件

javascript - 更改文本并在输入中设置光标

javascript - 如何修改字符串并在firestore中搜索?

asp.net - 在文本框中有一个默认文本,并通过在 asp.net 中键入一个字母来清除它

javascript - 悬停时并排显示三个 Div