VS Code 自定义快捷输入

Emmet

位置

  • ctrl + shift + p
  • 搜索: snippets
  • 输入类型: 比如 htmljavascript

目录

Windows: C:\Users\userName\AppData\Roaming\Code\User\snippets

参数说明

  • prefix:使用代码段的快捷入口
  • body:需要设置的代码放在这里,字符串间换行的话使用\r\n换行符隔开.如果值里包含特殊字符需要进行转义,多行代码以","分隔(在引号后面写逗号)
  • $0:定义最终光标位置
  • $1:定义第一次光标位置,按tab键可进行快速切换, 还可以有 $2, $3, $4, $5 ...
  • description:代码段描述,在使用智能感知时的描述

常用字符说明

  • \\ 反斜杠
  • \a 警告
  • \b 退格符
  • \f 换页符
  • \n 换行符
  • \r 回车符
  • \t Tab 符
  • \v 垂直 Tab 符
  • \u 使用数字指定的Unicode 字符, 如 \u2000
  • \x 使用十六进制数指定的Unicode 字符, 如 \xc8
  • \0 空值

JavaScript

  • javascript.json
{
    // 自定义
    "箭头函数": {
        "prefix": "jt",
        "body": [
            "($1) => {\r\n\t$2\r\n}"
        ],
        "description": "() => {}"
    },
    "function": {
        "prefix": "fn",
        "body": [
            "function $1($2) {\r\n\t$3\r\n}"
        ],
        "description": "function () {}"
    },
    "console.log": {
        "prefix": "co",
        "body": [
            "console.log($1);"
        ],
        "description": "console.log()"
    },
    "alert": {
        "prefix": "al",
        "body": [
            "alert($1);"
        ],
        "description": "alert()"
    },
    "on": {
        "prefix": "on",
        "body": [
            "on('click',function () {\r\n\t$1\r\n})"
        ],
        "description": "on"
    },
    "for": {
        "prefix": "fo",
        "body": [
            "for (let i = 0; i < $1; i++) {\r\n\t$2\r\n}"
        ],
        "description": "for"
    },
    "if": {
        "prefix": "if",
        "body": [
            "if ($1) {\r\n\t$2\r\n}"
        ],
        "description": "if"
    },
    "if-else": {
        "prefix": "ifel",
        "body": [
            "if ($1) {\r\n\t$2\r\n} else {\r\n\t$3\r\n}"
        ],
        "description": "if-else"
    },
    "ajax": {
        "prefix": "aj",
        "body": [
            // "$.ajax({\r\n\turl:$1,\r\n\tdata:{\r\n\t\t$2\r\n\t},\r\n\ttype:'post',\r\n\tdataType:'JSON',\r\n\tsuccess:function (res) {\r\n\t\t$3\r\n\t}\r\n})"
            "$.ajax({",
            "    url: '$1',",
            "    data:{",
            "        $2",
            "    },",
            "    type: 'post',",
            "    dataType: 'JSON',",
            "    success:function(res) {",
            "        $3",
            "    }",
            "});"
        ],
        "description": "ajax"
    },
    "axios": {
        "prefix": "ax",
        "body": [
            "axios.$1(`$2`, {",
            "    $3",
            "}).then(res => {",
            "    console.log(res);",
            "}).catch(err => {",
            "    console.log(err);",
            "});",
        ],
        "description": "axios"
    }
}

vue

