Visual Studio Code入门(译)

实质上,Visual Studio Code是一款代码编辑器,像许多其他代码编辑器一样,VS Code的左边采用了一个共同的用户界面和资源管理器的布局,它显示了所有你可以访问的文件和文件夹,它的右边是一个编辑器,显示你打开过的文件内容。

image

文件,文件夹和项目

VS Code是基于文件和文件夹的,你可以用VS Code打开一个文件和文件夹。在此之上,VS Code有读取和利用由不同框架和平台定义的项目文件的优势。比如,你打开的文件包含一个或多个package.js,project.json,tsconfig.json和项目文件,VS Code能读取这些文件并使用它们来提供额外的功能。在编辑中,它们像丰富的自能感知。

基本布局

VS Code有一个简单直观的布局,它提供最大化的编辑空间,同时留下足够空间来浏览和访问你的文件夹或项目全部上下文。它的用户界面分为五个方面:

  • 编辑器:来编辑你的文件。你可以同时打开三个的编辑。
  • 侧边框:包含不同的视图。在你的项目工作的时候,视图像资源管理器来帮助你。
  • 状态栏:显示打开的项目和编辑的文件的相关信息。
  • 视图栏:位于最左边的视图栏,可以让你在视图之间切换并给你更多的特定于上下文指示
  • 面板:在编辑区下面有不同的面板,面板有输入或调试信息,错误和警告或一个集成终端。

当你每次打开VS Code,它跟你上次关闭它时的状态一样。文件夹,布局,打开的文件都被保存。

image

VS Code允许同时打开三个可视编辑器,这样你可以编辑或查看并排一起的三个文件。在编辑区顶部区域,每个被打开的文件都有选项卡头部(Tabs)

提示:侧边框移动到右侧(View > Move Side Bar),切换显示/隐藏 ⌘B

分栏编辑

你最多可以并排的打开三个编辑器。

如果你已经打开一个编辑,你有很多方法打开其他编辑器,而且新编辑器会出现在当前编辑器一边。方法如下:

  • 按住 Ctrl (Mac:'Cmd'),同时点击一个文件
  • +\ 组合可以把一个编辑器分裂为两个。
  • 右击文件然后点击 Open the side
  • 点击编辑器右上角的 Split Editor 按钮
  • 把文件拖拽到编辑器的两侧
image

每次你打开一个文件的时候,编辑器将显示当前文件的内容。如果你有2个编辑器并排着,并且你想打开一个文件出现在编辑器的右边,在打开这个文件前,务必确保那个编辑器被选中(通过点击编辑器里面)。

当你有一个或多个编辑器被打开过,而且想快速在他们之间切换 Ctrl (Mac:'Cmd')+1,2或3

提示:你可以缩放编辑器,也可以对他们重新进行排序。拖拽编辑器的标题区域到其他位置。拖拽编辑器的边缘缩放编辑器。

资源管理器

在你的项目里,资源管理器是被用来浏览,打开,管理所有文件和文件夹的。

用VS Code打开你的文件夹后,该文件夹的内容在资源管理器里是展开的,在这儿你可以做很多操作:

  • 创建,删除,重命名文件和文件夹
  • 用拖拽移动文件和文件夹
  • 通过右击菜单浏览所有选项

提示:你可以拖拽VS code外部文件到资源管理器里来复制它们

image

VS Code与其他工具非常和谐,特别是命令行工具,如果你想用在VS Code被打开的文件夹上下文运行一个命令行工具,右键点击文件夹并选择 Open in Command (mac和Linux:Open in Termainal)。

image

你也可以右击一个文件或文件夹并选择·Reveal in Explorer·(mac:Reaveal in Finder ,Linux: Open Containing Folder )。

提示:用⌘P通过文件的名称可以快速的搜索和打开一个文件。

在默认的情况下,VS Code排除来自资源管理器的一些文件(比如:.git)。用files.exclude 来设置规则隐藏来自资源器的文件和文件夹。

提示:隐藏像Unity的 \*.meta ,Typescript项目里的 \*.js 的驱动原文件是非常有用的。在Typescript文件里,你可以修改 "**/*.js": {"when": "$(basename).ts"} 来排除生成的JavaScript。

打开编辑器

在资源管理器的顶部有标有 OPEN EDITORS 的部分,这是当前文件或预览列表。这些文件是你在工作中用VS Code打开过的。比如,按照下面操作,一个文件会被列到 OPEN EDITORS 中。

  • 对文件进行更改
  • 在资源管理器双击一个文件
  • 打开一个不属于当前文件夹的文件

配置编辑器

