在tornado中配置静态文件,命名一个目录为statics,尽管配置了 ,但是依旧找不到statics下的静态文件。
'static_path' : os.path.join(os.path.dirname(__file__), 'statics')
此时各个设置为:
settings = {
'static_path' : os.path.join(os.path.dirname(__file__), 'statics'),
}
<link rel="stylesheet" href="/statics/css/index.css">
因为默认去找static下的静态文件。
若将statics目录改为static,就能找到下面的css文件。
或者修改<link rel="stylesheet" href="{{static_url('css/index.css')}}">
若要使用statics作为静态文件的目录,需要设置static_url_prefix
/statics/,这样,当直接<link rel="stylesheet" href="/statics/css/index.css">这样访问的时候,就可以找到静态文件。
总结
- 仅仅设置
'static_path': os.path.join(os.path.dirname(__file__), 'static'),并且访问静态文件的时候,通过href="/static/css/index.css"访问。可以访问到静态文件。 - 不管静态文件目录是static还是statics,在访问的时候,通过
href="{{static_url('css/index.css')}}",访问。访问到的是static_path设置的static目录。 - static_url生成的前缀是可以设置的. 也在application的settings里
static_url_prefix默认是"/static/"
可以在路由里设置StaticFileHandler
(r'/css/(.*)', StaticFileHandler,
{"path": os.path.join(config.base_dir, config.CSS_URL)}),
STATIC_PATH = "static"
CSS_URL = "static/css"
IMG_URL = "static/img"
这样以后直接访问/css/index.css就可以访问到静态css文件。同理img,js都可以这样设置。
本文介绍了如何在Tornado Web框架中正确配置静态文件路径。包括使用'static_path'设置静态文件目录,调整static_url_prefix前缀以指向特定目录,以及通过StaticFileHandler自定义路由。
913

被折叠的 条评论
为什么被折叠?



