zoukankan      html  css  js  c++  java
  • Atom中设置你的Snippet,atom技巧(二)

    一个使用Snippet加速编码的动图示例

    我们经常需要对二维数组进行迭代,比如这样:

    for(int x = 0; x < width; x++){
      for(int y = 0; y < height; y++){
        screen[x][y].setColor("black");
      }
    }

    过上一段时间,你又要写这么一段代码:

    for(int i = 0; i < rows; i++){
      for(int j = 0; j< columns; j++){
        objects[i][j].update();
      }
    }

    如果你是程序员,那么你理应厌烦:又一次重复得输入for,[],{}……而且一个不小心,还很容易输入错误。浪费时间寻找哪里少了一个分号可不是你该做的事情。

    那么不如来试试Snippet,一小段预先定义好格式的代码块。下次使用时,只需填入变化的部分。是的,就像填表一样。

    在Atom中设置你的Snippet

    为了在Atom中使用Snippet,你需要首先定义好你的代码块格式。

    Linux环境下,进入Edit->Snippets...,相对应的,在Windows下是File->Snippets...。

    这实际上是一个cson文件,格式如下:

    '.source.python':                         # 在何种文件中使用这个Snippet
      'python coding':                        # 对Snippet的简短说明
        'prefix': 'coding'                    # 输入什么前缀可以触发这个Snippet
        'body': '# -*- coding:utf8 -*-
    '     # Snippet的内容

    第一行指定在何种文件中使用Snippet,你可以在设置的Packages中的Installed Package里搜索你要用的编程语言。
    点击对应的包,通常名字是:language-编程语言。在打开的包里看看Scope是什么。
    常用的几种如下:

    文件后缀Scope
    .c .h .source.c
    .py .source.python
    .java .source.java
    .js .source.js
    .css .source.css
    .md .source.gfm

    第一个示例:指定Python文件的编码

    我们都知道,如果你在python2中使用中文,在Python文件开头,你需要添加这么一段代码,指定这个文件的编码格式:

    # -*- coding:utf8 -*-

    每次都要输入,重复!那就把它变成一段Snippet吧:

    '.source.python':
      'python coding':
        'prefix': 'coding'
        'body': '# -*- coding:utf8 -*-
    '

    这样,在打开.py文件后,只需输入coding,然后按下Tab键,这段遍布着*的代码行就一下子输入成功了。

    第二个示例:划分你的代码

    还是在Python中,如果你想要添加一段像下面这样的代码,将你的.py文件划分成多块的话:

    #=====================
    # 数据爬取结束,开始匹配
    #=====================

    这时候,中间的文字是你每次都需要更改的部分,当然可以在输入其他部分后再移到中间部分进行编辑,但我们有更好的东西:

    '.source.python':
      'python coding':
        'prefix': 'coding'
        'body': '# -*- coding:utf8 -*-
    '
      'section':
        'prefix': 'section'
        'body': '#=====================
    # $1
    #=====================
    $2'

    注意,对同一后缀文件的Snippet,都得写在一起。

    $1表示光标第一次所处的位置,按一下Tab后光标会移到$2所处的位置。

    在这个例子中,输入section然后按Tab,光标就自动出现在这段代码的中间,输入完中间部分,再按Tab,光标就会移动到这段文字的最后。你可以继续编码,而无需浪费时间在移动光标上。

    第三个示例:同时编辑多处

    在上面,我们使用 划分多行,但是行数一多,这样看起来就眼花缭乱了,我们可以使用"""来编写多行的Snippet:

    '.source.java':
      'iterate two dimension array':
        'prefix' : 'for2'
        'body' : """
          for(int $1 = 0; $1 < $2; $1++){
            for(int $3 = 0; $3 < $4; $3++){
              $5[$1][$3]$6
            }
          }
          $7
        """

    Atom的一个优势就是可以同时修改文件的不同位置,Snippet自然支持这一点。
    你会注意到,$1出现三次,这意味着一次键入,三处输入。这样不但快捷,还能保证命名一致。(错也会错成一样的)。

    要注意的

      • Snippet很方便,但只有你用起来的时候才能加速你的编码。要记得使用,直到肌肉有了记忆,自然而然地使用Snippet。
      • Snippet的介绍似乎不是很重要,但安装了其他人的Snippet后,你需要这些介绍来进行区分,所以还是要认真编写的。
      • 保持开心,如果Snippet用起来感觉不是爽而是痛苦,那就不要使用它。也许你会发现,这些重复的编码可以用其他的东西来解决,比如map函数。
  • 相关阅读:
    VMware安装虚拟机(Ubuntu)
    鼠标拖拽事件
    css层叠样式表
    html--form表单常用操作
    python学习之HTML-table标签
    python之web前端day01
    字符串各种操作,关于字符串的内置函数
    正则中匹配次数的问题
    re模块
    Github网站打不开的问题
  • 原文地址:https://www.cnblogs.com/RuMengkai/p/6554760.html
Copyright © 2011-2022 走看看