開發工具、環境
data:image/s3,"s3://crabby-images/be61c/be61c4d1bd73761f3fc76dc44a1a0c4a9881dac3" alt=""
# Visual Studio Code
推薦設定、Plugin
data:image/s3,"s3://crabby-images/d9896/d989653b1faaccb4cfc952b178afc2795117e9f6" alt=""
# ESLint Rules
(with Airbnb)
# JSDoc
comment style
# DevTools tip
data:image/s3,"s3://crabby-images/be61c/be61c4d1bd73761f3fc76dc44a1a0c4a9881dac3" alt=""
# Visual Studio Code
Plugin
# TODO Highlight
data:image/s3,"s3://crabby-images/85f00/85f00c11d13d7f837cdec6016917090c6726ea9c" alt=""
data:image/s3,"s3://crabby-images/96f12/96f12358e1048ce329096fa2de34623882177ec3" alt=""
data:image/s3,"s3://crabby-images/85f00/85f00c11d13d7f837cdec6016917090c6726ea9c" alt=""
data:image/s3,"s3://crabby-images/5a4b9/5a4b9a4e239cc14a434a4545529008bddcc59f16" alt=""
# TODO Highlight
# TODO Tree
data:image/s3,"s3://crabby-images/c29a1/c29a17d5c8839b22585972592ae382f8ce6624a8" alt=""
data:image/s3,"s3://crabby-images/c4e12/c4e12a4f3152ada20f2222d74fff3dc7d5d36223" alt=""
# Code Spell Checker
data:image/s3,"s3://crabby-images/54fd7/54fd7bb0aadd17e704de9c07ca24b53a018de3aa" alt=""
data:image/s3,"s3://crabby-images/1484b/1484b81425a45ee11b5ea8090b79400419c282d7" alt=""
# Bookmarks
data:image/s3,"s3://crabby-images/30dc1/30dc1b11558d7189426c4041f83003bb987838b8" alt=""
data:image/s3,"s3://crabby-images/d1e61/d1e61536fcda398db79bafe121076d37404ea6c4" alt=""
# Bookmarks
data:image/s3,"s3://crabby-images/d1e61/d1e61536fcda398db79bafe121076d37404ea6c4" alt=""
data:image/s3,"s3://crabby-images/2b9bc/2b9bcce8a3e94b72880313e70511b64aff5012eb" alt=""
# Bracket Pair Colorizer
data:image/s3,"s3://crabby-images/aa440/aa4409ef59c856af94693fc8efacbecbd6d9036c" alt=""
data:image/s3,"s3://crabby-images/19b49/19b494ccc629d6251240aa47de26b3df3379e4a5" alt=""
# Eslint
data:image/s3,"s3://crabby-images/37c78/37c780d33bdea21dec7df465438784ce9253989e" alt=""
data:image/s3,"s3://crabby-images/1bfb4/1bfb478ec5cc7caa3a75ba33d5931c257f7ed778" alt=""
# Eslint
data:image/s3,"s3://crabby-images/37c78/37c780d33bdea21dec7df465438784ce9253989e" alt=""
// settings.json
{
"eslint.autoFixOnSave": true,
}
# Eslint
data:image/s3,"s3://crabby-images/37c78/37c780d33bdea21dec7df465438784ce9253989e" alt=""
data:image/s3,"s3://crabby-images/5f0cc/5f0cc75e8181d829f622a747d3c9d2420db292c3" alt=""
# Syncing
data:image/s3,"s3://crabby-images/b468a/b468ac43dce7c2682a751de10512da06deb2cc1d" alt=""
synchronize all of your VSCode settings across multiple devices with your GitHub Gist
data:image/s3,"s3://crabby-images/6ec4d/6ec4dc61ad315a123ef0e2693ce3c036bc045819" alt=""
也可以套用他人 Gist 上的設定檔
data:image/s3,"s3://crabby-images/be61c/be61c4d1bd73761f3fc76dc44a1a0c4a9881dac3" alt=""
# Visual Studio Code
Theme
# workbench color
// settings.json
{
// workbench IDE 本身的顏色相關
"workbench.colorCustomizations": {
// 背景
"editor.background": "#000",
// 左邊程式碼行號
"editorGutter.background": "#1c1c1c",
// 右邊 minimap 預覽
"editorOverviewRuler.errorForeground",
},
}
data:image/s3,"s3://crabby-images/ec4cd/ec4cd6d32dbfd80a481aa3b08a43d77d3154b5cc" alt=""
data:image/s3,"s3://crabby-images/1945a/1945ab17011a605d60c7135705da903346f3da5c" alt=""
# workbench color
data:image/s3,"s3://crabby-images/b1df7/b1df767d0656ea514e829b3834ab6fe26f0af645" alt=""
設定值都有 autocomplete
# tokenColorCustomizations
// settings.json
{
// syntax highlight
"workbench.colorCustomizations": {
// 註解
"comments": "#7fb785",
// 套用指定結構
"textMateRules": [
{
"scope": "storage.type.function",
"settings":{
"foreground": "#f00"
}
},
],
},
}
# tokenColorCustomizations
data:image/s3,"s3://crabby-images/2fc4a/2fc4a680dfe4bfd5a8314976788c1a9f128f97d3" alt=""
- Simple icons
- vscode-icons
- Kary Pro colors
- Color Highlight
- One Dark Pro
- High Contrast
data:image/s3,"s3://crabby-images/cb566/cb566cc4c4e04e044cde232d76c5a9d8404ed8f4" alt=""
data:image/s3,"s3://crabby-images/391d5/391d55425337134574943a005d647f81c01cd988" alt=""
data:image/s3,"s3://crabby-images/be61c/be61c4d1bd73761f3fc76dc44a1a0c4a9881dac3" alt=""
# Visual Studio Code
建議設定
{
// 關閉顯示已開啟的檔案
"explorer.openEditors.visible": 0,
"editor.minimap.enabled": true,
// 如果開啟 MiniMap 的話
// 預設會顯示實際字元 (字超小),根本看不清楚
// 將這個設定關閉,就會改顯示彩色區塊而已
// 這會讓 VSCode 反應速度更快
"editor.minimap.renderCharacters": false,
// 切 tab 時左邊的檔案會跳來跳去
"explorer.autoReveal": false,
}
data:image/s3,"s3://crabby-images/d9896/d989653b1faaccb4cfc952b178afc2795117e9f6" alt=""
# ESLint Rules
(with Airbnb)
# Install
npm i eslint-config-airbnb-base eslint-plugin-import eslint -D
# .eslintrc.js
module.exports = {
//lint 環境
'env': {
'browser': true,
'commonjs': true,
'es6': true,
'node': true
},
'extends': 'airbnb-base',
'parserOptions': {
'sourceType': 'module'
},
'rules': {
/*
'off' 或 0 - 关闭规则
'warn' 或 1 - 开启规则,使用警告级别的错误:warn
'error' 或 2 - 开启规则,使用错误级别的错误:error
*/
'indent': [2, 4, { 'SwitchCase': 1 }],
// 強制使用單引號
'quotes': [2, 'single'],
// airbnb 不允許使用 console ,這邊打開
'no-console': 0,
'class-methods-use-this': 0,
// allow underscore
'no-underscore-dangle': 0,
'no-plusplus': 0,
'strict': 0,
'max-len': [1, { "code": 140, "tabWidth": 4 }],
'camelcase': 1,
'no-unused-vars': 1,
'no-unused-expressions': [2, {
'allowShortCircuit': false,
'allowTernary': true
}],
'brace-style': [2, 'stroustrup'],
'import/no-unresolved': 0,
'import/extensions': [2, 'always'],
'no-param-reassign': 1,
},
// 告知 lint 有這些 global variable
'globals': {
'wz3': false,
'cc': false,
'Editor': false,
'jsb': false,
'CC_EDITOR': false,
'CC_PREVIEW': false,
'CC_DEV': false,
'CC_DEBUG': false,
'CC_BUILD': false,
'CC_JSB': false,
'CC_TEST': false,
}
};
建立 .eslintrc.js 在專案根目錄下
# linter 沒過
data:image/s3,"s3://crabby-images/faff9/faff958db411fd70c59fe2e8e13e40e1c27151db" alt=""
# JSDoc
comment style
/**
* @enum {number}
*/
const EnumTag = {
DOG: 1,
CAT: 2,
};
data:image/s3,"s3://crabby-images/7441f/7441fc9ec6ab5da28f3601e268bd551250b93c0a" alt=""
# enum
/**
* demo
*
* @param {number} number
* @param {string} string
* @param {{}} obj
* @param {[]} ary
*/
function demoFunc(number, string, obj, ary) {
}
# number, string, object, array
data:image/s3,"s3://crabby-images/e2036/e2036230da07fd7bf013e989d1e49abee1eaace8" alt=""
/**
* obj was {id1:123, id2: 456}
* @param {Object} obj
* @param {Object.<string, number>} idObj
*/
function objDemo(obj, idObj) {
}
# object
data:image/s3,"s3://crabby-images/a3a7e/a3a7ea0d1669b50ce3196470674dc29bd7b1d167" alt=""
/**
*
* @param {Array.<{
* name:string,
* age: number,
* detail:{city:string}}>} userData
*/
function complexAry(userData) {
}
# array
data:image/s3,"s3://crabby-images/95102/9510203c97eb72394fb72fff9c67f5e7e3936972" alt=""
/**
*
* @param {number} [code=1]
*/
function defaultVal(code = 1) {
}
# default value
data:image/s3,"s3://crabby-images/0dc5e/0dc5e856afe3ed67fe80f4c351aa073181554567" alt=""
/**
* @returns {{name:string, age: number}}
*/
function returnAnObj() {
}
# returns object (1/2)
data:image/s3,"s3://crabby-images/6045d/6045d72a481081f3bf23833b1718a273b15509e5" alt=""
/**
* @returns {number}
*/
function returnAValue() {
}
# returns object (2/2)
data:image/s3,"s3://crabby-images/57019/57019830ecfaaefdd9210c6e5791bf1f130af59f" alt=""
# jsPerf.com
JavaScript performance playground
# 事前準備
一個 github 帳號
# 你可以
- 寫性能測試
- 看別人的測試案例
- FORK 測試案例
- 瀏覽器速度收集數據
data:image/s3,"s3://crabby-images/289ba/289baf22afa38d0020cadd69b9cccba614d8f745" alt=""
# DEMO
# DevTools tips
chrome develop tools
# $_
返回最後一次執行運算的結果
data:image/s3,"s3://crabby-images/f3d7e/f3d7e85faa3dc2a08530d66ebd7401f7f4cb4d6c" alt=""
# copy
複製變數內容到剪貼簿
data:image/s3,"s3://crabby-images/c72f4/c72f4412d4d26c5581c29921ffa6431566ed68ae" alt=""
# console.table
data:image/s3,"s3://crabby-images/61c60/61c60817b76e0fea1a1417a65c7086e898605c58" alt=""
# debugger
data:image/s3,"s3://crabby-images/1013a/1013a5a346fc4e48d2476925818316d6d3ece860" alt=""
# edit break point
data:image/s3,"s3://crabby-images/a4cf6/a4cf6fd46c89008007217a894c14173055f54714" alt=""
# edit break point
data:image/s3,"s3://crabby-images/8b4b5/8b4b5e3d88cecfee5650734a4d1f50958195f67b" alt=""
# console.trace
data:image/s3,"s3://crabby-images/7e005/7e005503c8b34fcaad18ea71462262873411b8d1" alt=""
# console.time
data:image/s3,"s3://crabby-images/2315f/2315fdd20478815c213027ef8ea40dd7e0abe561" alt=""
# End
devenv
By mangogan
devenv
- 897