VS Code给你许多选项来配置编辑器。你可以通过 User Setting 配置全局,或者通过 Workspace Setting 配置每个项目或者文件夹。在 setting.json 中值是被生效的。

  • 选择 File > Preferences > User Settings (或者⇧⌘P跳出输入框,输入user,并且回车),打开User Setting.json
  • 选择 File > Preferences > Workspace Settings(或者⇧⌘P跳出输入框,输入worksp,并且回车),Workspace Setting.json

Mac用户注意:Preferences 菜单在 Code里,不是 File中,比如:Code > Preferences > User Settings

在窗口的左边你将看到VS Code的 Default Setting ,并且在窗口右边你可以编辑 Settings.json 。从 Default Setting 中你可以很容易的查看和复制配置。

编辑你的设置之后,用 ⌘S 保存你的配置,它们会立即生效。

保存/自动保存

默认情况下,VS Code需要用 ⌘S 保存重新设置的数据到磁盘里。

然而,VS Code能很容易开启自动保存,在你配置延迟后或者焦点离开编辑器后自动保存你的更改文件。自动保存一旦被开启,就不需要手动去保存文件。

打开 User Setting 或者 Workspace 配置自动保存,找到如下相关设置:

  • files.autoSave :设置值为off表示关闭自动保存,afterDelay 保存文件后延迟自动保存,onFocusChange 焦点移出编辑器后就会自动保存。
  • files.autoSaveDelayfiles.autoSave 的值是 afterDelay 时,就可以设置自动保存的延迟时间。

搜索文件

VS Code允许你在当前被打开的文件夹里快速搜索所有文件。使用 ⇧⌘F 并且输入你想搜索的内容。搜索结果被分组到包含的关键词的文件中,搜索结果中每个文件有包含关键词的数量以及文件位置。展开一个文件可以看到这个文件包含关键词列表。点击关键词就能在当前编辑器里查看它。

image

提示:在搜索框里只支持正则表达式

你可以通过 ⇧⌘J 配置高级搜索选项。这将显示附加字段配置搜索

image

在搜索框下面有两个输入框,你可以包含和排除文件。点击输入框的右边切换glob模式:

  • * 匹配路径段里面0或多个除 / 以外的字符
  • ? 匹配路径段里面一个除 / 以外的字符
  • ** 匹配路径段的多个字符,包括 /
  • {} 用组的形式(列如: {**/*.html,**/*.txt} 匹配所有的HTML和文本文件)
  • [] 匹配指定的字符范围

VS Code可以在默认情况下排除一些你不感兴趣的文件夹(例如:node_modules )来减少搜索结果的数量。可以通过设置改变 files.excludesearch.exclude 标题下面的规则。

提示:在资源管理器里右击一个文件夹并且选择 Find in Floder 就可以在这个文件夹内任意搜索

你也可以搜索并替换文件。展开搜索框出现替换文本框(Mac:Cmd + shift )。

image

当你键入文本到替换框中时,你可以看到即将更改的差异性显示。你可以通过文件替换框替换所有文件,也可以替换一个文件里所有或者替换一个单一变化,

image

命令面板|

VS Code同样可以用键盘操作。最重要的键盘组合 ⇧⌘P ,这将调出命令面板。从这里,你可以访问VS Code所有的功能,包含快捷键最常见的操作。

image

命令面板提供了许多命令。你可以执行编辑命令,打开文件,搜索符号,查看一个文件的简要概要,使用同一个交互的窗口。

  • ⌘P 只需简单的输入它的名字就让你导航到所有文件或者符号
  • ⌃⇧Tab 显示你最后打开的一组文件路径
  • ⇧⌘P 调出命令面板
  • ⇧⌘O 在一个文件里,跳到一个指定符号的位置
  • ⌃G 在一个文件里,输入行数直接跳到指定行的位置

输入 ? 到输入框得到可用的命令列表,你可以从这里执行:

image

文件切换

当你打开一个项目的时候,资源管理器擅长文件之间的切换。然而,当你处理任务时,你将发现你自己在一组文件之间快速切换。VS Code提供两个功能强大命令通过易用的键组合来浏览不同文件。

按住 Ctrl 然后按 Tab 键来查看编辑组中打开的所有文件的列表。如果要打开其中一个文件,再次使用 Tab 键选择你想浏览的文件,然后松开 ctrl 去打开它。

image

另外,你能使用 ⌃-⌃⇧- 在文件和编辑位置之间进行导航。如果你在同一个文件不同行之间跳来跳去。这些快捷键可以让你轻松地在这些位置之间进行导航。

提示:当你使用 ⌘P 时,你可以通过他们的名字打开任何文件

文件编码

