精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

手把手教你開發(fā)自己的VSCode插件

開發(fā) 前端
默認情況下,VSCode不直接支持查看某些特定類型的文件。但是,你可以通過使用自定義編輯器(customerEditors)來擴展其功能。

一、前言

在VSCode市場上搜索一個PDF閱讀插件,找到了下載量最高的插件。在檢查了插件的源代碼之后,發(fā)現(xiàn)它直接嵌入了pdf.js的Web界面。

圖片圖片

開發(fā)這樣的插件并不復(fù)雜,只需要一些插件開發(fā)的知識。

接下來,將在這里與大家分享這個插件是如何開發(fā)的。雖然與源代碼可能有些許不同,但基本原理是相同的。

二、定義自定義編輯器

默認情況下,VSCode不直接支持查看某些特定類型的文件。但是,你可以通過使用自定義編輯器(customerEditors)來擴展其功能。

通過customerEditors,你可以創(chuàng)建完全可自定義的讀/寫編輯器,以替換VSCode的標準文本編輯器,用于處理特定類型的資源。

例如,在編輯Markdown文件時,可以創(chuàng)建一個自定義編輯器,從而實時預(yù)覽Markdown的渲染效果。

對于PDF文件的預(yù)覽,同樣也可以使用customerEditors功能。

首先,在插件的pacakge.json文件中定義它:

"contributes": {
  "customEditors": [
    {
      "viewType": "dodo-reader.pdfEditor",
      "displayName": "PDF Viewer",
      "selector": [
        {
          "filenamePattern": "*.pdf"
        }
      ]
    }
  ]
}

三、注冊自定義編輯器

創(chuàng)建一個實現(xiàn)vscode.CustomEditorProvider接口的類。該接口包含了用于管理自定義編輯器(例如打開和保存)的方法。例如:

class PdfEditorProvider implements Partial {
 constructor() {
 // 可在此處進行初始化操作
 }

resolveCustomEditor(document: CustomDocument, webviewPanel: WebviewPanel, _token: CancellationToken) {
 // 基于URI創(chuàng)建一個自定義文檔,并返回一個自定義文檔對象
 }
openCustomDocument(uri: vscode.Uri, openContext: vscode.CustomDocumentOpenContext, token: vscode.CancellationToken) {
 // 將自定義文檔與Webview面板關(guān)聯(lián),并處理編輯器內(nèi)容與Webview之間的交互
 }
}
 // 注冊你的提供程序
const myProvider = new PdfEditorProvider();
const disposable = vscode.window.registerCustomEditorProvider('dodo-reader.pdfEditor', myProvider);
context.subscriptions.push(disposable);

四、改進視圖提供程序

如上所述注冊自定義編輯器之后,下一步就是加強PdfEditorProvider接口,以定義視圖的顯示方式。

顯示涉及使用網(wǎng)絡(luò)視圖,而你將使用pdf.js的Web視圖程序。首先,下載預(yù)構(gòu)建的程序(現(xiàn)代瀏覽器),并將其提取到你的項目目錄中。

圖片圖片

這個程序可以直接在瀏覽器中訪問。在目錄中啟動一個服務(wù),并打開地址:

你可以通過添加查詢參數(shù)?file=fileUrl來打開PDF文件。

4.1 openCustomDocument

當打開PDF文件時,首先會調(diào)用openCustomDocument方法。你可以基于傳入的URI創(chuàng)建一個自定義文檔對象。該文檔對象將包含你想要編輯的內(nèi)容。在這個程序中,不進行任何處理,而是直接返回一個包含URI的對象,該對象將傳遞給resolveCustomEditor方法的document參數(shù)。

openCustomDocument(uri: vscode.Uri, openContext: vscode.CustomDocumentOpenContext, token: vscode.CancellationToken) {
 return {
   uri,
   dispose: () => { }
 };
}

4.2 resolveCustomEditor

在resolveCustomEditor方法中,可以定義要顯示的視圖,程序如下。

resolveCustomEditor(document: CustomDocument, webviewPanel: WebviewPanel, _token: CancellationToken) {
   webviewPanel.webview.html = 'Hello World!';
}

要顯示PDF文件,只需將下載的PDF程序的HTML內(nèi)容替換為當前的webviewPanel.webview.html值。最初認為可以更改為:

// 嵌入一個iframe以查看PDF
webviewPanel.webview.html = `
  
  
   
     
   
   
     
   
  
`

