代码拉取完成,页面将自动刷新
(self.webpackChunktypescriptlang_org=self.webpackChunktypescriptlang_org||[]).push([[930],{2125:function(e,t,n){"use strict";n.d(t,{X:function(){return r}});var l=n(2784),a=n(8447),r=function(e){var t=function(t){return e.active&&e.active.toLowerCase()===t?"active":""};return l.createElement("nav",{className:"navbar-sub dev-tools"},l.createElement("ul",{className:"nav"},l.createElement("li",{className:"name"},l.createElement("h3",null,"Developer Tools")),l.createElement("li",{style:{display:"none"}},l.createElement("a",{className:t("compiler api"),href:(0,a.withPrefix)("/dev/compiler")},"Compiler API")),l.createElement("li",null,l.createElement("a",{className:t("sandbox"),href:(0,a.withPrefix)("/dev/sandbox")},"Sandbox")),l.createElement("li",null,l.createElement("a",{className:t("twoslash"),href:(0,a.withPrefix)("/dev/twoslash")},"Twoslash")),l.createElement("li",null,l.createElement("a",{className:t("typescript vfs"),href:(0,a.withPrefix)("/dev/typescript-vfs")},"TypeScript VFS")),l.createElement("li",null,l.createElement("a",{className:t("playground plugins"),href:(0,a.withPrefix)("/dev/playground-plugins")},"Playground Plugins")),l.createElement("li",null,l.createElement("a",{className:t("bug workbench"),href:(0,a.withPrefix)("/dev/bug-workbench")},"Bug Workbench"))))}},8591:function(e,t,n){"use strict";n.r(t);var l=n(2784),a=n(7480),r=n(8447),o=n(4345),i=n(2125),c=function(e){return l.createElement(l.Fragment,null,l.createElement(a.A,{title:"Developers - Playground Plugins",description:"What is a TypeScript Playground Plugin, and how can you make one?",lang:"en"},l.createElement("div",{id:"dev"},l.createElement(i.X,{active:"playground plugins"}),l.createElement("div",{className:"raised content main-content-block"},l.createElement("div",{className:"split-fivehundred"},l.createElement("h1",{style:{marginTop:"20px"}},"Your toys, our sandbox"),l.createElement("p",null,"The new TypeScript Playground allows people to hook into the Playground and extend it in ways in which the TypeScript team don't expect."),l.createElement("p",null,"The sidebar of the Playground uses the same plugin infrastructure as external plugins, so you have the same level of access as the playground to build interesting projects."),l.createElement("p",null,"Playground plugins are built via the DOM API and an expansive Design System, however, you're free to use a framework like React or Svelte at runtime."),l.createElement("p",null," "),l.createElement("p",null,"Getting started is easy, we have a plugin template, and the Playground has a dev-mode for hooking directly to your local server, so you don't need to run a copy of the TypeScript website to have a working development environment."),l.createElement("p",null,"There is a repo of sample plugins at ",l.createElement("a",{href:"https://github.com/microsoft/TypeScript-Playground-Samples/"},"microsoft/TypeScript-Playground-Samples")," and there are many existing open source plugins to look at too: ",l.createElement("a",{href:"https://github.com/orta/playground-slides"},"Presentation Mode"),", ",l.createElement("a",{href:"https://github.com/orta/playground-clippy#playground-plugin-clippy"},"Clippy")," ",l.createElement("a",{href:"https://github.com/orta/playground-plugin-tsquery"},"TSQuery"),", ",l.createElement("a",{href:"https://github.com/orta/playground-collaborate#typescript-playground-collaborate"},"Collaborate")," and ",l.createElement("a",{href:"https://github.com/orta/playground-transformer-timeline"},"Transformer")," which are available by default for you to investigate and understand."),l.createElement("p",null,"If you have questions as you are working on your plugin, ask in the ",l.createElement("a",{href:"https://discord.gg/typescript"},"TypeScript Community Discord"),". When it is polished, ship it to the npm registry and it will make its way into the plugins sidebar.")),l.createElement("div",{className:"fivehundred",style:{borderLeft:"1px solid gray"}},l.createElement("img",{src:n(6366).Z,width:"100%",alt:"Screenshot of the playground showing the plugins tab"}))),l.createElement("div",{className:"raised main-content-block"},l.createElement("h2",null,"Quick Tutorial"),l.createElement("p",null,"You need about 5 minutes, Node.js, yarn and Firefox/Edge or Chrome."),l.createElement("p",null,l.createElement("b",null,"Step 1"),": Use the template to bootstrap: ",l.createElement("code",null,"yarn create typescript-playground-plugin playground-my-plugin")),l.createElement("p",null,l.createElement("b",null,"Step 2"),": Run ",l.createElement("code",null,"yarn start")," in the new repo, to start up the local dev server"),l.createElement("p",null,l.createElement("b",null,"Step 3"),": Open the ",l.createElement("a",{href:(0,r.withPrefix)("/play/")},"playground"),' in your browser, click "Options" and enable ',l.createElement("code",null,'"Connect to localhost:5000/index.js"')),l.createElement("p",null,l.createElement("b",null,"Step 4"),": Refresh, and see the new tab. That's your plugin up and running"),l.createElement("p",null," "),l.createElement("p",null,"That's all the pieces working in tandem, now you can make changes to the template and build out your plugin. The plugin in dev mode will always become forefront when connected, so you can re-load without a lot of clicks. To understand the template's technology, read the ",l.createElement("a",{href:"https://github.com/microsoft/TypeScript-Website/blob/v2/packages/create-typescript-playground-plugin/template/CONTRIBUTING.md"},"CONTRIBUTING.md")),l.createElement("h2",null,"Alternatives"),l.createElement("p",null,"There are community-run templates for Playground plugins which bootstrap your plugin with well-known view libraries:"),l.createElement("ul",null,l.createElement("li",null,l.createElement("a",{href:"https://github.com/gojutin/typescript-playground-plugin-react#typescript-playground-plugin-react"},"gojutin/typescript-playground-plugin-react")),l.createElement("li",null,l.createElement("a",{href:"https://github.com/gojutin/typescript-playground-plugin-svelte#typescript-playground-plugin-svelte"},"gojutin/typescript-playground-plugin-svelte"))),l.createElement("p",null,"They have their own up-to-date documentation in their READMEs.")))))};t.default=function(e){return l.createElement(o.R,{locale:"en"},l.createElement(c,e))}},6366:function(e,t,n){"use strict";t.Z=n.p+"static/playground-plugin-preview-3fa319f7efff676f839a57ad3d8be916.png"}}]);
//# sourceMappingURL=component---src-pages-dev-playground-plugins-tsx-416795800ae4687f7f82.js.map
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。