Web行動裝置 App調試工具——Weinre

來源:互聯網
上載者:User

如今人們也越來越習慣在手機上瀏覽網頁,而在手機上這些針對案頭瀏覽器設計的網頁經常慘不忍睹。Web應用開發人員需要針對手機進行介面的重新設計,但是手機上並沒有稱心如意的調試工具(如Firebug、web inspector),重新設計介面的工作往往事半功倍。本文介紹的調試工具Weinre
就是解決這一問題的優秀調試工具。

 

Weinre是什嗎?

Weinre代表We
b In
spector Re
mote,是一種遠端偵錯工具。舉個例子,在電腦上可以即時
的更改手機上對應網頁的頁面元素、樣式表,或是查看Javascript變數,同時還可以看到手機上頁面的錯誤和警告資訊. 所示中的例子,通過在console中運行“document.body.style.backgroundcolor = 'green';” 即時改變了手機上網頁的背景色。

 

圖1: 案頭的debug用戶端與手機上的對應頁面

 

 

使用一種工具之前,瞭解它的原理和結構是很有協助的。Weinre作為一種遠端偵錯工具,在結構上分為三層:

  • 目標頁面(target):被調試的頁面,頁面已嵌入weinre的遠程js,下文會介紹;
  • Debug用戶端(client):本地的Web Inspector調試用戶端;
  • Debug服務端(agent):一個HTTP Server,為目標頁面與Debug用戶端建立通訊。

三層結構如所示:

 

 

圖2:Weinre組成結構

 

 

Weinre的debug用戶端是基於Web Inspector開發,而Web Inspector只與以WebKit為核心的瀏覽器安全色,所以Weinre的用戶端只能用Chrome或者Safari開啟。

 

運行Weinre

首先需要下載
weinre, weinre目前支援Windows與MacOS, 本文中以Windows版為例。 下載完成之後,啟動weinre的Debug服務端。在下載的weinre.jar所在檔案夾中運行以下命令:

java -jar weinre.jar --httpPort 8081 --boundHost -all-

這行命令在本機啟動了weinre的Debug服務端,連接埠為8081。開啟Chrome或Safari,訪問localhost:8081,就可以看到weinre的基本資料。(設定boundHost為-all-,就可以通過IP訪問Debug服務端,這點很重要)

 

 

中的"debug client user interface"是weinre的Debug用戶端,點擊進入後可以看到目前還沒有被測試的目標網頁。

 

 

如何讓網頁可以被localhost:8081上的weinre檢測到呢?很簡單,只要往網頁面上添加一個js檔案就可以了。如果原生IP為192.168.0.5,那麼就添加如下的js檔案。target-script.js可以獲得從Debug服務端傳來的資訊,更改當前頁面的樣式;也可以運行傳來的js,並返回結果。

 

<script src="http://192.168.0.5:8081/target/target-script.js"></script>

 

注意,對於dojo這樣的非同步載入模組,上面的靜態嵌入的js就會不相容,在有dojo等非同步載入模組的環境下,請在非同步載入全部完成後載入target-script.js

 

dojo.addOnLoad(function(){
    ...
    dojo.create("script",{
     src: "http://192.168.0.5:8081/target/target-script.js"
    }, dojo.body());
   })

 

開啟添加了這個指令碼的網頁後,可以看見在Debug 的用戶端的裡檢測到了新的目標頁面。

 

 

之後我們就能在Elements與Console中調試遠端頁面了。


Debug用戶端中對應的HTML元素:

 

同時也可以查看js對象:

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.