[翻譯]一個新式的基於文本的瀏覽器 Browsh

来源:https://www.cnblogs.com/AlienXu/archive/2018/07/15/9314205.html
-Advertisement-
Play Games

介紹 什麼是Browsh? Browsh是一個純文本瀏覽器,可以運行在大多數的TTY終端環境和任何瀏覽器。目前1 ,終端客戶端比瀏覽器客戶端更先進2。 TTY 客戶端 終端客戶端即時更新和交付,以便於體驗新的功能,例如,你可以觀看視頻。它使用UTF 8半塊技巧(& 9600;)3從每個字元單元中獲取 ...


介紹

什麼是Browsh?

Browsh是一個純文本瀏覽器,可以運行在大多數的TTY終端環境和任何瀏覽器。目前1 ,終端客戶端比瀏覽器客戶端更先進2

TTY 客戶端

終端客戶端即時更新和交付,以便於體驗新的功能,例如,你可以觀看視頻。它使用UTF-8半塊技巧(▀)3從每個字元單元中獲取2中顏色,從而模擬基本圖形。對那些支持它的終端,除了鍵盤輸入,它也可以理解滑鼠輸入。因此,你可以點擊鏈接,甚至在素描彩繪APP中繪製線條。

瀏覽器客戶端

瀏覽器客戶端有些複雜,容易混淆。Browsh在另一個瀏覽器中運行解析,然後在瀏覽器客戶端上呈現出簡單HTML和純文本。Browsh輸出的HTML和文本是極其輕量級的,這一點很關鍵。在2018年,普通的網站寫入,需要下載大約3M數據,併發出超過100獨立HTTP請求。換到Browsh,它大約需要15kb,2個HTTP請求-一個用於HTML/文本,另一個用於favicon。

目前,HTML/文本 輸出非實時更新,也非互動式,希望瀏覽器客戶端最終具有與TTY客戶端相同的功能。

安裝

請參閱安裝頁面。

設計

Browsh包含一個最小的Golang CLI客戶端和一個瀏覽器webextension。當CLI啟動時,它會查找相容的瀏覽器(目前只有Firefox)並以無頭模式4啟動它。瀏覽器啟動後,將打開遠程調試連接並安裝擴展。

當網頁在瀏覽器中載入時,自定義腳本將註入頁面,然後在webextension中連接到Browsh的後臺進程。此後臺進程本身通過websocket連接到CLI客戶端。

每頁內容腳本還應用一些自定義CSS,以嘗試使頁面儘可能接近剛性網格,如終端單元所強制執行的那樣。這並不總是成功的,因為網頁經常小心地將元素定位到不是字元單元格的像素值 - 因此當2個字元想要占據相同的單元格時,有時需要做出妥協。

為了節省必須解析每個角色的顏色和可見度,Browsh使用自定義的單字形全塊字體,其中每個字元都是:▇。解析元素的計算樣式在計算上是昂貴的。因此,為了獲得字元的顏色,框架構建器檢查頁面的屏幕截圖的像素值,該像素值對應於字元的位置。這還有一個額外的好處,即能夠在不解析CSS的情況下檢測角色的可見性 - 如果在顯示和隱藏文本時像素值改變顏色,則角色是可見的。當然有邊緣情況,但它們的頻率意味著處理它們仍然比CSS解析更便宜。

在TTY客戶端的情況下,幀的圖形是在原始頁面的隱藏文本狀態期間生成的。然後將此屏幕截圖縮放到與活動終端相同的大小。然後將那些像素值轉換為終端顏色轉義碼。最後,文本在圖形上分層並呈現給終端。

譯者註:
1.官網顯示該介紹更新於2018年7月13日
2.更先進的意思大略是指終端客戶端的完善度較瀏覽器客戶端高
3.UTF-8 方塊元素 HTML字元集
4.headless mode:指可以在不打開UI界面的情況下使用瀏覽器

英文原文:https://www.brow.sh/docs/introduction/


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言 在本系列上一篇文章Android包管理機制(一)PackageInstaller的初始化中我們學習了PackageInstaller是如何初始化的,這一篇文章我們接著學習PackageInstaller是如何安裝APK的。本系列文章的源碼基於Android8.0。 1.PackageInsta ...
  • 網路請求數據格式: 總的網路請求數據格式: 外層數據格式 數據模型: .h文件 .m文件 initWithDictionary: 解析數據 解析數據: 結果: 中間層數據格式 1 categories = ( 2 { 3 alias = Politics; 4 name = "\U65f6\U653 ...
  • 前言 包管理機制是Android中的重要機制,是應用開發和系統開發需要掌握的知識點之一。 包指的是Apk、jar和so文件等等,它們被載入到Android記憶體中,由一個包轉變成可執行的代碼,這就需要一個機制來進行包的載入、解析、管理等操作,這就是包管理機制。包管理機制由許多類一起組成,其中核心為Pa ...
  • 總結了一周學習Js的筆記、關於git、GitHub、this、作用域等 ...
  • 1.前言 Vue 是一款友好的、多用途且高性能的javascript框架,與其它大型框架不同的是,Vue 被設計為可以自底向上逐層應用,它能夠幫你創建可維護性和可測試性更強的代碼庫,Vue是漸進式的javascript框架庫。 2.安裝簡介 Vue集成環境三大核心組件:node.js,npm,vue ...
  • 網路載入類 減少 HTTP 資源請求次數 合併靜態資源圖片、JavaScript 或 CSS 代碼,減少頁面請求數和資源請求消耗 避免重覆的資源,防止增加多餘請求 減小 HTTP 請求大小 減少沒必要的圖片、JavaScript、CSS 及 HTML 代碼 對文件進行壓縮優化 使用 gzip 等方式 ...
  • 表單選擇器 :input(匹配所有input、textarea、select和button元素) :text(匹配所有單行文本框) :password(匹配所有密碼框) :radio(匹配所有單項按鈕) :checkbox(匹配所有覆選框) :submit(匹配所有提交按鈕) :image(匹配所有 ...
  • 在《JavaScript高級程式設計》第三版 4.1.3,講到傳遞參數: ECMAscript中所有函數的參數都是按值傳遞 按值傳遞 也就是,把函數外部的值複製給函數內部的參數,就和把值從一個變數複製到另一個變數一樣 當傳遞value給函數foo的時候,相當於拷貝一份value給foo假設拷貝的那份 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...