User SettingWorkspace 中通过编辑 files.encoding 设置全局或每个工作区域的文件编码。

image

你可以在状态栏中查看到文件编码格式

image

点击在状态栏中的编码按钮,用不同的编码格式来重新打开或者保存当前文件。

image

然后选择一个编码格式

image

命令行启动

你可以通过命令行来启动VS Code来快速打开一个文件,文件夹,或者项目。通常情况,在一个文件范围内打开VS Code.我们发现最好的方法是在终端键入:

code .

提示:对于Mac用户,我们需要通过设置使您能够从终端内启动VS Code.首选运行VS code并打开命令面板( ⇧⌘P ),然后输入 shell command 找到: Install ‘code' command in PATH 。

image

Windows和Lunix用户安装过程自动把VS Code的执行代码加到 PATH 环境变量中。

有时你想打开或者创建一个文件。如果指定文件不存在,VS Code将会为你创建此文件。

code index.html style.css readme.md

提示:你可以通过空格键来分隔许多文件名

额外的命令行参数

当通过 code 的命令行启动VS Code时你可以使用以下可选的命令行参数:

参数 描述
-h--help code使用说明
-v--version VS Code版本(例如:0.10.10)
-n--new-window 打开一个VS Code新的版本替代默认版本
-r--reuse-window 强制打开最后活动窗口的文件或文件夹
-g--goto 当和 file:line:column?使用时 ,打开文件并定位到一个的特定行和可选的列位置的文件。
file 以一个文件名打开。如果文件不存在,此文件将被创建并标记为已编辑
file:line:column? 以文件的名称在指定行和可选的列的位置打开,你可以以这个方式指定多个文件。但是在使用 file:line:column? 之前必须使用 -g 参数。例如:code -g file:10
folder 以一个文件夹名打开。你可以指定多个文件夹。例如:code folder folder
-d--diff 打开一个不同的编辑器。需要两个文件路径作为参数。例如:code -d file file
--locale 为VS Code设置显示语言,支持语言环境有:en-US (英语) ,zh-TW (中文繁体),zh-CN (中文简体),frdeitjakorues 。例如: code . --locale=en-US 设置显示语言为英语
--disable-extensions 禁用所有安装的插件。下拉选 Show installed Extensions 后插件依然可见,但是永远不会被激活。
--list-extensions code --list-extensions 列出被安装的插件
--install-extension 安装一个插件。提供完整的扩展名 publisher.extension 作为参数。例如:code --install-extension ms-vscode.cpptools
--uninstall-extension 卸载一个插件。提供完整的扩展名 publisher.extension 作为参数.例如 code --uninstall-extension ms-vscode.csharp
-w--wait 等待窗口返回之前关闭

打开一个项目

VS Code不区分你打开是文件夹还是项目。如果VS Code在文件夹检测到你打开一个项目(例如:一个 C# 项目),这个项目的上下文将被显示在状态栏。如果有多个项目被发现,可以从这里切换项目。
在一个文件夹 C:\src\WebApp 里打开一个项目,像这里启动VS Code:

code C:\src\WebApp

VS Code 打开之后,只需打开源文件并且使用状态栏根据需要来切换活动项目

image

窗口管理

VS Code有一些选项来控制窗口应该被新建还是恢复上一次窗口。

User settingWorkspace setting 中:
window.openFilesInNewWindow : 设置文件是否在一个新窗口打开,而不是在重用现有的VS Code实例。默认是 true, VS Code打开一个新的窗口。false 重用VS code最后一个活动实例并在此打开文件。

window.reopenFolders 设置通知VS Code怎么去恢复以前会话窗口。默认是 one ,VS Code将重新打开你处理过最后一个文件夹。改变设置为 none 不重新打开任何文件夹并始终以一个空文件打开。设置为 all 恢复上次会话处理过的所有文件夹

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,793评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,567评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,342评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,825评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,814评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,680评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,033评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,687评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,175评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,668评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,775评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,419评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,020评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,206评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,092评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,510评论 2 343

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,596评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,454评论 25 707
  • error code(错误代码)=0是操作成功完成。error code(错误代码)=1是功能错误。error c...
    Heikki_阅读 3,355评论 1 9
  • 上一篇文章我介绍VS Code 的简单配置,这篇来点认真的。作为一个编辑器,我们当然是要拿来写代码了,VS Cod...
    天堂迈舞阅读 22,524评论 8 19
  • 题记:不要放弃自己进步的机会 背景 公司刚接了一个大项目(现在整理文章的时候,真是感慨啊),其中涉及低功耗蓝牙BL...
    王诛魔Phy阅读 1,447评论 1 11