注: 组件/实例的书写顺序参照 Vue 风格指南

  • vue.json
{
  // 自定义
  "vue": {
    "prefix": "vue",
    "body": [
      "",
      "<template>",
      "  <div class=\"$1\">",
      "    New page",
      "  </div>",
      "</template>",
      "",
      "<script>",
      "export default {",
      "  name: '$2',",
      "  components: {},",
      "  props: {},",
      "  data() {",
      "    return {};",
      "  },",
      "  computed: {},",
      "  watch: {},",
      "  created() {},",
      "  mounted() {},",
      "  beforeDestroy() {},",
      "  methods: {}",
      "};",
      "</script>",
      "",
      "<style lang=\"scss\" scoped></style>",
      ""
    ],
    "description": "Vue templet"
  },
    "vue3-setup": {
        "prefix": "vue3-setup",
        "body": [
            "",
            "<template>",
            "  <div class=\"$1\">",
            "    New page",
            "  </div>",
            "</template>",
            "",
            "<script setup lang=\"ts\"></script>",
            "",
            "<style lang=\"scss\" scoped></style>",
            ""
        ],
        "description": "Vue3 templet"
    },
    "vue3": {
        "prefix": "vue3",
        "body": [
            "",
            "<template>",
            "  <div class=\"$1\">",
            "    New page",
            "  </div>",
            "</template>",
            "",
            "<script lang=\"ts\">",
            "export default {",
            "  name: '$2',",
            "  components: {},",
            "  props: {},",
            "  setup() {},",
            "  data() {",
            "    return {};",
            "  },",
            "  computed: {},",
            "  watch: {},",
            "  created() {},",
            "  mounted() {},",
            "  beforeUnmount() {},",
            "  methods: {}",
            "};",
            "</script>",
            "",
            "<style lang=\"scss\" scoped></style>",
            ""
        ],
        "description": "Vue3 templet"
    },
  "uni": {
    "prefix": "uni-app-page",
    "body": [
      "",
      "<template>",
      "  <view class=\"$1\">",
      "    New page",
      "  </view>",
      "</template>",
      "",
      "<script>",
      "export default {",
      "  name: '$2',",
      "  components: {},",
      "  props: {},",
      "  data() {",
      "    return {};",
      "  },",
      "  computed: {},",
      "  watch: {},",
      "  onLoad() {},",
      "  onShow() {},",
      "  onReady() {},",
      "  onHide() {},",
      "  onUnload() {},",
      "  methods: {}",
      "};",
      "</script>",
      "",
      "<style scoped lang=\"scss\">",
      "</style>",
      ""
    ],
    "description": "uni-app-page templet"
  }
}

react

  • javascriptreact.json
{
  // 自定义
  "react": {
    "prefix": "react",
    "body": [
      "",
      "import React, { Component, Fragment } from 'react';",
      "import { withRouter } from 'react-router-dom';",
      "",
      "class $1 extends Component {",
      "  static defaultProps = {};",
      "",
      "  constructor(props) {",
      "    super(props);",
      "",
      "    this.state = {};",
      "  }",
      "",
      "  componentDidMount() {}",
      "",
      "  componentDidUpdate() {}",
      "",
      "  componentWillUnmount() {}",
      "",
      "  render() {",
      "    return (",
      "      <Fragment>$3</Fragment>",
      "    );",
      "  }",
      "}",
      "",
      "export default withRouter($2);",
      ""
    ],
    "description": "React templet"
  }
}
  • typescriptreact.json
{
  // 自定义
  "react": {
    "prefix": "react",
    "body": [
      "",
      "import React from 'react'",
      "import { RouteComponentProps, withRouter } from 'react-router-dom'",
      "",
      "interface Props extends RouteComponentProps {}",
      "",
      "class $1 extends React.Component<Props> {",
      "  /* 静态属性 */",
      "  static defaultProps = {}",
      "",
      "  /* 构造函数 */",
      "  constructor(props: Props) {",
      "    super(props)",
      "",
      "    this.state = {}",
      "  }",
      "",
      "  /* 生命周期 */",
      "  componentDidMount() {}",
      "",
      "  componentDidUpdate() {}",
      "",
      "  componentWillUnmount() {}",
      "",
      "  /* Events */",
      "",
      "  /* Methods */",
      "",
      "  render() {",
      "    return (",
      "      <>Hello World</>",
      "    );",
      "  }",
      "}",
      "",
      "export default withRouter($2);",
      ""
    ],
    "description": "React TypeScript"
  },
    // 自定义
  "箭头函数": {
    "prefix": "jt",
    "body": ["($1) => {\r\n\t$2\r\n}"],
    "description": "() => {}"
  },
  "function": {
    "prefix": "fn",
    "body": ["function $1($2) {\r\n\t$3\r\n}"],
    "description": "function () {}"
  },
  "console.log": {
    "prefix": "co",
    "body": ["console.log($1);"],
    "description": "console.log()"
  },
  "alert": {
    "prefix": "al",
    "body": ["alert($1);"],
    "description": "alert()"
  },
  "on": {
    "prefix": "on",
    "body": ["on('click',function () {\r\n\t$1\r\n})"],
    "description": "on"
  },
  "for": {
    "prefix": "fo",
    "body": ["for (let i = 0; i < $1; i++) {\r\n\t$2\r\n}"],
    "description": "for"
  },
  "if": {
    "prefix": "if",
    "body": ["if ($1) {\r\n\t$2\r\n}"],
    "description": "if"
  },
  "if-else": {
    "prefix": "ifel",
    "body": ["if ($1) {\r\n\t$2\r\n} else {\r\n\t$3\r\n}"],
    "description": "if-else"
  },
  "ajax": {
    "prefix": "aj",
    "body": [
      // "$.ajax({\r\n\turl:$1,\r\n\tdata:{\r\n\t\t$2\r\n\t},\r\n\ttype:'post',\r\n\tdataType:'JSON',\r\n\tsuccess:function (res) {\r\n\t\t$3\r\n\t}\r\n})"
      "$.ajax({",
      "    url: '$1',",
      "    data:{",
      "        $2",
      "    },",
      "    type: 'post',",
      "    dataType: 'JSON',",
      "    success:function(res) {",
      "        $3",
      "    }",
      "});"
    ],
    "description": "ajax"
  },
  "axios": {
    "prefix": "ax",
    "body": [
      "axios.$1(`$2`, {",
      "    $3",
      "}).then(res => {",
      "    console.log(res);",
      "}).catch(err => {",
      "    console.log(err);",
      "});"
    ],
    "description": "axios"
  }
}

