vue --- 使用vue在html上顯示當前時間

希望如下效果(時間按秒鐘更新)
在這里插入圖片描述

導入Vue依賴的CDN

<script src="https://unpkg.com/vue/dist/vue.min.js"> </script>

創建視圖

<div id="app">{{date}}</div>

Model

<script>var app = new Vue({el: "app",data: {date: new Date();  // 初始化date}mounted: function () {var _this = this;this.timer = setInterval(function() {_this.date = new Date();  // 每隔1秒鐘更新一次date}, 1000);},beforeDestroy: function () {   // 清除定時器if (this.timer) {clearInterval(this.timer);}}
})
</script>

總代碼

<html>
<head>
<meta charset="utf-8">
</head>
<body>
?
<div id="app">{{date}}
</div><script src="https://unpkg.com/vue/dist/vue.min.js"></script><script>var app = new Vue({el:'#app',data:{date: new Date()},mounted: function () {var _this = this;this.timer = setInterval(function() {_this.date = new Date();}, 1000);},beforeDestroy: function () {if (this.timer) {clearInterval(this.timer);}}})</script>
?
</body>
</html>

你可能覺得上面的時間看著別扭.

你真正需要的可能是下面這樣
在這里插入圖片描述
那么接下來,我們需要一個formatDate函數.用于將日期轉化成需要的格式

// 首先編寫一個padDate函數,用于將小于0的數,轉換成0a的形式
var padDate = function (value){return value < 10?  "0" + value : value
}
// 下面編寫formatDate函數. 用于轉換日期格式
var formatDate = function(value) {var date = new Date(value);var year = date.getFullYear();   // 獲取年份var month = padDate(date.getMonth()+1);  // js里面月份(0~11月)會比正常的少1; 使用padDate函數轉換小于10的月份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;
}

使用filters 對{{}}中的參數進行過濾(用上面定義的formatDate)

// HTML 
<div id = "app"> {{ date | formatDate}}
</div>// javascript
var app = new Vue({el: '#app',data:{date: new Date();},filters: {formateDate: formatDate  // 注意此處沒有括號,代表函數賦值}
// ps: 過濾的實質是在date顯示之前,先作為參數傳給formatDate函數進行處理

全部代碼

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
</head>
<body><div id="app">{{ date | formatDate }}
</div><script src="https://unpkg.com/vue/dist/vue.min.js"></script><script>var padDate = function (value) {return value < 10 ?  '0' + value : value;};var formatDate = function (value) {  // 這里的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;}var app = new Vue({el: '#app',data:{date: new Date()},filters: {formatDate:formatDate},mounted: function () {var _this = this;this.timer = setInterval(function() {_this.date = new Date();}, 1000);},beforeDestroy: function (){if(this.timer) {clearInterval(this.timer);}}})</script></body>
</html>

參考 《Vue.js實戰》 P12

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/251464.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/251464.shtml
英文地址,請注明出處:http://en.pswp.cn/news/251464.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

namespace 或The content of element type mapper must match EMPTY

必須為元素類型 "mapper" 聲明屬性 "namespace" 或The content of element type "mapper" must match "EMPTY" <?xml version"1.0" encoding"UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org/…

EAS WebService部署

1、創建 facade ,設置好接口及參數、返回信息; 2、代碼&#xff1a;元數據打包部署到服務器; 3、然后修改配置文件&#xff1a; 將本地開發環境生成的.wsdd文件拷貝到eas\server\deploy\eas.ear的web.war下的WEB-INF目錄下&#xff0c;再將.wsdd文件中的<service></se…

vue --- 購物車頁面

下面我看開始自己寫一個購物車的頁面. 我們希望得到如下的效果: 說明: 購買數量最小為0購買數量變化時,對應的總價隨之變化點擊移除操作對應的商品會移除掉,總價隨之改變每個商品作為一個list表的一個對象每個對象,包含id、name、price、count等屬性 index.html (整體代碼最…

Javascript阻止表單提交

Javascript阻止表單提交 Html 1.<form name"loginForm" action"login.aspx" method"post"> 2. <button type"submit" value"Submit" id"submit">Submit</button> 3.</form> Js …

XML CDATA的作用

操作XML文件時&#xff0c;如果允許用戶輸入內容&#xff0c;例如∶"< "、">"、"/"、""等&#xff0c;當生成XML時&#xff0c;會破壞了XML結構&#xff0c;使數據中斷。 這就要用XML CDATA 在XML文檔中的所有文本都會被解析器解…

vue --- 從模塊從父元素獲取數據

vue的精彩之處在于其組件的可復用性.下面談談組件(component)如何從父元素獲取數據 模塊引用 首先說說,如何引用模塊 <div id"app"><my-component ></my-component> </div> <script src“unpkg.com/vue/dist/vue.min.js”> </…

前端知識總結(一)

1、用原生JS實現forEach if(!Array.prototype.forEach) {Array.prototype.forEach function(fn, context) {var context arguments[1];if(typeof fn ! "function") {throw new TypeError(fn "is not a function");}for(var i 0; i < this.length; …

廣播風暴

能夠抑制網絡風暴的是&#xff1f;A中斷器 B集線器 C網橋 D路由器 答案D解析&#xff1a;&#xff08;1&#xff09;廣播風暴&#xff1f;一個數據幀或包被傳輸到本地網段上的每個節點就是廣播&#xff1b;由于網絡拓撲的設計和連接問題&#xff0c;或其他原因導致廣播在網段內…

java getClass()

Java反射學習 所謂反射&#xff0c;可以理解為在運行時期獲取對象類型信息的操作。傳統的編程方法要求程序員在編譯階段決定使用的類型&#xff0c;但是在反射的幫助下&#xff0c;編程人員可以動態獲取這些信息&#xff0c;從而編寫更加具有可移植性的代碼。嚴格地說&#xff…

vue --- 模塊從子組件獲取數據

先看個一般的例子: // 我們需要將信息從子組件傳遞給父組件,(有可能不止一條信息,因此)肯定需要一個標識,這個標識放在$emit里面(js),在dom中通過來關聯父元素。如下:<div id "app"><transfer connect"sayConnect" build"sayBuild"&g…

mySql配置在nodejs中使用

mySql安裝完成后&#xff0c;配置鏈接nodejs項目中的數據庫。 1、測試是否安裝成功。 2、use nodejs使用nodejs 3、設置數據源 5、exit 轉載于:https://www.cnblogs.com/zhxzh/p/9244996.html

轉,jquery中attr和prop的區別

https://www.cnblogs.com/Showshare/p/different-between-attr-and-prop.html 像checkbox&#xff0c;radio和select這樣的元素&#xff0c;選中屬性對應“checked”和“selected”&#xff0c;這些也屬于固有屬性&#xff0c;因此需要使用prop方法去操作才能獲得正確的結果。 …

前端知識總結(二)

33、閉包 閉包的概念 上一節代碼中的f2函數&#xff0c;就是閉包。 各種專業文獻上的"閉包"&#xff08;closure&#xff09;定義非常抽象&#xff0c;很難看懂。我的理解是&#xff0c;閉包就是能夠讀取其他函數內部變量的函數。 由于在Javascript語言中&#x…

javascript --- 實現Ajax的代碼

直接上代碼,(前幾天項目出差部署去叻) const ajax function (options {}) {option.type (options.type || GET).toUpperCase();let data [];for(let i in options.data) {data.push(encodeURIComponent(i) encodeURIComponent (options.data[i]));}data data.join(&am…

[Spark]-RDD詳解之變量操作

RDD的操作 1.1 概述 RDD整體包含兩大類操作 transformation 從現有中創建一個新的數據集 action 在對數據集做一定程度的計算后將結果返回 對于所有的transformation,都是Lazy的,也就是說它不會立即執行,只是單純的記住怎么樣從原來的數據集進行轉換的邏輯而已,它僅在某一個計算…

前端知識總結(三)

51、啟動GNU加速 硬件加速的工作原理 瀏覽器接收到一個頁面之后&#xff0c;將html解析成DOM樹&#xff0c;瀏覽器解析渲染「html」的過程 按著一定的規則執行&#xff0c;DOM樹和CSS樹結合后構成瀏覽器形成頁面的 渲染樹 ; 渲染樹中包含大量的渲染元素&#xff0c;每一個元素…

為阿里云服務器ECS實例安裝Nodejs

為阿里云服務器ECS實例安裝Nodejs部署Node.js項目&#xff08;CentOS&#xff09;準備工作操作步驟步驟1&#xff1a;部署Node.js環境&#xff08;使用二進制文件安裝&#xff09;步驟2&#xff1a;部署測試項目部署Node.js項目&#xff08;CentOS&#xff09; 本文檔介紹如何…

JavaScrpt --- es5實現ES6的Number擴展(部分)

ES6對數值對象Number進行了擴展, // ES實現Number.isFinite() (function (global) {var global_isFinite global.isFinite;Object.defineProperty(Number, isFinite, {value: function isFinite(value) {return typeof value number && global_isFinite(value);},co…

webstorm激活+漢化教程

1.安裝教程激活 輸入的激活網址&#xff1a; http://idea.imsxm.com/ 2.漢化教程 軟件適用于&#xff1a;webstorm2017.2以及以上&#xff0c;如有需要可直接加本人QQ 1940694428。 轉載于:https://www.cnblogs.com/cisum/p/7919712.html

如何從零開始,成為element-plus的contributor

序言 提到element-ui&#xff0c;我想很多前端er應該都不陌生&#xff0c;而element-ui也是我第二個使用的前端UI庫&#xff0c;第一個是bootstrap&#xff08;笑&#xff09;。我是在去年初學vue的時候開始接觸elemment-ui的&#xff0c;到現在也快一年了&#xff0c;中間經歷…