這個方法是最簡單的,但令人意外的是,iframe沒有顯示內(nèi)容。這可能是由于VSCode的安全策略限制造成的。

因此,在這里考慮了另一種方法:讀取PDF視圖主頁的HTML內(nèi)容,并將其賦值給webviewPanel.webview.html。

然而,這種方法可能會遇到一個問題:如何向PDF視圖程序提供文件鏈接。

如前所述,PDF視圖程序?qū)⑼ㄟ^查詢參數(shù)“file.”獲取文件鏈接。如果沒有提供此參數(shù),程序?qū)⒆x取默認鏈接。以下是一個相關(guān)的源代碼示例:

file = params.get("file") ?? _app_options.AppOptions.get("defaultUrl");

然而,直接賦值HTML文本不能通過URL提供“file”的值。這可能需要修改源代碼。盡管修改源代碼可能會帶來一些不便,但一開始似乎也沒有其他辦法,所以不得不嘗試一下。一種方法是改變獲取“file”值的方式,直接從全局變量中獲取。可以使用如下方法在HTML內(nèi)容中添加“file”值:

window.file = 'https://...'

然后將上述源代碼修改為:

file = window.file ?? _app_options.AppOptions.get("defaultUrl");

然而,就在我以為成功即將到來的時候,出現(xiàn)了一個紅色錯誤:“加載PDF時出現(xiàn)錯誤。文件來源與閱覽器不匹配”。

經(jīng)過進一步調(diào)查,在相應(yīng)的源代碼中發(fā)現(xiàn)了一個“fileinputchange”事件監(jiān)聽處理程序,如下所示:

var webViewerFileInputChange = function (evt) {
 if (PDFViewerApplication.pdfViewer?.isInPresentationMode) {
   return;
 }
 const file = evt.fileInput.files[0];
 PDFViewerApplication.open({
   url: URL.createObjectURL(file),
   originalUrl: file.name
 });
};

從代碼中很容易看出,一旦檢測到文件發(fā)生更改,就會立即調(diào)用open方法打開文件。重要的是要注意,該open方法并不驗證URL是否與當前源相匹配。目前,它使用了一個blob鏈接。在這種情況下,我們是否可以在初始化后直接調(diào)用open方法來打開文件呢?經(jīng)過一些改造,最終證明是可行的。以下是修改后的代碼示例:

resolveCustomEditor(document: CustomDocument, webviewPanel: WebviewPanel, _token: CancellationToken) {
   webviewPanel.webview.options = {
     enableScripts: true,
     localResourceRoots: [vscode.Uri.file(path.dirname(document.uri.fsPath)), this.context.extensionUri]
  };
   const base = vscode.Uri.joinPath(this.context.extensionUri, 'dist/web/pdf/web/')
   webviewPanel.webview.html = readFileSync(path.join(base.fsPath, 'viewer.html'), 'utf8').replace('', `
   
   
   
 `)
}

對上面的關(guān)鍵代碼進行分析:

  • localResourceRoots參數(shù):該參數(shù)的目的是定義可以通過Web URL訪問的目錄。在這里,需要明確定義兩個目錄:一個用于打開PDF文件的當前目錄,另一個用于插件所在的目錄。確保兩者都正確定義,否則可能在訪問時遇到401錯誤。
  • tag:通過設(shè)置tag,可以為網(wǎng)頁內(nèi)部加載資源提供基本路徑。確保資源能夠正確加載。
  • setTimeout函數(shù):在調(diào)用程序打開文件時使用setTimeout的目的是在打開默認PDF文件后再打開所需的PDF文件。這樣可以防止后面執(zhí)行打開默認PDF的操作覆蓋想要打開的PDF(盡管實際上會出現(xiàn)默認文件錯誤,但不會產(chǎn)生實質(zhì)性影響)。

與之前提到的PDF插件實現(xiàn)相比,這種實現(xiàn)要簡單得多,但原理基本相同。

責(zé)任編輯:武曉燕 來源: Java學(xué)研大本營
相關(guān)推薦

2021-02-26 11:54:38

MyBatis 插件接口

2024-04-02 08:58:13

2024-03-05 18:27:43

2021-09-26 16:08:23

CC++clang_forma

2022-01-04 08:52:14

博客網(wǎng)站Linux 系統(tǒng)開源

2011-04-28 15:09:15

jQueryjqPlot

2011-05-27 08:41:26

JavascriptFirefox

2017-09-05 13:01:11

CocoaPods開源庫GitHub

