在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都可以这样设置。