웹 확장 개발
Azure DevOps Services | Azure DevOps Server 2022 - Azure DevOps Server 2019
확장을 사용하여 새 웹 환경, 대시보드 위젯, 빌드 작업 등으로 Azure DevOps를 향상시킵니다. HTML, JavaScript 및 CSS와 같은 표준 기술을 사용하여 확장을 개발할 수 있습니다. 이 자습서에서는 Azure DevOps용 웹 확장을 만드는 방법에 대해 설명합니다.
팁
Azure DevOps Extension SDK사용하여 확장 샘플 및 확장 개발에 대한 최신 설명서를 살펴봅니다.
필수 구성 요소
다음 권한 및 설치를 확인하십시오.
- 조직 소유자여야 합니다. 조직이 없는 경우, 무료로 조직을 만들 수 있습니다.
- Node.js를 설치하십시오.
- TFX(확장 패키징 도구)를 설치합니다. 명령 프롬프트에서
을 실행하여, 나중에 확장을(를) 패키징하는 데 을 사용합니다.
디렉터리 및 매니페스트 만들기
확장은 필수 매니페스트 파일을 포함하는 파일 집합으로 구성됩니다. .vsix 파일로 패키지하고 Visual Studio Marketplace에 게시합니다.
확장에 필요한 파일을 저장할 디렉터리를 만듭니다.
mkdir my-first-extension
이 디렉터리에서 새 npm 패키지 매니페스트를 초기화합니다.
npm init -y
이 파일은 확장에 필요한 라이브러리를 설명합니다.
Microsoft VSS 웹 확장 SDK 패키지를 설치하고 npm 패키지 매니페스트에 저장합니다.
npm install azure-devops-extension-sdk --save
이 SDK에는 확장이 포함된 페이지와 통신하는 데 필요한 API를 제공하는 JavaScript 라이브러리가 포함되어 있습니다.
다음 콘텐츠를 사용하여 확장 디렉터리의 루트에
vss-extension.json
확장 매니페스트 파일을 만듭니다.{ "manifestVersion": 1, "id": "my-first-extension", "publisher": "", "version": "1.0.0", "name": "My First Extension", "description": "A sample Visual Studio Services extension", "public": false, "categories": ["Azure Repos"], "targets": [ { "id": "Microsoft.VisualStudio.Services" } ], "contributions": [ { "id": "my-hub", "type": "ms.vss-web.hub", "targets": [ "ms.vss-code-web.code-hub-group" ], "properties": { "name": "My Hub", "uri": "my-hub.html" } } ], "files": [ { "path": "my-hub.html", "addressable": true }, { "path": "node_modules/azure-devops-extension-sdk", "addressable": true, "packagePath": "lib" } ] }
메모
public
속성은 확장이 Visual Studio Marketplace의 모든 사용자에게 표시되는지 여부를 제어합니다. 개발 중에 확장을 비공개로 유지합니다.확장 디렉터리의 루트에
my-hub.html
라는 이름의 파일을 만들고, 해당 파일에는 웹 환경에 기여하는 보기(허브라고도 함)에 대한 다음 콘텐츠를 포함시킵니다.<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <script src="https://cdnjs.cloudflare.com/ajax/libs/require.js/2.3.6/require.min.js"></script> <script> window.requirejs.config({ enforceDefine: true, paths: { 'SDK': './lib/SDK.min' } }); window.requirejs(['SDK'], function (SDK) { if (typeof SDK !== 'undefined') { console.log("SDK is defined. Trying to initialize..."); SDK.init(); SDK.ready().then(() => { console.log("SDK is ready"); document.getElementById("name").innerText = SDK.getUser().displayName; }); } else { console.log('SDK is not defined'); } }); </script> <style> body { background-color: rgb(0, 67, 117); color: white; margin: 10px; font-family: "Segoe UI VSS (Regular)","-apple-system",BlinkMacSystemFont,"Segoe UI",sans-serif; } </style> </head> <body> <h1>Hello, <span id="name"></span></h1> </body> </html>
확장 디렉터리가 다음 예제와 같이 표시됩니다.
|-- my-hub.html |-- node_modules |-- @types |-- azure-devops-extension-sdk |-- package.json |-- vss-extension.json