蒲公英 · JELLY技術周刊 Vol.13 跟 VSCode 學習如何開發大型 IDE 項目

来源:https://www.cnblogs.com/o2team/archive/2020/07/08/13265166.html
-Advertisement-
Play Games

開發一個 IDE 很難麽?這或許是件很難的事情,但當我們參考 VSCode 的技術構架來看,整個開發流程就會平滑順暢很多,從內核開發、代碼編輯器、視圖結構到插件系統,在這整個技術構架中我們可以看到很多一個 IDE 開發中需要註意的方方面面。如果你對 VSCode 深入研究過,相信可以從中頗受啟發,在 ...


HEADER

開發一個 IDE 很難麽?這或許是件很難的事情,但當我們參考 VSCode 的技術構架來看,整個開發流程就會平滑順暢很多,從內核開發、代碼編輯器、視圖結構到插件系統,在這整個技術構架中我們可以看到很多一個 IDE 開發中需要註意的方方面面。如果你對 VSCode 深入研究過,相信可以從中頗受啟發,在此之前不妨先來看看本期推薦。

登高遠眺

天高地迥,覺宇宙之無窮

基礎技術

跟 VSCode 學習如何開發大型 IDE 項目

VSCode 是當下非常流行的微軟開源的代碼編輯器,它在滿足多樣性插件化生態的同時保證了軟體的健壯和性能,這得益於其優秀的插件化內核架構設計。本文作者是螞蟻金服雲鳳蝶團隊成員,文中對 VSCode 的關鍵技術架構作了深刻的剖析和理解,包括內核分層隔離與擴展機制、依賴註入、命令系統、插件化架構等等,如果你正在打造一個可擴展的軟體系統,這篇解讀非常值得去學習參考。其實,VSCode 的優秀架構離不開其專註而剋制的產品定位——“編輯器 + 代碼理解 + 調試”,其他的內容交給社區生態來擴展。最完美的設計,往往是精簡到極致,而無法再做減法了。

前端進階:跟著開源項目學習插件化架構

微內核(插件化)架構被廣泛應用於軟體系統設計中,譬如 Vue 的插件機制 Vue.use(Plugin) 就是一個簡單的插件化設計。微內核架構既能滿足靈活擴展的特性,又不影響系統的穩定性。本文基於西瓜視頻播放器項目來闡述微內核架構的實踐應用,在播放器中,小到一個播放按鈕大到一項直播功能特性都可以理解為一個插件模塊。作者貼合簡練的代碼,講述了插件系統中插件管理、連接和通信的全過程,非常通俗易懂。

圖形編程

UI 交互動效合輯

這個合輯收集了近期較有創意的 UI 交互轉場動效,可以看到許多不同於尋常轉場交互的想法,比如波紋、圖形變形與轉場動畫的結合,又比如利用弧形色塊的變化進行的轉場效果等等,目前已發佈了8期內容,有網頁動效設計需求的設計或開發都可以瀏覽參考,同時感受一下優秀動效設計中的緩動曲線。

AR 體驗的“後浪”來了:ARCore Depth API 讓遮擋難題迎刃而解

針對 AR 開發場景中景深演算法的 Depth API 正式發佈。有了這個 API,開發者在支持 ARCore 的 Android 設備上開發 AR 場景時可以更準確地處理虛擬物體與現實物體的遮擋關係,完全杜絕虛擬物體與透視關係不符的“貼圖”問題,使得虛擬物體沉浸效果更為真實。文中還有更多的應用場景,並提供了海量動圖演示。

桌面開發

Flutter 在桌面端的最新進展:支持打包 Windows 和 Linux 應用了

Flutter 的目標是支持儘可能多的平臺和設備,我們已經知道它可以很好地在 iOS 和 Android 設備上運行了,那麼它對桌面端的支持情況如何呢?Tim Sneath,Flutter 產品經理,在最近的一篇博文中分享了他們最新的進展,聊到了他們支持了打包 Windows 和 Linux 應用了,如何調用不同桌面系統的原生組件,以及更新插件模型來方便開發者更容易地支持不同的平臺等工作。Tim Sneath 還分享了有開發者已經利用 Flutter 發佈了最新的桌面端應用,你也可以跟隨本文,嘗試一下,看看 Flutter 桌面端能否滿足你的需求。
譯文:https://jelly.jd.com/article/5ef9e4ac7c53070156dd5b8a

服務端開發

Easy-Monitor3 開始你的Node.js內核性能監控之旅

Easy-Monitor3是一款基於 Node.js Addon實現的開源內核採樣以及收集工具,提供完整的Web UI支持(APM),支持私有化部署,全平臺支持。可用於記憶體泄露分析,性能瓶頸分析,監控告警等。

工具推介

AutoCannon:一款http壓測工具

