使用node.js創建電池:客戶端
鑰匙要點
- >本文介紹瞭如何使用Node.js構建電池可視化服務的客戶端部件,該服務在不重新加載頁面的情況下定期更新電池狀態。客戶可以暫停或恢復更新,以避免在不需要信息時使系統重載。 >
- 反應性設計和聲明框架用於自動有效地更新文檔對像模型(DOM),以響應數據的變化。這是使用ractive.js來實現的,ractive.js是一個將數據綁定到DOM元素並每次數據更改時都會更新DOM的庫。 >作者演示瞭如何使用ractive.js創建電池可視化,包括設置暫停/簡歷更新的機制,並從靜止服務中異步檢索數據。
- > >本文以一個呼籲結束,以進一步探索所討論的工具和概念,例如使用node.js設置http服務器,RESTFULE API,在Node.js服務器上運行OS終端命令以及聲明框架的基礎知識和ractive .js。
- 在這個迷你係列的第一部分中,我們討論了我們正在構建的服務的細節以及您將學到的東西。然後,我們介紹了為什麼我們需要服務器以及為什麼我選擇創建RESTFUL服務的原因。在討論如何開發服務器時,我藉此機會討論瞭如何識別當前操作系統以及如何使用node.js在其上運行命令。 在本系列的第二個也是最後一部分中,您將發現如何以不錯的方式構建客戶部分以向用戶提供信息。為了實現此目標,我們應該每x分鐘(或秒)更新電池狀態,而無需重新加載頁面。此外,我們應該能夠暫停/簡歷更新,以避免在不需要信息時氾濫到我們的系統,甚至當我們不查看頁面時。為此,我們將:
- >安排Ajax通過常規時間間隔來打電話給我們的後端服務;
- >使用一個聲明的框架,該框架會自動有效地對數據的更改進行自動更新;
> 使用一些jQuery效用功能使我們的生活更輕鬆; - > >使用一些不錯的圖像和CSS使儀表板視覺吸引人(作為獎勵!)。
- 。
反應性設計
討論Ajax和異步電話肯定不在本文的範圍之內(我將在帖子結尾提供一些有用的鏈接)。出於我們的目的,我們甚至可以將它們視為黑匣子,使我們可以向服務器詢問一些數據,並在將數據發送回數據後執行某些操作。 相反,讓我們花一點時間討論反應性設計和聲明性框架。 HTML頁面默認是靜態實體。這意味著,對於純HTML頁面,每次在瀏覽器中渲染時,頁面上顯示的內容保持不變。但是,我們知道,通過使用JavaScript以及一些模板庫(例如Mustache),我們可以動態更新它們。 有許多庫可以幫助開發人員將數據綁定到DOM節點。他們中的大多數使用JavaScript來描述應轉換數據的DOM元素,並需要對頁面進行更新,以手動觸發(通過JavaScript)。因此,我們最終依靠應用程序的邏輯來確定應何時更新可視化以及應對數據更改應進行的更改。 聲明框架將數據綁定到DOM元素,並在數據更改時自動更新DOM。還使用演示文稿中的模板(HTML標記)而不是JavaScript中的模板提供了這種綁定。 這些框架的附加值可以在幾個關鍵點中標識:-
他們在內容和呈現之間實施更大程度的分離。這是通過讓您在演示層中定義數據,事件處理程序甚至視圖的結構(例如迭代和復合對象,例如表);
- >他們提供了一種簡單的方法,可以使您的數據模型和您的演示文稿保持同步;
> ractive.js
對於ractive.js,我們將要使用的庫,數據和DOM之間的同步是通過>容器對象獲得的。該庫創建對象圍繞數據包裹的對象。這些對象可以訪問數據,因此每次您設置或獲取任何屬性時,庫都可以捕獲您的操作並內部廣播給所有訂戶。 >動手 現在,我們已經看到了什麼是ractive.js有用的,現在該將我們的第一個ractive模板添加到我們的頁面了。為此,您可以在內的任何位置添加帶有您選擇的ID的腳本標籤。我建議您明智地選擇ID,因為我們以後需要它。我們還需要添加類型='text/ractive'屬性:type ='text/ractive' 實際上,對您的瀏覽器沒有任何意義,因為除非您也將ractive的腳本添加到頁面上,否則它會忽略腳本:
現在,在RACTIVE腳本內部,您可以添加HTML標籤,模板變量以及條件/循環。 ractive.js將負責評估{{}}組內的所有內容。<span><span><span><script</span> id<span>='meterVizTemplate'</span> type<span>='text/ractive'</span>></span><span><span></script</span>></span></span>
<span><span><span><script</span> src<span>='http://cdn.ractivejs.org/latest/ractive.js'</span>></span><span><span></script</span>></span></span>
<span><span><span><script</span> id<span>='meterVizTemplate'</span> type<span>='text/ractive'</span>></span><span> </span></span><span><span> <span>{{#batteryState}} </span></span></span><span><span> <span><br> </span></span></span><span><span> <span><div class='battery-div'> </span></span></span><span><span> <span><div class='battery-shell'> </span></span></span><span><span> <span><div class='battery-percent-text'>{{batteryPercent.toFixed(1) + '%'}}</div> </span></span></span><span><span> <span></div> </span></span></span><span><span> <span><div class='battery-level'> </span></span></span><span><span> <span><div class='battery-mask' style="width:{{(100 - batteryPercent) + '%'}};"> </span></span></span><span><span> <span></div> </span></span></span><span><span> <span></div> </span></span></span><span><span> <span>{{#batteryCharging}} </span></span></span><span><span> <span><div class='battery-plug' intro-outro='fade:1000'></div> </span></span></span><span><span> <span>{{/batteryCharging}} </span></span></span><span><span> <span>{{#batteryPercent <= batteryRedThreshold}} </span></span></span><span><span> <span><div class='battery-warning' intro-outro='fade:1000'></div> </span></span></span><span><span> <span>{{/batteryLife}} </span></span></span><span><span> <span></div> </span></span></span><span><span> <span><br> </span></span></span><span><span> <span><br> </span></span></span><span><span> <span><span class='key'>Battery state:</span> <span class='value {{batteryStateClass(batteryState)}}'>{{batteryState}}</span> </span></span></span><span><span> <span><br> </span></span></span><span><span> <span>{{#batteryLife}} </span></span></span><span><span> <span><span class='key'>Time to empty:</span> <span class='value {{batteryLifeClass(batteryPercent)}}'>{{batteryLife}}</span> </span></span></span><span><span> <span>{{/batteryLife}} </span></span></span><span><span> <span>{{/batteryState}} </span></span></span><span><span> <span>{{^batteryState}} </span></span></span><span><span> <span><br> </span></span></span><span><span> <span>LOADING... </span></span></span><span><span> <span>{{/batteryState}} </span></span></span><span><span></span><span><span></script</span>></span></span>
- 條件:{{#batterystate}}}
- >函數召喚:{{{BattuctStateClass(Battertstate)}}}
<span><span><span><script</span> id<span>='meterVizTemplate'</span> type<span>='text/ractive'</span>></span><span><span></script</span>></span></span>
<span><span><span><script</span> src<span>='http://cdn.ractivejs.org/latest/ractive.js'</span>></span><span><span></script</span>></span></span>
<span><span><span><script</span> id<span>='meterVizTemplate'</span> type<span>='text/ractive'</span>></span><span> </span></span><span><span> <span>{{#batteryState}} </span></span></span><span><span> <span><br> </span></span></span><span><span> <span><div class='battery-div'> </span></span></span><span><span> <span><div class='battery-shell'> </span></span></span><span><span> <span><div class='battery-percent-text'>{{batteryPercent.toFixed(1) + '%'}}</div> </span></span></span><span><span> <span></div> </span></span></span><span><span> <span><div class='battery-level'> </span></span></span><span><span> <span><div class='battery-mask' style="width:{{(100 - batteryPercent) + '%'}};"> </span></span></span><span><span> <span></div> </span></span></span><span><span> <span></div> </span></span></span><span><span> <span>{{#batteryCharging}} </span></span></span><span><span> <span><div class='battery-plug' intro-outro='fade:1000'></div> </span></span></span><span><span> <span>{{/batteryCharging}} </span></span></span><span><span> <span>{{#batteryPercent <= batteryRedThreshold}} </span></span></span><span><span> <span><div class='battery-warning' intro-outro='fade:1000'></div> </span></span></span><span><span> <span>{{/batteryLife}} </span></span></span><span><span> <span></div> </span></span></span><span><span> <span><br> </span></span></span><span><span> <span><br> </span></span></span><span><span> <span><span class='key'>Battery state:</span> <span class='value {{batteryStateClass(batteryState)}}'>{{batteryState}}</span> </span></span></span><span><span> <span><br> </span></span></span><span><span> <span>{{#batteryLife}} </span></span></span><span><span> <span><span class='key'>Time to empty:</span> <span class='value {{batteryLifeClass(batteryPercent)}}'>{{batteryLife}}</span> </span></span></span><span><span> <span>{{/batteryLife}} </span></span></span><span><span> <span>{{/batteryState}} </span></span></span><span><span> <span>{{^batteryState}} </span></span></span><span><span> <span><br> </span></span></span><span><span> <span>LOADING... </span></span></span><span><span> <span>{{/batteryState}} </span></span></span><span><span></span><span><span></script</span>></span></span>
異步檢索數據
如所承諾的,這是一個功能,可以照顧從我們的休息服務中檢索數據。通過使用jQuery延期對象,我們設置了一個回調,一旦從服務器收到某些數據,就會被調用。由於我們還在此回調中使用ractive.js,因此我們不必仔細研究如何更新演示層的邏輯。實際上,我們只是更新模板腳本中使用的變量的值,ractive.js將負責所有內容。 我剛剛描述的是由下面報告的代碼實現的:ractive <span>= new Ractive({ </span> <span>el: 'panels', </span> <span>template: '#meterVizTemplate', </span> <span>data: { </span> <span>// Percentage at which the battery goes to 'red' zone (export for Ractive templates) </span> <span>batteryRedThreshold: BATTERY_RED_THRESHOLD, </span> <span>// Percentage at which the battery enters 'yellow' zone (export for Ractive templates) </span> <span>batteryYellowThreshold: BATTERY_YELLOW_THRESHOLD, </span> <span>// The capacity of the battery, in percentage. Initially empty </span> <span>batteryPercent: NaN, </span> <span>// How much more time can the battery last? </span> <span>batteryLife: "", </span> <span>// True <=> the update daemon for the battery has been paused </span> <span>batteryPaused: false, </span> <span>// True <=> the update daemon for the battery has reported an error at its last try </span> <span>batteryUpdateError: false, </span> <span>// Is the battery connected to power? </span> <span>batteryCharging: false, </span> <span>batteryStateClass: function (state) { </span> <span>return state === 'discharging' ? BATTERY_RED_CLASS : BATTERY_GREEN_CLASS; </span> <span>}, </span> <span>batteryLifeClass: function (percent) { </span> <span>return percent <= BATTERY_RED_THRESHOLD ? BATTERY_RED_CLASS : (percent <= BATTERY_YELLOW_THRESHOLD ? BATTERY_YELLOW_CLASS : BATTERY_GREEN_CLASS); </span> <span>} </span> <span>} </span><span>});</span>
將它們全部放在一起
當然,還有更多的接線可以將所有這些連接在一起。我們完全跳過了儀表板UX的設計。最終,這取決於您,一旦您獲得瞭如何使其與模板系統一起使用!例如,如果我們可以使用圖像和動畫將充電百分比顯示為文本,並且在視覺上以某些涼爽的功率指示器顯示為文本和視覺上,那會有多酷?使用ractive.js,這並不難!看看最終結果:
結論
我們的多平台電池儀表板現在應該準備就緒。但這應該是一個起點,而不是最終結果,我希望您在此過程中了解到的重要一點是:- 如何使用node.js 設置HTTP服務器
- > RESTFUL API
- >如何在node.js服務器上運行OS終端命令
- 聲明框架和ractive.js的基礎知識尤其
- 建築風格和基於網絡的軟件體系結構的設計
- >創建RESTFUL API 的指南
- 在本機庫中使用REST API的優點/缺點是什麼? 模板方法模式
- JavaScript中的異步請求
- >克羅克福德(Crockford)在JavaScript上 - 第四集:Ajax的變態 - 像往常一樣的洞察力,以及關於Ajax一詞起源的超級有趣的故事,作為獎勵! >
- > jQuery $ .getjson方法
- ractivejs教程
- >常見問題(常見問題解答)關於使用node.js客戶端創建電池可視化的問題
navigator.getBattery()。然後(function(battery){
console.log(“電池級別:“電池級別:“電池)。 );
});
此代碼將當前的電池電量記錄到控制台。
如何可視化電池狀態數據?
為了可視化電池狀態數據,您可以使用任何JavaScript圖表庫,例如Chart.js或d3.js。這些庫允許您從數據中創建各種類型的圖表和圖形。您還可以使用HTML和CSS創建一個簡單的欄或餅圖。
>我可以在所有設備上獲取電池狀態嗎?
>電池狀態API受到大多數現代瀏覽器的支持,但是不是全部。還值得注意的是,某些設備(例如台式計算機)可能無法提供準確或任何電池狀態信息。>
>如何處理電池狀態更改?
您可以通過將事件偵聽器添加到電池管理器對像中來處理電池狀態更改。電池狀態API提供了多個事件,例如“ ChargingChange”,“ LevelChange”,“ ChargingTimeChange”和“ AnergingTimeChange”。這是如何使用這些事件的一個示例:
navigator.getBattery()。然後(function(Batterion){
battery.addeventlistener('levelChange',function',function(){
console。 log(“電池級別:”電池級*100“%”);
} );
});
>
如果不支持電池狀態API,那麼您沒有什麼可以做的來獲得電池狀態。您可以使用功能檢測來檢查是否支持API,並為用戶提供替代功能或消息。以上是使用node.js創建電池:客戶端的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

Python和JavaScript開發者的薪資沒有絕對的高低,具體取決於技能和行業需求。 1.Python在數據科學和機器學習領域可能薪資更高。 2.JavaScript在前端和全棧開發中需求大,薪資也可觀。 3.影響因素包括經驗、地理位置、公司規模和特定技能。

實現視差滾動和元素動畫效果的探討本文將探討如何實現類似資生堂官網(https://www.shiseido.co.jp/sb/wonderland/)中�...

學習JavaScript不難,但有挑戰。 1)理解基礎概念如變量、數據類型、函數等。 2)掌握異步編程,通過事件循環實現。 3)使用DOM操作和Promise處理異步請求。 4)避免常見錯誤,使用調試技巧。 5)優化性能,遵循最佳實踐。

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

如何在JavaScript中將具有相同ID的數組元素合併到一個對像中?在處理數據時,我們常常會遇到需要將具有相同ID�...

探索前端中類似VSCode的面板拖拽調整功能的實現在前端開發中,如何實現類似於VSCode...
