效果图
思路
- 使用
new Date()
获取当前时间,利用setInterval
每秒更新一次数据 - 使用过滤器格式化时间的文本显示
代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>示例</title>
</head>
<body>
<div id="app">
<h1>当前的时间是(实时更新):<br>{{date | formatDate}}</h1>
</div>
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<script>
var padDate = function(value){
return value < 10 ? '0'+ value:value;
};
var app = new Vue({
el:'#app',
data:{
date:new Date()
},
filters:{
formatDate: function (value){
var date = new Date(value);
var year = date.getFullYear();
var month = padDate(date.getMonth()+1);
var day = padDate(date.getDate());
var hours = padDate(date.getHours());
var minutes = padDate(date.getMinutes());
var seconds = padDate(date.getSeconds());
return year+'-'+month+'-'+day+' '+hours+':'+minutes+':'+seconds;
}
},
mounted:function(){
var _this = this;
this.timer = setInterval(function(){
_this.date = new Date();
},1000);
},
beforeDestory:function(){
if(this.timer){
clearInterval(this.timer);
}
}
})
</script>
</body>
</html>