AutoCannon是一款使用node編寫的壓測工具,能比wrk生成更多負載,市面上類似的產品很多,老牌的ab,帶有圖形界面的soap ui等。不過AutoCannon可以方便的進行命令行調用,甚至還能在代碼內調用,這對於寫壓測腳本來說就非常方便。另外它還能結合node clinic 一起使用,定位性能問題無往而不利。

滄海拾遺

滄海拾遺,積跬步以至千里

實現一個簡單但有趣的 AR 效果

看完 Depth API 這樣的 AR 後浪,不知道你有沒有心動呢?如果你也想快速上手 AR,不妨來試試這樣一個簡單的效果,讓你快速對 Web AR 有一個瞭解,這些基礎能幫助我們在 AR 這條路上走的更遠。

碰撞檢測 -- 源自生活的特效

Web 中有很多常見的 2D 碰撞檢測,掌握這些實用的小技巧,在特定需求的頁面中會有更為出色的體驗。你對這些方法熟悉麽?還不瞭解的話可以進來試試看哦~「內含基於 Canvas 的運行實例、圖片說明」

「蒲公英」期刊,每周更新,我們專註於挖掘「基礎技術工程化跨端框架技術圖形編程服務端開發桌面開發人工智慧」等多個大方向的業界熱點,並加以專業的解讀;不僅如此,我們還精選凹凸技術文章,向大家呈現團隊內的研究技術方向。

抬頭仰望,蒲公英的種子會生根發芽,如夏花絢爛;格物致知,我們登高遠眺、滄海拾遺,以求積硅步而至千里。

蒲公英 · JELLY技術周刊貢獻指南

FOOTER

歡迎關註凹凸實驗室博客:aotu.io

或者關註凹凸實驗室公眾號(AOTULabs),不定時推送文章:

歡迎關註凹凸實驗室公眾號


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

-Advertisement-
Play Games
更多相關文章
  • ​互聯網的高速發展促使互聯網企業對於網站等頁面的用戶體驗要求也越來越高,導致網站開發難度越來越大,於是一個新興職業應運而生——web前端工程師。因為互聯網時代的高速發展,公司企業的迫切需求web前端工程師,web人才成為各大公司名企爭搶的“香餑餑”。 ...
  • 簡介 http-server是一個簡單的零配置命令行http伺服器。 它足夠強大,足以用於生產用途,但它既簡單又易於破解,可用於測試,本地開發和學習 應用場景 1、區域網訪問靜態頁面 訪問本地電腦中的文件都是基於file協議,如果要開放我們的本地文件給區域網人員訪問,是不能使用file協議。得用h ...
  • 今天為什麼要給大家講解這個東西呢,因為css這部分,尤其是數值這部分感覺非常簡單,但是尤其是簡單的,卻很多人根本就沒有弄懂。所以今天就來講一下css的數值問題吧。大家還是好好聽一下吧。 width height 百分比 當元素的height、width設置為百分比時,分別基於包含它的塊級對象的高度、 ...
  • 今天面試了一個前端實習生,我問了一個比較簡單的問題,就是css如何實現元素垂直居中的問題,但是要說出多種方案。其實他說的不錯,基本上說到了flex佈局,grid佈局等下麵提到的佈局。還不錯,但是這幾種都是已經經常用的,老生常談,但是我想聽到他說一種用的比較少的解決方案,瞭解一下他學習的深度和廣度。但 ...
  • 許多同學是不是還在徘徊、猶豫、糾結的階段,想學怕學不好,甚至不知從何入手,下麵這篇文章幫助想轉行前端及想學好Web前端開發的同學們解決心中的困惑。 1HTML的學習 超文本標記語言(HyperTextMark-up Language簡稱HTML)是一個網頁的骨架,無論是靜態網頁還是動態網頁,最終返回 ...
  • 前端埋點主要是為了服務運營人員採集用戶行為數據,進行後續的數據分析工作。 前端監控和埋點能做什麼 數據監控(用戶行為) pv,uv 記錄操作系統 用戶在每一個頁面的停留時間(離開頁面,進入頁面) 用戶進入的入口 用戶在相應頁面的觸發行為,點擊按鈕 性能監控 (js中的performance) 用戶的 ...
  • 綜合來講,Web前端培訓分為HTML5+CSS3、JS交互設計、移動端、伺服器、前端框架、小程式六大模塊,下麵就為大傢具體介紹每個階段學什麼。 第一階段前端核心基礎,讓學員掌握前端基礎知識包括HTML5與CSS的基礎知識和代碼的撰寫會學習PC端網站佈局以及jQuery框架。 第二階段HTML5 + ...
  • web前端現在是一個很熾手可熱的職業,現在前端工程師到底能賺多少錢?月薪3000和30000的工程師到底差在哪?前端的待遇為什麼這麼高? 今天我們來具體分析一下。 web前端的薪資是多少? 我們先用三個數據瞭解一下。 web前端在北京地區的薪資: 北京前端開發工程師平均工資:¥ 18690/月,取自 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...