vscode配置snippets四步

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vscode配置snippets四步相关的知识,希望对你有一定的参考价值。

参考技术A 第一步:ctrl+ship+p  //打开控制台命令

第二步:输入 snippets //过滤选择

第三步:选择要定义的文件类型 //此时很多,如Js,babel,css...

第四步:配置并定义

json 用于VSCode的Velocity Snippets。

{
  "Get Item By Id": {
    "prefix": "GetItem",
    "body": [
      "{",
      "    \"version\": \"2017-02-28\",",
      "    \"operation\": \"GetItem\",",
      "    \"key\": {",
      "        \"id\": \\$util.dynamodb.toDynamoDBJson(\\$ctx.args.id),",
      "    }",
      "}"
    ],
    "description": "Get Item By Id"
  },
  "List Items": {
    "prefix": "Scan",
    "body": [
      "{",
      "    \"version\" : \"2017-02-28\",",
      "    \"operation\" : \"Scan\",",
      "    ## Add 'limit' and 'nextToken' arguments to this field in your schema to implement pagination. **",
      "    ## \"limit\": \\$util.defaultIfNull(\\${ctx.args.limit}, 20),",
      "    ## \"nextToken\": \\$util.toJson(\\$util.defaultIfNullOrBlank(\\$ctx.args.nextToken, null))",
      "}"
    ],
    "description": "List Items"
  },
  "Put Item": {
    "prefix": "PutItem",
    "body": [
      "{",
      "    \"version\" : \"2017-02-28\",",
      "    \"operation\" : \"PutItem\",",
      "    \"key\" : {",
      "        ## If object \"id\" should come from GraphQL arguments, change to \\$util.dynamodb.toDynamoDBJson(\\$ctx.args.id)",
      "        \"id\": \\$util.dynamodb.toDynamoDBJson(\\$util.autoId()),",
      "    },",
      "    \"attributeValues\" : \\$util.dynamodb.toMapValuesJson(\\$ctx.args)",
      "}"
    ],
    "description": "Put Item"
  },
  "Put Item With S3": {
    "prefix": "PutItem+S3",
    "body": [
      "{",
      "    \"version\" : \"2017-02-28\",",
      "    \"operation\" : \"PutItem\",",
      "    \"key\" : {",
      "        \"id\" : { \"S\" : \"\\${util.autoId()}\" }",
      "    },",
      "    #set( \\$attribs = \\$util.dynamodb.toMapValues(\\$ctx.args) )",
      "    #if(\\$util.isNull(\\$ctx.args.file.version))",
      "        #set( \\$attribs.file = \\$util.dynamodb.toS3Object(\\$ctx.args.file.key, \\$ctx.args.file.bucket, \\$ctx.args.file.region))",
      "    #else",
      "        #set( \\$attribs.file = \\$util.dynamodb.toS3Object(\\$ctx.args.file.key, \\$ctx.args.file.bucket, \\$ctx.args.file.region, \\$ctx.args.file.version))",
      "    #end",
      "    \"attributeValues\" : \\$util.toJson(\\$attribs)",
      "}"
    ],
    "description": "Put Item With S3"
  },
  "Delete Item by ID": {
    "prefix": "DeleteItem",
    "body": [
      "{",
      "    \"version\" : \"2017-02-28\",",
      "    \"operation\" : \"DeleteItem\",",
      "    \"key\" : {",
      "        ## If your table's hash key is not named 'id', update it here. **",
      "        \"id\" : { \"S\" : \"\\${ctx.args.id}\" }",
      "        ## If your table has a sort key, add it as an item here. **",
      "    }",
      "}"
    ],
    "description": "Delete Item by ID"
  },
  "Simple Query": {
    "prefix": "Query",
    "body": [
      "{",
      "    \"version\" : \"2017-02-28\",",
      "    \"operation\" : \"Query\",",
      "    \"query\" : {",
      "        ## Provide a query expression. **",
      "        \"expression\": \"id = :id\",",
      "        \"expressionValues\" : {",
      "            \":id\" : \\$util.dynamodb.toDynamoDBJson(\\$ctx.args.id)",
      "        }",
      "    }",
      "}"
    ],
    "description": "Simple Query"
  },
  "Query with greater than expression": {
    "prefix": "Query with > expression",
    "body": [
      "{",
      "    \"version\" : \"2017-02-28\",",
      "    \"operation\" : \"Query\",",
      "    \"query\" : {",
      "        ## Provide a query expression. **",
      "        \"expression\": \"id = :id and createdAt > :createdAt\",",
      "        \"expressionValues\" : {",
      "            \":id\" : {",
      "                \"S\" : \"\\${ctx.args.id}\"",
      "            },",
      "            \":createdAt\": {",
      "                \"S\": \"\\${ctx.args.createdAt}\"",
      "            }",
      "        }",
      "    }",
      "}"
    ],
    "description": "Simple Query with greater than expression"
  },
  "Query with filter on index expression": {
    "prefix": "Query with filter expression",
    "body": [
      "{",
      "    \"version\" : \"2017-02-28\",",
      "    \"operation\" : \"Query\",",
      "    \"index\" : \"name-index\",",
      "    \"query\" : {",
      "        \"expression\": \"#name = :name\",",
      "        \"expressionNames\" : {",
      "        \"#name\" : \"name\"",
      "    },",
      "        \"expressionValues\" : {",
      "            \":name\" : {",
      "                \"S\" : \\$util.dynamodb.toDynamoDBJson(\\$ctx.args.name)",
      "            }",
      "        }",
      "    },",
      "    \"filter\" : {",
      "        \"expression\" : \"contains(#city, :city)\",",
      "        \"expressionNames\" : {",
      "            \"#city\" : \"city\"",
      "        },",
      "        \"expressionValues\" : {",
      "            \":city\" : \\$util.dynamodb.toDynamoDBJson(\\$ctx.args.city)",
      "        }",
      "    }",
      "}"
    ],
    "description": "Query with filter on index expression"
  },
  "Query with contains expression": {
    "prefix": "Query with contains expression",
    "body": [
      "{",
      "    \"version\" : \"2017-02-28\",",
      "    \"operation\" : \"Query\",",
      "    \"query\" : {",
      "        ## Provide a query expression. **",
      "        \"expression\": \"id = :id\",",
      "        \"expressionValues\" : {",
      "            \":id\" : {",
      "                \"S\" : \"\\${ctx.args.id}\"",
      "            }",
      "        }",
      "    },",
      "    \"filter\": {",
      "        \"expression\": \"contains(tags, :tag)\",",
      "        \"expressionValues\" : {",
      "            \":tag\": {",
      "                \"S\": \"\\${ctx.args.tag}\"",
      "            }",
      "        }",
      "    }",
      "}"
    ],
    "description": "Query with contains expression"
  },
  "Query items created today": {
    "prefix": "Query items created today|date",
    "body": [
      "#set( \\$todayString = \\$util.time.nowISO8601().substring(0, 10) )",
      "{",
      "    \"version\" : \"2017-02-28\",",
      "    \"operation\" : \"Query\",",
      "    \"query\" : {",
      "        ## Provide a query expression. **",
      "        \"expression\": \"id = :id and begins_with(createdAt, :today)\",",
      "        \"expressionValues\" : {",
      "            \":id\" : {",
      "                \"S\" : \"\\${ctx.args.id}\"",
      "            },",
      "            \":today\": {",
      "                \"S\": \"\\$todayString\"",
      "            }",
      "        }",
      "    }",
      "}"
    ],
    "description": "Query items created today"
  },
  "Simple Query with pagination": {
    "prefix": "Query with pagination",
    "body": [
      "{",
      "    \"version\" : \"2017-02-28\",",
      "    \"operation\" : \"Query\",",
      "    \"query\" : {",
      "        ## Provide a query expression. **",
      "        \"expression\": \"id = :id\",",
      "        \"expressionValues\" : {",
      "            \":id\" : {",
      "                \"S\" : \"\\${ctx.args.id}\"",
      "            }",
      "        }",
      "    },",
      "    ## Add 'limit' and 'nextToken' arguments to this field in your schema to implement pagination. **",
      "    \"limit\": \\$util.defaultIfNull(\\${ctx.args.limit}, 20),",
      "    \"nextToken\": \\$util.toJson(\\$util.defaultIfNullOrBlank(\\$ctx.args.nextToken, null))",
      "}"
    ],
    "description": "Simple Query with pagination"
  },
  "Batch Get Items": {
    "prefix": "BatchGetItems",
    "body": [
      "#set(\\$ids = [])",
      "#foreach(\\$id in \\${ctx.args.ids})",
      "    #set(\\$map = {})",
      "    \\$util.qr(\\$map.put(\"id\", \\$util.dynamodb.toString(\\$id)))",
      "    \\$util.qr(\\$ids.add(\\$map))",
      "#end",
      "",
      "{",
      "    \"version\" : \"2018-05-29\",",
      "    \"operation\" : \"BatchGetItem\",",
      "    \"tables\" : {",
      "        ## Note: \\${sampleTableName} was defined in substitutions field.",
      "        \"\\${sampleTableName}\": {",
      "            \"keys\": \\$util.toJson(\\$ids),",
      "            \"consistentRead\": true",
      "        }",
      "    }",
      "}"
    ],
    "description": "Batch Get Items"
  },
  "Batch Put Items": {
    "prefix": "BatchPutItems",
    "body": [
      "#set(\\$postsdata = [])",
      "#foreach(\\$item in \\${ctx.args.posts})",
      "    \\$util.qr(\\$postsdata.add(\\$util.dynamodb.toMapValues(\\$item)))",
      "#end",
      "",
      " ## Note: \\${sampleTableName} was defined in substitutions field.",
      "{",
      "    \"version\" : \"2018-05-29\",",
      "    \"operation\" : \"BatchPutItem\",",
      "    \"tables\" : {",
      "        \"\\${sampleTableName}\": \\$utils.toJson(\\$postsdata)",
      "    }",
      "}"
    ],
    "description": "Batch Put Items"
  },
  "Batch Delete Items": {
    "prefix": "BatchDeleteItems",
    "body": [
      "#set(\\$ids = [])",
      "#foreach(\\$id in \\${ctx.args.ids})",
      "    #set(\\$map = {})",
      "    \\$util.qr(\\$map.put(\"id\", \\$util.dynamodb.toString(\\$id)))",
      "    \\$util.qr(\\$ids.add(\\$map))",
      "#end",
      "",
      "## Note: \\${sampleTableName} was defined in substitutions field.",
      "{",
      "    \"version\" : \"2018-05-29\",",
      "    \"operation\" : \"BatchDeleteItem\",",
      "    \"tables\" : {",
      "        \"\\${sampleTableName}\": \\$util.toJson(\\$ids)",
      "    }",
      "}"
    ],
    "description": "Batch Delete Items"
  },
  "Cognito group access": {
    "prefix": "Cognito Group Access Authorization",
    "body": [
      "#set(\\$expression = \"\")",
      "#set(\\$expressionValues = {})",
      "#foreach(\\$group in \\$ctx.identity.claims.get(\"cognito:groups\"))",
      "    #set( \\$expression = \"\\${expression} contains(groupsCanAccess, :var\\$foreach.count )\" )",
      "    #set( \\$val = {})",
      "    #set( \\$test = \\$val.put(\"S\", \\$group))",
      "    #set( \\$values = \\$expressionValues.put(\":var\\$foreach.count\", \\$val))",
      "    #if ( \\$foreach.hasNext )",
      "    #set( \\$expression = \"\\${expression} OR\" )",
      "    #end",
      "#end",
      "{",
      "    \"version\" : \"2017-02-28\",",
      "    \"operation\" : \"Scan\",",
      "    \"filter\":{",
      "        \"expression\": \"\\$expression\",",
      "        \"expressionValues\": \\$utils.toJson(\\$expressionValues)",
      "    }",
      "}"
    ],
    "description": "Cognito group access"
  },
  "Put Item with cognito identity": {
    "prefix": "PutItem with Owner Identity",
    "body": [
      "#set( \\$attributes = \\$util.dynamodb.toMapValues(\\$ctx.args) )",
      "\\$util.qr(\\$attributes.put(\"$Identity\", \\$ctx.identity.cognitoIdentityId))",
      "{",
      "    \"version\" : \"2017-02-28\",",
      "    \"operation\" : \"PutItem\",",
      "    \"key\" : {",
      "        \"id\" : { \"S\" : \"\\${context.args.id}\" }",
      "    },",
      "    \"attributeValues\": \\$util.toJson(\\$attributes)",
      "}"
    ],
    "description": "Put Item with cognito identity"
  },
  "Delete Item with cognito identity": {
    "prefix": "DeleteItem with Owner Identity",
    "body": [
      "{",
      "    \"version\" : \"2017-02-28\",",
      "    \"operation\" : \"DeleteItem\",",
      "    \"key\" : {",
      "        \"id\" : { \"S\" : \"\\${context.args.id}\" }",
      "    },",
      "    \"condition\" : {",
      "        \"expression\"       : \"contains($Owner,:expectedOwner)\",",
      "        \"expressionValues\" : {",
      "            \":expectedOwner\" : { \"S\" : \"\\${context.identity.username}\" }",
      "        }",
      "    }",
      "}"
    ],
    "description": "Delete Item with cognito identity"
  },
  "Put Item offline enabled": {
    "prefix": "PutItem Offline",
    "body": [
      "{",
      "    \"version\" : \"2017-02-28\",",
      "    \"operation\" : \"PutItem\",",
      "    \"key\": {",
      "        \"id\": { \"S\" : \"\\$utils.autoId()\"}",
      "    },",
      "    #set( \\$attribs = \\$util.dynamodb.toMapValues(\\$ctx.args) )",
      "    \\$util.qr(\\$attribs.remove(\"relayState\"))",
      "    #set( \\$attribs.version = { \"N\" : 1 } )",
      "    \"attributeValues\" : \\$util.toJson(\\$attribs)",
      "}"
    ],
    "description": "Put Item offline enabled"
  },
  "Conditional Update with version": {
    "prefix": "UpdateItem with version",
    "body": [
      "{",
      "    \"version\" : \"2017-02-28\",",
      "    \"operation\" : \"UpdateItem\",",
      "    \"key\" : {",
      "        \"id\" : \\$util.dynamodb.toDynamoDBJson(\\$ctx.args.id)",
      "    },",
      "",
      "    ## Set up some space to keep track of things we're updating **",
      "    #set( \\$expNames  = {} )",
      "    #set( \\$expValues = {} )",
      "    #set( \\$expSet = {} )",
      "    #set( \\$expAdd = {} )",
      "    #set( \\$expRemove = [] )",
      "",
      "    ## Increment \"version\" by 1 **",
      "    \\$!{expAdd.put(\"version\", \":one\")}",
      "    \\$!{expValues.put(\":one\", \\$util.dynamodb.toDynamoDB(1))}",
      "",
      "    ## Iterate through each argument, skipping \"id\" and \"expectedVersion\" **",
      "    #foreach( \\$entry in \\$util.map.copyAndRemoveAllKeys(\\$ctx.args, [\"id\",\"expectedVersion\"]).entrySet() )",
      "        #if( \\$util.isNull(\\$entry.value) )",
      "            ## If the argument is set to \"null\", then remove that attribute from the item in DynamoDB **",
      "",
      "            #set( \\$discard = \\${expRemove.add(\"#\\${entry.key}\")} )",
      "            \\$!{expNames.put(\"#\\${entry.key}\", \"\\${entry.key}\")}",
      "        #else",
      "            ## Otherwise set (or update) the attribute on the item in DynamoDB **",
      "",
      "            \\$!{expSet.put(\"#\\${entry.key}\", \":\\${entry.key}\")}",
      "            \\$!{expNames.put(\"#\\${entry.key}\", \"\\${entry.key}\")}",
      "            \\$!{expValues.put(\":\\${entry.key}\", \\$util.dynamodb.toDynamoDB(\\$entry.value))}",
      "        #end",
      "    #end",
      "",
      "    ## Start building the update expression, starting with attributes we're going to SET **",
      "    #set( \\$expression = \"\" )",
      "    #if( !\\${expSet.isEmpty()} )",
      "        #set( \\$expression = \"SET\" )",
      "        #foreach( \\$entry in \\$expSet.entrySet() )",
      "            #set( \\$expression = \"\\${expression} \\${entry.key} = \\${entry.value}\" )",
      "            #if ( \\$foreach.hasNext )",
      "                #set( \\$expression = \"\\${expression},\" )",
      "            #end",
      "        #end",
      "    #end",
      "",
      "    ## Continue building the update expression, adding attributes we're going to ADD **",
      "    #if( !\\${expAdd.isEmpty()} )",
      "        #set( \\$expression = \"\\${expression} ADD\" )",
      "        #foreach( \\$entry in \\$expAdd.entrySet() )",
      "            #set( \\$expression = \"\\${expression} \\${entry.key} \\${entry.value}\" )",
      "            #if ( \\$foreach.hasNext )",
      "                #set( \\$expression = \"\\${expression},\" )",
      "            #end",
      "        #end",
      "    #end",
      "",
      "    ## Continue building the update expression, adding attributes we're going to REMOVE **",
      "    #if( !\\${expRemove.isEmpty()} )",
      "        #set( \\$expression = \"\\${expression} REMOVE\" )",
      "",
      "        #foreach( \\$entry in \\$expRemove )",
      "            #set( \\$expression = \"\\${expression} \\${entry}\" )",
      "            #if ( \\$foreach.hasNext )",
      "                #set( \\$expression = \"\\${expression},\" )",
      "            #end",
      "        #end",
      "    #end",
      "",
      "    ## Finally, write the update expression into the document, along with any expressionNames and expressionValues **",
      "    \"update\" : {",
      "        \"expression\" : \"\\${expression}\",",
      "        #if( !\\${expNames.isEmpty()} )",
      "            \"expressionNames\" : \\$utils.toJson(\\$expNames),",
      "        #end",
      "        #if( !\\${expValues.isEmpty()} )",
      "            \"expressionValues\" : \\$utils.toJson(\\$expValues),",
      "        #end",
      "    },",
      "",
      "    \"condition\" : {",
      "        \"expression\"       : \"version = :expectedVersion\",",
      "        \"expressionValues\" : {",
      "            \":expectedVersion\" : \\$util.dynamodb.toDynamoDBJson(\\$ctx.args.expectedVersion)",
      "        }",
      "    }",
      "}"
    ],
    "description": "Conditional Update with version"
  },
  "Return single item": {
    "prefix": "Return single item",
    "body": [
      "## Pass back the result from DynamoDB. **",
      "\\$util.toJson(\\$ctx.result)"
    ],
    "description": "return single item"
  },
  "Return a list of results": {
    "prefix": "Return list",
    "body": ["\\$util.toJson(\\$ctx.result.items)"],
    "description": "Return a list of results"
  },
  "Return paginated results": {
    "prefix": "Return paginated results",
    "body": [
      "{",
      "    \"items\": \\$util.toJson(\\$ctx.result.items),",
      "    \"nextToken\": \\$util.toJson(\\$util.defaultIfNullOrBlank(\\$context.result.nextToken, null))",
      "}"
    ],
    "description": "Return paginated results"
  },
  "Return batch response": {
    "prefix": "Return Batch Response",
    "body": [
      "## Batch results are available in $context.result.data as name of the table (TABLENAME below)",
      "## Read more: https://docs.aws.amazon.com/appsync/latest/devguide/tutorial-dynamodb-batch.html",
      "",
      "\\$util.toJson(\\$ctx.result.data.${1:TABLENAME})"
    ],
    "description": "Return batch response"
  },
  "Return batch response with error handling": {
    "prefix": "Return Batch Response + Error Handling",
    "body": [
      "## Batch results are available in \\$context.result.data as name of the table (TABLENAME below)",
      "## If there was an error with invocation there may be partial results in \\$ctx.error object",
      "## You can append an error for that field in GraphQL response along with successful data",
      "## Read more: https://docs.aws.amazon.com/appsync/latest/devguide/tutorial-dynamodb-batch.html",
      "",
      "#if(\\$ctx.error)",
      "    \\$utils.appendError(\\$ctx.error.message, \\$ctx.error.message)",
      "#end",
      "\\$utils.toJson(\\$ctx.result.data)"
    ],
    "description": "Return batch response with error handling"
  },
  "Return only my owned records": {
    "prefix": "Return Owner Records",
    "body": [
      "#set(\\$myResults = [])",
      "#foreach(\\$item in \\$ctx.result.items)",
      "    ## For Cognito User Pools use \\$ctx.identity.username instead",
      "    #if(\\$item.Owner == \\$ctx.identity.cognitoIdentityId)",
      "        #set(\\$added = \\$myResults.add(\\$item))",
      "    #end",
      "#end",
      "\\$utils.toJson(\\$myResults)"
    ],
    "description": "Return only own records"
  },
  "Return a single record if public": {
    "prefix": "Return Single Record If Public",
    "body": [
      "#if(\\$ctx.result.public == 'yes')",
      "    \\$utils.toJson(\\$ctx.result)",
      "#else",
      "    \\$utils.unauthorized()",
      "#end"
    ],
    "description": "Return a single record if public"
  },
  "Return record if viewable by my groups": {
    "prefix": "Return Record If Viewable By My Groups",
    "body": [
      "#set(\\$permissions = \\$ctx.result.GroupsCanAccess)",
      "#set(\\$claimPermissions = \\$ctx.identity.claims.get(\"cognito:groups\"))",
      "",
      "#foreach(\\$per in \\$permissions)",
      "    #foreach(\\$cgroups in \\$claimPermissions)",
      "        #if(\\$cgroups == \\$per)",
      "            #set(\\$hasPermission = true)",
      "        #end",
      "    #end",
      "#end",
      "",
      "#if(\\$hasPermission)",
      "    \\$utils.toJson(\\$ctx.result)",
      "#else",
      "    \\$utils.unauthorized()",
      "#end"
    ],
    "description": "Return record if viewable by my groups"
  },
  "Return a list of public records": {
    "prefix": "Return A List Of Public Records",
    "body": [
      "#set(\\$publicRecords = [])",
      "#foreach(\\$item in \\$ctx.result.items)",
      "    #if(\\$item.public == 'yes')",
      "        #set(\\$added = \\$publicRecords.add(\\$item))",
      "    #end",
      "#end",
      "\\$utils.toJson(\\$publicRecords)"
    ],
    "description": "Return a list of public records"
  },
  "Return Offline enabled response": {
    "prefix": "Return Offline Enabled Response",
    "body": [
      "\\$util.qr(\\$context.result.put(\"relayState\", \"\\$context.arguments.relayState\"))",
      "\\$util.toJson(\\$context.result)"
    ],
    "description": "Return Offline enabled response"
  }
}

以上是关于vscode配置snippets四步的主要内容,如果未能解决你的问题,请参考以下文章

vscode配置Markdown snippet 的快捷键

vscode 开发微信小程序环境配置

VSCode Snippet 小试牛刀

VSCODE snippets的使用

vscode:snippet基本使用方法

json 用于VSCode的Velocity Snippets。