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"
  }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

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