Flask-Moment本地化日期和时间

14 篇文章 1 订阅

1. 为什么使用Flask-Moment?

如果Web程序的用户来自世界各地,那么就思考如何让Web的世界和当地时间一致。服务器需要统一时间单位,这和用户所在的地理位置无关,所以一般会使用协调时间(Coordinated Universal Time,UTC)。但是对于用户来说他们想看到的是自己所在的当地时间,而且使用当地惯用的格式。

2. Flask-Moment实现原理

一个优雅的解决方法就是把时间单位发送给Web浏览器,转换成当地时间, 然后渲染。Web浏览器可以更好的更成这一任务,因为他们能获得电脑中的时区和区域设置。

有一个使用JavaScript开发的优秀客户端开源代码库,名为moment.js, 它可以在浏览器中渲染日期和时间。Flask-Moment是一个Flask程序扩展, 能把moment.js集成到Jinja2模板中。

3. 具体代码

3-1. 模板的编写

  • 除了moment.js.Flask_Moment还依赖jquery.js,要在HTML文档的引入这个文件,这样可以选择使用哪个版本,也可以使用扩展提供的辅助函数,从内容分发网络中引入通过测试的加新内容,必须使用JinJa2提供的super()函数。比如可以这样在基模板中的scripts块中引入这个库。

{% block script %}
{{ super()}}
{{ monent.include_moment()}}
{% endblock %}



3-2. 编辑视图函数

为了处理时间,Flask-Moment向模板开放了monent类。所以代码可以把变量current_time(也就是UTC时间传给模板处理)传入模板进行渲染。就这样解决了本地时间问题

@app.route('/')
def index():
    return render_template('index.html',
                           current_time=datetime.utcnow())

3-3. 编辑页面逻辑

<p>The local date and time is {{ moment(current_time).format('LLL') }}.</p>
<p>That was {{ moment(current_time).fromNow(refresh=True) }}.</p>

4. 参考资料

Flask-Moment 实现了 moment.js 中的 format() 、 fromNow() ,fromTime()、 calendar() 、 valueOf()和 unix() 方法。可查阅文档(http://momentjs.com/docs/#/displaying/)学习 moment.js 提供的全部格式化选项。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值