wepy

  • 新建全局代码片段文件
{
  // 自定义
  "wepyPage": {
    "prefix": "wepy",
    "body": [
      "",
      "<template>",
      "  <view class=\"$1\">",
      "    New page",
      "  </view>",
      "</template>",
      "",
      "<script>",
      "import wepy from 'wepy';",
      "",
      "export default class $2 extends wepy.page {",
      "  config = {}",
      "",
      "  components = {}",
      "",
      "  mixins = []",
      "",
      "  data = {}",
      "",
      "  computed = {}",
      "",
      "  watch = {}",
      "",
      "  methods = {}",
      "",
      "  events = {}",
      "",
      "  /* 生命周期 */",
      "  onLoad() {",
      "    wx.setNavigationBarTitle({",
      "      title: '$3'",
      "    });",
      "  }",
      "",
      "  // onShow() {}",
      "",
      "  // onReady() {}",
      "",
      "  // onHide() {}",
      "",
      "  // onUnload() {}",
      "",
      "  /* 函数 */",
      "}",
      "</script>",
      "",
      "<style lang=\"less\" scoped></style>",
      ""
    ],
    "description": "WePY templet"
  },
  "wepyComponent": {
    "prefix": "wepyc",
    "body": [
      "",
      "<template>",
      "<view class=\"$1\">",
      "  New Component",
      "</view>",
      "</template>",
      "",
      "<script>",
      "import wepy from 'wepy';",
      "",
      "export default class $2 extends wepy.component {",
      "  config = {}",
      "",
      "  components = {}",
      "",
      "  watch = {}",
      "",
      "  props = {}",
      "",
      "  mixins = []",
      "",
      "  data = {}",
      "",
      "  computed = {}",
      "",
      "  methods = {}",
      "",
      "  events = {}",
      "",
      "  /* 生命周期 */",
      "  onLoad() {",
      "    wx.setNavigationBarTitle({",
      "      title: '$3'",
      "    });",
      "  }",
      "",
      "  /* 函数 */",
      "}",
      "</script>",
      "",
      "<style lang=\"less\" scoped></style>",
      ""
    ],
    "description": "WePY templet"
  },
  "image": {
    "prefix": "image",
    "body": [
      "<image src=\"{{'/$1' + '?x-oss-process=image/resize,w_750,limit_0'}}\" mode=\"aspectFill\"></image>"
    ],
    "description": "WePY templet"
  },
  "text": {
    "prefix": "text",
    "body": [
      "<text>$1</text>"
    ],
    "description": "WePY templet"
  }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,736评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,167评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,442评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,902评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,302评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,573评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,847评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,562评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,260评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,531评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,021评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,367评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,016评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,068评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,827评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,610评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,514评论 2 269

推荐阅读更多精彩内容

  • HTML 5 HTML5概述 因特网上的信息是以网页的形式展示给用户的,因此网页是网络信息传递的载体。网页文件是用...
    阿啊阿吖丁阅读 3,361评论 0 0
  • Download Visual Studio Code 简介 VSCode是微软推出的一款轻量编辑器,采取了和VS...
    jrg陈咪咪sunny阅读 2,796评论 0 3
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,099评论 18 139
  •   JavaScript 与 HTML 之间的交互是通过事件实现的。   事件,就是文档或浏览器窗口中发生的一些特...
    霜天晓阅读 3,426评论 1 11
  • 周末的时候垃圾点的垃圾总是比平时多。 周末大概是个适合清理垃圾的时间。 无论是生活垃圾,还是心理垃圾。 那些安静夜...
    凌雪懿阅读 273评论 0 1