2021-07-14 09:00:00

JavaFX開發(fā)應(yīng)用

2011-05-03 15:59:00

黑盒打印機

2025-05-07 00:31:30

2011-01-10 14:41:26

2011-03-28 16:14:38

jQuery

2021-06-04 05:18:29

ARM程序Gdbserver

2023-04-26 12:46:43

DockerSpringKubernetes

2022-01-08 20:04:20

攔截系統(tǒng)調(diào)用

2022-12-07 08:42:35

2022-03-14 14:47:21

HarmonyOS操作系統(tǒng)鴻蒙

2022-07-27 08:16:22

搜索引擎Lucene

2011-02-22 13:46:27

微軟SQL.NET
點贊
收藏

51CTO技術(shù)棧公眾號

精品久久久久久| 销魂美女一区二区| 免费观看国产精品| 成人午夜国产| 国产mv日韩mv欧美| 日韩一区二区福利| 一区二区三区入口| 香蕉久久国产av一区二区| 天堂网在线观看国产精品| 大荫蒂欧美视频另类xxxx| 91一区二区三区| 国产中文av在线| 深夜视频一区二区| 国产午夜精品一区二区三区视频 | 国产精品视频中文字幕91| 一级全黄裸体片| 在线āv视频| 狠狠做深爱婷婷综合一区| 岛国av午夜精品| 福利网在线观看| 国产视频在线一区| 亚洲精品一区二区妖精| 午夜影视日本亚洲欧洲精品| αv一区二区三区| 一区二区成人免费视频| www.成人在线.com| 亚洲欧美日韩人成在线播放| 91在线看www| 久久久久99精品成人片试看| 日本高清精品| 亚洲国产日韩在线一区模特| 国产精品入口免费| 日韩激情一区二区三区| 卡一精品卡二卡三网站乱码| 色综合中文综合网| 欧美大香线蕉线伊人久久国产精品| 日韩精品无码一区二区| 亚欧日韩另类中文欧美| 日本韩国欧美一区二区三区| 天天人人精品| 99久久精品无免国产免费| 久久夜色精品| www.亚洲免费视频| 娇妻被老王脔到高潮失禁视频| av成人在线观看| 亚洲精品伦理在线| 久久国产日韩欧美| 亚洲午夜激情视频| 激情欧美丁香| 亚洲偷熟乱区亚洲香蕉av| 最新中文字幕免费视频| 成人性生活视频| 日韩美女视频19| 国产一区视频观看| 亚洲性猛交富婆| 欧美日韩三区| 亚洲丝袜在线视频| 韩国三级在线播放| 裤袜国产欧美精品一区| 精品国产乱码久久久久久天美 | 久久精品老司机| 色成人免费网站| 亚洲乱码一区二区三区在线观看| 精品视频在线观看| 国产精品无码久久久久成人app| 欧美黄在线观看| 亚洲人线精品午夜| 亚洲理论片在线观看| 午夜日韩影院| 精品国产乱子伦一区| 国产精品久久久久9999小说| 97超碰在线公开在线看免费| 亚洲欧美日韩中文播放| 高清无码一区二区在线观看吞精| 九色视频网站在线观看| 国产成人免费视| 国产成人精彩在线视频九色| 麻豆亚洲av成人无码久久精品| 国内精品伊人久久久| 在线视频欧美日韩精品| 日本免费福利视频| 日韩激情综合| 亚洲精品成人久久| 美女被爆操网站| 免费看久久久| 日韩一级完整毛片| 欧美成年人视频在线观看| 欧美亚洲日本精品| 樱桃国产成人精品视频| 亚洲人精品午夜射精日韩| 中文在线观看免费| 精品成人av一区| 中文久久久久久| 韩漫成人漫画| 56国语精品自产拍在线观看| 黄色在线视频网| 日韩一区网站| 亚洲欧美中文日韩在线| 久久久久久久久久97| 夜久久久久久| 91大神福利视频在线| 国产一级久久久| 日本成人在线视频网站| 国产97在线|亚洲| 成人精品在线看| 亚洲福利电影| 国产精品久久久久国产a级| 亚洲天堂一区在线| 狠狠干成人综合网| 美女国内精品自产拍在线播放| 91无套直看片红桃在线观看| 国产99久久久国产精品成人免费 | 98精品在线视频| 艳妇乳肉豪妇荡乳av| 99久久国产综合精品女不卡| 超碰97国产在线| 国产大学生校花援交在线播放| 久久综合久久综合久久| 久久精品aaaaaa毛片| 欧美jizz18性欧美| 最新久久zyz资源站| www.亚洲天堂网| 外国成人直播| 欧美精品久久久久久久多人混战 | 亚洲国产欧美一区二区丝袜黑人 | 香港欧美日韩三级黄色一级电影网站| 91高潮精品免费porn| 精品国产99久久久久久宅男i| 日韩激情av在线| 国产精品久久久久久久久久久不卡| www香蕉视频| 一区二区中文视频| 鲁一鲁一鲁一鲁一av| 深爱激情久久| 欧美与黑人午夜性猛交久久久| 欧美在线观看不卡| www.日本不卡| 偷拍视频一区二区| 国产精品伦理| 亚洲社区在线观看| 成人免费毛片视频| 久久久综合网站| 日本成年人网址| 一道在线中文一区二区三区| 中文字幕精品网| 无码人妻精品一区二区50| 91在线你懂得| 女人扒开屁股爽桶30分钟| 久久久久97| 777777777亚洲妇女| 人妻va精品va欧美va| 亚洲一区二区在线视频| 欧美 日韩 国产 激情| 先锋影音国产精品| 国产国产精品人在线视| 高清毛片在线看| 欧美日韩精品系列| 高清中文字幕mv的电影| 欧美裸体在线版观看完整版| 欧美日本高清视频| 91麻豆精品在线| 亚洲国产精品国自产拍av| 久操手机在线视频| 日韩美女在线| 日韩经典一区二区三区| 免费成人深夜夜行网站| 韩国精品久久久| 久久综合久久久| av在线看片| 欧美性猛交xxxxxxxx| 中文字幕在线播放一区| 综合国产在线| 国产另类第一区| 美女100%一区| 久久精品国产69国产精品亚洲| 天天操中文字幕| 欧美激情资源网| 免费一级特黄毛片| 欧美成人一级| 日韩在线观看你懂的| 日韩中文字幕在线观看视频| 久久精品一区四区| 无码中文字幕色专区| 少妇一区二区三区| 国产精品永久免费视频| 欧美人与禽猛交乱配| 欧美午夜一区二区| 欧美精品成人久久| 久久青草国产手机看片福利盒子| 亚洲免费看av| 极品少妇一区二区三区| 天堂av一区二区| 超碰97久久| 欧美成人精品xxx| 五月婷婷免费视频| 9191成人精品久久| 日本中文字幕第一页| 日韩理论片一区二区| 国产精品无码在线| 寂寞少妇一区二区三区| 极品美女扒开粉嫩小泬| 91精品久久久久久久久久不卡| 国内精品久久久久久久果冻传媒| 六九午夜精品视频| 视频直播国产精品| 日韩一级片免费在线观看| 欧美三级日韩三级| 丁香激情五月少妇| 波多野结衣视频一区| 搞av.com| 久久亚州av| 成人黄色av网站| 免费av网站在线观看| 亚洲韩国青草视频| 国产又粗又猛又爽| 色婷婷久久久亚洲一区二区三区 | 成人动漫网站在线观看| 天堂网在线最新版www中文网| 亚洲精品乱码久久久久久金桔影视| 在线免费观看av片| 色香蕉成人二区免费| 久久久久久免费观看| 粉嫩aⅴ一区二区三区四区| 亚洲第一狼人区| 久久婷婷av| 青娱乐自拍偷拍| 国产一在线精品一区在线观看| 一区二区三区四区| 日韩精品久久久久久久软件91| 国产精品视频免费在线| а√中文在线8| 在线观看国产精品淫| 国产又粗又猛又爽| 欧美视频在线观看一区| 看黄色一级大片| 亚洲免费在线视频| 日本免费网站视频| 国产精一区二区三区| 少妇高潮毛片色欲ava片| 黄色av日韩| h无码动漫在线观看| 欧美女激情福利| 50度灰在线观看| 窝窝社区一区二区| 久久久久久草| 国产三级精品三级在线观看国产| 69精品小视频| 自拍偷拍亚洲视频| 人人爽久久涩噜噜噜网站| 欧美另类极品| 日韩网站免费观看| 超碰个人在线| 欧美高清在线播放| 国产高清视频在线观看| 亚洲香蕉av在线一区二区三区| 男人av在线| 日韩欧美高清在线| 老熟妇一区二区三区| 在线日韩一区二区| 久艹视频在线观看| 亚洲国产一区在线观看| 日韩精品――中文字幕| 欧美性xxxx极品高清hd直播| 婷婷色中文字幕| 亚洲一区二区在线播放相泽| 国产一级特黄a高潮片| 精品美女永久免费视频| 一级免费在线观看| 亚洲免费在线电影| 久久精品一级片| 欧美日韩中文字幕日韩欧美| 波多野结衣视频观看| 51精品国自产在线| 亚洲成a人片77777精品| 欧美裸体一区二区三区| 精品人妻无码一区二区三区蜜桃一| 欧美本精品男人aⅴ天堂| 中文 欧美 日韩| 一本大道综合伊人精品热热| 中文字幕av网站| 日韩一区二区三区免费看 | 欧美人与性动交| 亚洲免费福利| 91久久久久久久久久久久久| 卡通动漫精品一区二区三区| 亚洲国产欧美不卡在线观看| 一区二区美女| 警花观音坐莲激情销魂小说| 精品国产成人| 8x8x华人在线| 午夜在线一区二区| 日日橹狠狠爱欧美超碰| 激情综合电影网| 欧美黄色性生活| 成人国产视频在线观看| 日本视频在线免费| 精品福利在线视频| 国产又爽又黄又嫩又猛又粗| 亚洲福利视频二区| 天天操天天操天天| 精品久久久久一区| 97在线观看免费观看高清| 亚洲性69xxxbbb| 丝袜中文在线| 久久久久久97| 国产精品一区hongkong| 欧美大片第1页| 黄色成人小视频| 另类视频在线观看+1080p| 欧美阿v一级看视频| 一区二区三区 日韩| 99久久精品国产一区二区三区| 天海翼在线视频| 色综合一个色综合亚洲| 亚洲风情第一页| 久久精品国产2020观看福利| 欧美精品总汇| 精品乱码一区二区三区| 中文字幕免费精品| 亚洲欧美自拍另类日韩| 久久免费视频色| 日韩乱码人妻无码中文字幕| 日韩一区二区在线看| 理论片午午伦夜理片在线播放| 国产成人av在线| 伊人久久综合影院| 免费黄色福利视频| 美女免费视频一区二区| 国产三级精品三级在线| 国产成人精品免费看| 99re6热在线精品视频| 在线精品视频免费观看| 四虎精品在线| 上原亚衣av一区二区三区| 户外露出一区二区三区| 欧美精品七区| 媚黑女一区二区| 操人视频免费看| 99久久精品国产一区| 精品无码av在线| 欧美成人一区二区三区| 18+视频在线观看| 亚洲最大av在线| 在线日本制服中文欧美| 日韩av黄色网址| 26uuu久久天堂性欧美| 青青操在线播放| 欧美另类一区二区三区| 欧美性videos| 91传媒视频在线观看| 午夜久久福利| 精品伦一区二区三区| 亚洲成人第一页| 少妇激情av一区二区| 久久天天躁狠狠躁夜夜av| 欧美男男tv网站在线播放| 精品国产一区二区三区麻豆免费观看完整版 | 国产一区久久久| 免费在线观看成年人视频| 狠狠躁夜夜躁人人爽超碰91| 青梅竹马是消防员在线| 国产成人精品电影久久久| 成人羞羞网站入口| 在线免费黄色小视频| 亚洲一区二区三区中文字幕| 婷婷久久久久久| 国产精品免费视频xxxx| 亚洲精品国产偷自在线观看| 久久久久亚洲AV成人网人人小说| 天天做天天摸天天爽国产一区| 亚洲三级黄色片| 国产精品视频网址| 欧美一区精品| 黄色国产在线观看| 欧美日韩精品一区二区三区蜜桃| 伊人影院在线视频| 欧美13一14另类| 国内精品久久久久影院色| 日本天堂网在线观看| 在线观看欧美www| 天堂久久av| 熟女少妇精品一区二区| 一个色在线综合| av男人天堂网| 91福利视频在线观看| 91欧美在线| 日韩欧美亚洲另类| 中文字幕国产精品一区二区| 国产视频在线观看视频| 日本高清视频精品| 国产精品久久久乱弄 | 欧美激情一区二区三区四区| 国产视频手机在线| 欧美在线观看网站| 亚洲欧美一区在线| 免费看污片的网站| 精品动漫一区二区三区在线观看| 香蕉成人影院| 国产婷婷一区二区三区| 成人欧美一区二区三区白人 |