无法使用python软件包web.py仅显示HTML

时间:2019-01-24 22:00:36

标签: python html css static web.py

我目前正在学习python课程,当页面加载时,它将不会与任何CSS一起显示。

我的Controller.py位于根目录D:\Coding\Python_Projects\Py\CodeWizard

我的CSS文件位于D:\Coding\Python_Projects\Py\CodeWizard\static\css

我的HTML文件位于D:\Coding\Python_Projects\Py\CodeWizard\Views\Templates

Controller.py

import web


urls = (
    '/', 'home'
    )

render = web.template.render("Views/Templates", base="MainLayout")
app = web.application(urls, globals())


# Classes/Routes
class home:
    def GET(self):
        return render.home()


if __name__ == "__main__":
    app.run()

MainLayout.html:

$def with (page)
$var css: \\static\css\bootstrap.min.css \\static\css\bootstrap-material-design.min.css

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>CodeWizard</title>

    $if self.css:
        $for style in self.css.split():
            <link rel="stylesheet" href="$style"/>

</head>
<body>
  <div id="app">
    <nav class="navbar navbar-dark bg-primary fixed-top navbar-expand-lg">
      <div class="navbar-header">
        <a class="navbar-brand">CodeWizard</a>
      </div>

      <div class="nav navbar-nav mr-auto mt-2 mt-lg-0">
        <a class ="nav-item nav-link" href="/">Home Feed</a>
        <a class ="nav-item nav-link" href="/discover">Discover</a>
        <a class ="nav-item nav-link" href="/profile">Profile</a>
        <a class ="nav-item nav-link" href="/settings">Settings</a>
      </div>

      <div class="pull-right">
        <a href"/register" class="btn btn-raised btn-default">Register</a>
      </div>
    </div>
      $:page
  </nav>
</body>
</html>

home.html:

<br /> <br /> <br />

<div class="container">
<h1>Hello CodeWizard</h1>
</div>

如果我不为CSS文件位置在static前面加上多余的斜线,则会出现一些控制台错误,例如StaticApp没有属性目录,且int()的基数为10时的无效文字

加上额外的斜杠,我会收到200 OK消息。当我检查页面并查看网络时,它显示CSS文件的状态为已取消。

不确定如何解决此问题。我尝试搜索了很多。我使用

为chrome创建了快捷方式
  

“ C:\ Program Files(x86)\ Google \ Chrome \ Application \ chrome.exe”   --allow-file-access --disable-web-security --user-data dir =“ C:\ ChromeLocalFileAccess”

那没有用,我还尝试了css文件的直接路径,还尝试了file:///和许多其他组合。

如果有人可以帮助我,将不胜感激,因此我可以继续学习该课程并了解更多python :)谢谢。

2 个答案:

答案 0 :(得分:0)

这是在Python 3.7环境中运行的web.py的问题。此pull request已修复。

修复该问题后,您的路径不应以\\开头:

要么

$var css: static\css\bootstrap.min.css static\css\bootstrap-material-design.min.css

$var css: static/css/bootstrap.min.css static/css/bootstrap-material-design.min.css

可以工作

答案 1 :(得分:0)

这对我有用,因此请在mainLayout.html中尝试

$def with (page)
$var css: static/css/bootstrap.min.css

<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>mainlayout</title>
    $if self.css:
        $for style in self.css.split( )
            <link rel ="stylesheet" href="$style" />
</head>
<body>
     <div id="app">
    <nav class="navbar navbar-dark bg-primary fixed-top navbar-expand-lg">
      <div class="navbar-header">
        <a class="navbar-brand">CodeWizard</a>
      </div>

      <div class="nav navbar-nav mr-auto mt-2 mt-lg-0">
        <a class ="nav-item nav-link" href="/">Home Feed</a>
        <a class ="nav-item nav-link" href="/discover">Discover</a>
        <a class ="nav-item nav-link" href="/profile">Profile</a>
        <a class ="nav-item nav-link" href="/settings">Settings</a>
      </div>

      <div class="pull-right">
        <a href="/register" class="btn btn-raised btn-default">Register</a>
      </div>

    </div>
   <div>
       $:page
   </div>


</body>
</html>