提升前端开发效率及查错能力的小技巧

前言

  作为一个快五年开发经验的前端工程师,在工作中感到最痛苦的除了无止境的改需求之外,就是调试bug阶段了,有时候开发一个网站也就两个星期左右,但调试起bug来一调就是几个小时!浪费时间不说,效率又低,作为程序员如果自己不懂得心疼自己(摸摸头顶...),那么没人会心疼你。

  

一、各种console

  下面的众多console输出中,如果不想都记,就记住关键的五个:console.log(); console.warn(); console.error(); console.time(); console.timeEnd();

// 判断第一个参数是否为真,false 的话抛出异常并且在控制台输出相应信息。
Console.assert();

// 清空控制台,并输出 Console was cleared。
Console.clear();

// 以参数为标识记录调用的次数,调用时在控制台打印标识以及调用次数。
Console.count();

// 重置指定标签的计数器值。
Console.countReset();

// 在控制台打印一条 "debug" 级别的消息。
Console.debug();

// 显示一个由特定的 Javascript 对象列表组成的可交互列表。这个列表可以使用三角形隐藏和显示来审查子对象的内容。.
Console.dir();

// 打印 XML/HTML 元素表示的指定对象,否则显示 JavaScript 对象视图。
Console.dirxml();

// 打印一条错误信息,使用方法可以参考 string substitution。
Console.error();

// 创建一个新的内联 group, 后续所有打印内容将会以子层级的形式展示。调用 groupEnd()来闭合组。
Console.group();

// 创建一个新的内联 group。使用方法和 group() 相同,不同的是,groupCollapsed() 方法打印出来的内容默认是折叠的。调用groupEnd()来闭合组。
Console.groupCollapsed();

// 闭合当前内联 group。
Console.groupEnd();

// 打印资讯类说明信息,使用方法可以参考 string substitution。
Console.info();

// 打印内容的通用方法,使用方法可以参考 string substitution。
Console.log();

// Starts the browser's built-in profiler (for example, the Firefox performance tool). You can specify an optional name for the profile.
Console.profile();

// Stops the profiler. You can see the resulting profile in the browser's performance tool (for example, the Firefox performance tool).
Console.profileEnd();

// 将列表型的数据打印成表格。
Console.table();

// 启动一个以入参作为特定名称的计时器,在显示页面中可同时运行的计时器上限为10,000.
Console.time();

// 结束特定的 计时器 并以豪秒打印其从开始到结束所用的时间。
Console.timeEnd();

// 打印特定 计时器 所运行的时间。
Console.timeLog();

// 添加一个标记到浏览器的 Timeline 或 Waterfall 工具。
Console.timeStamp() ;

// 输出一个 stack trace。
Console.trace();

// 打印一个警告信息,可以使用 string substitution 和额外的参数。
Console.warn();

 

二、debug

  会java的小伙伴们见到这个单词应该非常亲切,因为比起System.out.println();这么low的调试,善用debug才是王道;现在就介绍js中的:debugger;

function test() {
  console.log("debugger之前");
  debugger;
  console.log("debugger之后");
}

  注意:这个只有在浏览器中运行时才生效,程序运行到debugger就不会再执行下去,也就是浏览器会一直转圈圈,但控制台依旧能打印debugger之前的所有信息;

 

三、TODO

  同样是令java小伙伴们亲切的单词,起到标签记录位置的作用

  注意:1.这个是在我们某个逻辑还未写完,但是又不得不去更改别的地方或优先处理别的问题时使用;2.这个一般情况写在注释上,不会对程序造成影响,且能快速定位;

  准备工具:下载两个插件(TODO Highlight, Todo Tree)

  TODO Highlight是为了让TODO:这个字样为高亮提醒,就算放在注释内字体颜色也是高亮的,非常显眼;

  Todo Tree是为了起到类似超链接一样的效果,不管你的项目多大,被标记的地方都被统一管理,可以直接跳转;

提升前端开发效率及查错能力的小技巧_第1张图片

 

四、VScode常用快捷键&&快捷操作

  Ctrl+回车,直接跳到下一行;

  Ctrl+Shift+回车,直接在上一行; 

  选中字符,按Ctrl+k,直接全局选中并加光标; 

  shift+alt+↓是快速复制当前行到下一行; 

  按住滚轮一直往下,那么下面的段落都会多一个鼠标闪烁,可以统一进行多行操作;

  Shift + Alt + F,实现当前页代码的对齐;

 

  输入单词Lorem之后按Tab键,会(随机)生成很多文字信息--乱输假文,如果Lorem100,后面写的数字就是指定出现的单词个数;

  h$*6{$级标题}--$为自增符,表示创建h1~h6的标题,{}里面的表示元素内容;

  ((h2[id="chapter$"]>{章节$})+p>lorem1000)*6--可以设置里面的id;

  ul*5>(li>h3>a>lorem5)+(li*6>a>lorem2)--让第一个li里面嵌套h3属性;

 

五、在线API

  这个其实我有点不想发出来,因为本身这个是有人好心搭建服务器并提供假数据给大家方便调试,但有些人不知道报着什么目的恶意循环调用这些API导致对方服务器奔溃多次,希望大家使用这些接口的时候能报着感恩的心态去使用,不要恶意攻击;

  http://jsonplaceholder.typicode.com  ( /users  /todos /comments /ablums /photos /posts)  这个网址是为提供一些假的在线API,举例子,就是后端接口没做好,我们拿来用,总共6个接口。

 

总结

  以上就是我常用的开发小技巧,不常用的并没有发出来,如果小伙伴们有更好的方法也欢迎在评论区留言,大家一起学习进步!

你可能感兴趣的:(提升前端开发效率及查错能力的小技巧)