Github代码空间服务初尝——在线的VSCode
haoteby 2024-11-22 15:24 20 浏览
Github最近在内测一款新的秘密武器代码空间服务,一种由Visual Studio Code支持的在线浏览器内集成开发环境。该服务可以让用户快速加载虚拟机和完整的集成开发环境 (IDE),用户只需通过浏览器就进行代码编辑和调试,支持对常见语言的调试。
代码空间包括为特定仓库开发所需的一切,其中包括具有语法突出显示和自动完成功能的文本编辑器、终端、调试工具和 Git 命令,所有这些都集成在 GitHub 中。也可以在代码空间中安装 Visual Studio Code 扩展以添加更多功能。
使用Gitlab的同学可能都用过Gitlab的WebIDE,Github代码空间的使用类似于此,但是基于VSCode,体验效果可能会更好。目前该服务属于Beta内测阶段,需要发出请求申请内测,经过审核后才能尝试。
初探
GitHub代码空间和仓库紧密相关,获得内测资格后,有关仓库的右侧项目概览部分就有一个按钮"Open with Codespaces",打开该按钮就可以进行代码编辑。无需任何额外配置,马上即可在线工作。
也可以通过Github页面的顶部的顶级菜单Codespaces,打开代码空间。
然后选择要打开的具体项目:
加载代码空间需要花费一点时间。GitHub代码空间界面是典型的VSCode界面,左边是活动栏,侧边栏、编辑栏,面板栏和状态栏。
很明显,是基于Visual Studio Code,还是典型的暗模式。整个界面包浏览器期望的所有标准功能,例如语法突出显示,ViM和Emac绑定(在浏览器中很好用)以及默认启用的自动保存。
还可以将文件从本地计算机拖放到Codespaces文件系统中,并在浏览器中预览和编辑某些非文本文件,例如图像,这两个文件对于Web开发都是非常方便的。
终端模拟器
GitHub代码空间包含一个功能强大的终端编辑器,该编辑器似乎基于Debian镜像。使用下拉列表而不是使用选项卡访问单独的终端。而且重要的,该终端下也能运行Docker。
能够在浏览器中简单运行Docker很棒。默认情况下未安装Docker-compose,目前其工作模式我们还不得而知,以后可以了解下。
在终端仿真器中发现的唯一问题是,只能通过右键单击将其粘贴到基于Chromium的浏览器(例如Chrome或Edge),Firefox好像不行。
代码转发
端口转发使我们可以访问在代码空间中运行的TCP端口。例如,如果在端口3000上运行Web应用程序,则可以从浏览器访问该应用程序以对其进行测试和调试。
Github代码空间在处理端口转发方面做得很出色,当代码空间内运行的应用程序将端口输出到控制台时,代码空间将检测到localhost URL模式并自动转发这些端口。可以通过单击终端中的URL,以在浏览器中将其打开。例如,如果应用程序输出http://127.0.0.1:3000或输出http://localhost:3000到控制台,日志将自动将输出。如果GitHub检测到localhost:PORT组合,就可以通过单击URL对其进行访问,如下所示:
示例中的Jekyll加载和重新加载很快,当单击转发的链接或切换选项卡以预览站点的更改时,它就会刷新站点。该功能仅支持Chromium的功能,在Firefox中好像也有问题。
可以通过通过触发命令面板(shift+command+P或者shift+control+P)并,输入"Codespaces: Forward Port"来按需转发端口。然后,可以输入要转发的端口号。
也可以通过.devcontainer.json文件中的forwardPorts属性配置转发的端口。
在"Remote Explorer远程资源管理器"扩展中支持添加或删除转发的端口,并可以复制并粘贴转发端口的URL,可以在浏览器中通过该Url访问。
总结
这是一个非常棒的功能,可以帮助那些不是很专门的开发人员进行在线开发。专业开发人员也可以偶尔用来应急代码调试,这样就不需要时常背着笨重的笔记本了。
另外GitHub代码空间还有很其他的功能包括协作工作区,Git集成以及与Visual Studio本地版本的连接。还需要大家一起探索学习。
相关推荐
- Chrome OS 41 用 Freon 取代 X11_chrome os atom
-
在刚发布的ChromeOS41里,除了常规的Wi-Fi稳定性提升(几乎所有系统的changelog里都会包含这一项)、访客模式壁纸等之外,还存在底层改变。这一更新中Google移除...
- 苹果iPad Pro再曝光 有望今年六月发布
-
自进入2015年以后,有关大屏iPad的消息便一直不绝于耳,之前就有不少媒体猜想这款全新的平板电脑将会在三月发布,不过可惜的是我么只在那次发布会上看到了MacBookPro。近日@Ubuntu团队便...
- 雷卯针对香橙派Orange Pi 5 Max开发板防雷防静电方案
-
一、应用场景高端平板、边缘计算、人工智能、云计算、AR/VR、智能安防、智能家居、Linux桌面计算机、Linux网络服务器、Android平板、Android游戏机...
- Ubuntu Server无法更新问题解决_ubuntu server not found
-
上周老家的一台运行UbuntuServer的盒子无法连接上了,中秋这两天回来打开,顺手更新一下发现更新报错。提示`E:Releasefileforhttps://mirrors.aliyun...
- 虚幻引擎5正式版发布:古墓丽影&巫师新作采用、新一代实时渲染
-
机器之心报道编辑:杜伟、陈萍虚幻引擎5的目标是「助力各种规模的团队在视觉领域和互动领域挑战极限,施展无限潜能」。...
- AMD Milan-X双路霄龙7773X平台基准测试曝光 CPU缓存总量超1.5GB
-
OpenBenchmarking基准测试数据库刚刚曝光了AMDMilan-X双路霄龙7773X平台的跑分成绩,虽然很快就被撤下,但我们还是知晓了高达1.6GB的总CPU缓存。早些时...
- 全网最新的Dify(1.7.2)私有化离线部署教程(ARM架构)
-
Hello,大家好!近期工作中有涉及到Dify私有化离线部署,特别是针对于一些国产设备。因此特别整理了该教程,实测有效!有需要的小伙伴可以参考下!本文主要针对Dify1.7.2最新版本+国产操作系...
- 在ubuntu下新建asp.net core项目_创建ubuntu
-
本文一步步讲述在ubuntu下用visualstudiocode创建asp.netcore项目的过程。step1:环境操作系统:virtualbox下安装的lubuntu。请不要开启“硬件...
-
- 在晶晨A311D2处理器上进行Linux硬件视频编码
-
在KhadasVIM4AmogicA311D2SBC上,我更多的时间是在使用Ubuntu22.04。它的总体性能还不错,只不过缺少3D图形加速和硬件视...
-
2025-08-26 17:22 haoteby
- Nacos3.0重磅来袭!全面拥抱AI,单机及集群模式安装详细教程!
-
之前和大家分享过JDK17的多版本管理及详细安装过程,然后在项目升级完jdk17后又发现之前的注册和配置中心nacos又用不了,原因是之前的nacos1.3版本的,版本太老了,已经无法适配当前新的JD...
- 电影质量级渲染来了!虚幻引擎5.3正式发布:已开放下载
-
快科技9月8日消息,日前,Unrealengine正式发布了虚幻引擎5.3,带来了大量全方位的改进。...
- 2025如何选购办公电脑?极摩客mini主机英特尔系列选购指南
-
当下,迷你主机的性能越来越强,品类也越来越多。但是CPU是不变的,基本都是AMD和英特尔的。有一个小伙伴在评论区提问,我应该如何在众多机器中选购一台符合自己的迷你主机呢?那今天我们优先把我们的系列,分...
- ubuntu 20.04+RTX4060 Ti+CUDA 11.7+cudnn
-
ububtu添加国内源sudocp/etc/apt/sources.list/etc/apt/sources.list.backupsudovim/etc/apt/sources.lis...
- Linux Mint 18将重新基于Ubuntu 16.04 带来更好硬件支持
-
项目负责人ClementLefebvre在本月6日披露了关于LinuxMint18“Sarah”操作系统的大量信息,包括带来全新扁平化体验的Mint-Y主题。而现在,这款将于年底之前上线的操作...