致刚入行的前端工程师

作者: lanzhiheng | 来源:发表于2017-04-13 00:07 被阅读5604次

讲真,这篇文章已经憋了好多天了。其实本文可以说是“起于前端,但不止于前端。”

写作的契机是最近在指导一位北京的哥们写前端,有感而发罢了。希望能够给同行一些可行性的建议吧。

Paste_Image.png

文章开始之前我想要深情地问候一下社保业务的相关部门,你们高耦合的业务,让我在天河区兜兜转转了小半天,却只是为了一张难以识别的照片。让这篇文章拖到深夜才能完成。

OK,回归正题。这篇文章出于一个刚转行6个月的初级前端之手,故不能保证看了这篇文章的人就一定能做好前端工程师的工作(我自己也尚且没做好),也不确定这篇文章能够帮到多少人,不过如佛家所言

“能度一人是一人吧”

1. Github,Github,Github

Paste_Image.png

重要的事情所以说三遍。如今前端圈大热,除了前端项目天生开源的优势之外,Github这个网站功不可没。

我们打开浏览器的调试模式就能看到对应页面的结构,以及对应的样式实现,我们也可以通过恰当的方式获取到页面的js代码。

如果说前端天生的开源知识是“发散”的,那我觉得github就是这类知识的一种“聚合”。

如今几乎所有的前端技术都是开源的,前端开发人员可以很方便地在上面找到一些高效的插件库。这不但可以提高我们的开发效率,还可以借此学习一些前端知识。

如果你想搞前端,那我觉得咱们面试之前起码得有个Github的账号,毕竟这个全球最大的同性交友网站对于前端工作者来说太重要了。

但有一点要注意的Github跟百度云盘是不一样的。他是程序员交流的地方我们只需要上传代码就可以了,我们不需要通过视频来交流(曾经有同学说想往Github上传视频)。

2. 小心培训班

如果你像我一样穷到上不起培训班的话,我相信你也不会对培训班有什么特别的好感。更加不会依赖培训班。

当然,我这里只是叫你小心培训班。并没有否定所有培训班,毕竟我知道有一些培训班还是挺用心的。

(1)培训班并没有教会你写代码

很抱歉北京的朋友,这里得借用一下聊天记录

Paste_Image.png

这是我觉得比较操蛋的一件事情。毕业之后似乎就再也没遇到过用拼音命名变量的情况。当时我只是建议这位哥们以后都用英文。并没有说为什么。

先引入一位大牛的话

“代码是写给人看的,并且可以顺带运行到机器上。”

你使用拼音来命名的话中国人都尚且看不懂,更何况是老外?而且咱们中国文化博大精深,用拼音来命名跟使用a, b, c 来命名其实并没有什么区别,语义并没有明确多少。

为了减少代码的字符数量而把变量名转换成a, b, c这种简化形式,那是优化器做的事情。而我们作为程序员,尽可能让自己的代码更语义化一些,请选择适当的英文来命名你的变量。(当然,如果你使用国人开发的易语言,那就当我没说。)

(2)培训班并不会帮你找到工作
Paste_Image.png Paste_Image.png

被这样说简直压力山大,您付费都尚且做不到的事情,我这种免费的服务肯定也做不到。培训班能做的顶多只是帮你梳理一些基础知识(或许有的只是教你背书?)知识能吸收多少主要是看自己。

再者,如今许多公司对程序员的要求已经不限于他能否写代码(或者说敲键盘?)。还有一些其他的潜规则。我举几个例子

  1. 合作意识。
  2. 沟通能力。
  3. 编码风格。
    .....

当然还有很多,从这位兄弟的情形来看,某些培训班只是教会了我们敲键盘,许多软实力的东西并没有提点太多。过于依赖培训班的话,我相信人们会逐渐疏于其他软技能的练习,这其实并不利于就业。

对于没有经验的技术工作者来说更是如此。技能已经不够硬了,其他方面如果不能稍微弥补一下那还谈什么就业?

3. 挑选一个合适的编辑器

一个好的编辑器能够提高你的编码效率,一个赏心悦目的编辑器能够让你开发的过程更加愉悦。

Paste_Image.png

现在出现了许许多多优秀的编辑器,Vim, Emacs,Sublime Text,Atom, VSCode 等等。编辑器之间该如何选择?本来就是个人喜好问题。

据我个人的使用体会,Vim跟Emacs两个编辑器比较轻量级一些,但是他们的界面我只能说一般,而且学习曲线比较陡峭。如果你喜欢折腾,倒是可以尝试一下。

Sublime Text是我目前发现周围用的人比较多的编辑器,而我个人也比较推荐,他不但有丰富的插件,还有比较美观的界面。更重要的是操作简单,能够满足大部分开发需求。

虽说我推荐Sublime Text,但其实我是一个Atom用户,两者用起来感觉差不多。

Atom比较Cool的地方是,它是通过Web技术搭建起来的桌面端软件。这也有个问题,毕竟它是通过Web技术搭建的(可以看成是运行在chrome内核的浏览器上网站),这就导致了这款编辑器相当耗电。

总之选择一个自己喜欢的编辑器。写代码去吧!!

4. 独立解决问题的能力

“这种能力是个人都有啊!!”

是吗?

Paste_Image.png Paste_Image.png

如果一个程序员在一些没有耐心的老鸟面前问这种问题的话,我相信老鸟们不只是内心有千万只草泥马在蹦腾,而是草泥马早已脱口而出了。

“当然如果对象是妹子的话,我们倒是很乐意着手帮她解决这些问题。”

以上哥们明显就还不具有这种独立解决问题的意识,并不是说不能拿问题去请教别人。而是,您需要请教别人的问题,必须是自己已经动手尝试解决,而且解决不了的问题。

毕竟程序员最怕打扰,咱们能不打扰就不打扰。

我们生活在如此幸福的时代,其实很多问题已经有大牛解决了,并且他们会把经验分享到网上,我们需要做的只是组织好自己的问题简单地Google,或者百度一下。这样很难吗?

如果连这点都做不到,那我觉得要进入一家公司或者是在一家公司里生存都是很艰难的事情(当然某些国有企业除外)。毕竟大部分公司需要的是能够解决问题的程序员,而不是只会写代码的打字员。

5. 阅读英文文档

这让我之前想起知乎上Vue.js 作者尤雨溪说过的一句话,其大意是:

我为什么要浪费跟家人相处的时间来教你学英文?

如今大部分优秀开发的资源都是以英文的形式展现到网络上的。

当然不排除有些国内的热心人会把他们翻译成中文,再托管到相关网站上,但是,这毕竟是少数。而且中文文档往往会跟不上国外官网的脚步。

还记得我当初用Python的时候,框架Django的中文版本是1.6.x而官方的最新版本已经到1.8.x了。

这也导致了,如果你用着新版本的框架,而看着旧版本文档写代码的话可能会引入一些新版本里面已经抛弃了的写法,进而你的项目可能会出现一些诡异的行为。而且这类bug往往最难发现。

当然,并不是说你一定要英文很流利才行,但是最起码要看得懂英文文档。(实话说现在我工作快两年了,看英文文档还是有些吃力。)

6. 操作系统

好吧,允许我再啰嗦一下。

这里我们谈谈操作系统,毕竟有些朋友还是会纠结选择什么操作系统。

Windows

优点: 用户页面可用性较好,丰富的桌面端软件,玩游戏一级棒。
缺点: 软件广告比较多,病毒相对多些。命令行不够友好(我个人觉得相当操蛋)。

Linux

优点: 命令行非常好用,开源社区活跃,发行版本比较多。
缺点: 常用桌面软件开发商比较少,QQ这些都没有。有些发行版不怎么稳定,经常卡死。

MacOS

优点: 命令行非常好用,界面优雅,可用性高。苹果商店有许多windows平台所没有的优质软件。
缺点: 设备昂贵,普遍配置不高,不太适合打游戏。

以上是我使用操作系统的一些小体会吧。至于具体使用什么系统各位可以自行掂量,但是个人觉得结合命令行开发会更爽一些。因此我曾经选择过Linux。后来,机缘巧合之下买了台Macbook之后就再也回不了头了。

正如业界的人所赞赏的

“MacOS就像是Liunx跟Windows的结合体。它既有Windows的用户友好的界面,也有Linux优雅的命令行。”

不过这玩意儿

用了之后就很难回头了。

我有个同学买了它之后,干脆把LOL(英雄联盟)都戒了。

Paste_Image.png

7. HTML + CSS + JavaScript

现在才谈这些技术点并不是说这东西不重要。只是我觉得这三样东西就算我不说,只要你有心搞前端肯定会去学,那还有说的必要吗?(此处省略百万字)

8. 尾声

都不知道自己写了多少字,只希望今晚能够发布出去。希望能对有缘看到此文的朋友有那么一点帮助吧。

Happy Coding and Writing !!

相关文章

网友评论

  • yingzigo:哈哈哈,刚好也是转行六个月多点哟:beers:
    lanzhiheng:@yingzigo :sweat:别这样说。前端水太深我兼顾不来,相比起来我感觉自己更适合后端
    yingzigo:@lanzhiheng 那你厉害了,全栈咯
    lanzhiheng:@yingzigo :monkey_face:哈哈。我可能很快就做后端去了
  • 邱雯腾:工作了一年的女前端默默飘过~~:smile:
    lanzhiheng:@邱雯腾 我做了一年后端。前不久刚转前端
    邱雯腾:@lanzhiheng 看你的文章不像是还不到一年的:smile:
    lanzhiheng:@邱雯腾 我前端还不到一年:smile:
  • 我系哆啦:写得挺好,哈哈哈哈哈
    lanzhiheng:@我系哆啦 t h x
  • sanchuan:Mac邪教:smiley:
    lanzhiheng:@sanchuan 我很荣幸:smile:
  • Melon丶:什么东西不试着解决就提问,真不适合做程序猿🤒
  • doyle_诗豪:看了下截图,这个哥们真的不适合这行,劝退吧,基本的自学能力都很欠缺。
  • 来米阳光:我不会说看过很多成品已上线的pc站,都有拼音,class
  • c3be5117160b:厉害了😍
  • 4b6b19c73727:对我这刚伸脚进前端的小菜,现在学到js函数了,有点懵逼,大神有没有好的建议
  • 05b5034e8244:对于一个入行半年多的程序媛来说,阔以的。
  • 1dent1ty:之前在技术群我还是一个热心指导热鸟的新手,后来我发现直接提供答案并没有什么卵用,所以现在新手再提特别低级的问题,我直接甩给他一本书的链接,什么书呢,《提问的智慧》。
  • 1eff7f40b465:我是妹子
    1eff7f40b465:@lanzhiheng 你好,我是汉子,是一个有代码洁癖的汉子
    lanzhiheng:@chen_long 妹子你好。
  • a2e3f419b1f8:个人觉得写的不好,多给点忠告,给点干活,学习资源
    lanzhiheng:@阿磊哥爱吃肉 下次吧
  • 沙漏了:说到用拼音命名,我想起来一个人,至今不知道是哪位同事……当初在代码里用我的姓名全拼做类名,然后埋了个雷,后来领导直接找我谈话……
    496621bdffbb:你可以开沙漏啊,免受伤害
    沙漏了:@久久归ling 坑谁也不能坑自己呀
    久久归ling:@沙漏了 可能是你自己哟:relieved:
  • 咆哮女孩:现在微软的命令行相当友好,楼上说程序猿不用学算法的反正过几年都回家耕田了😄
    lanzhiheng:@咆哮女孩 你就装逼
  • dac705ab6149:有点意思,很搞笑:+1:
    lanzhiheng:@文艺上班族 thx
  • 成长路上多迷惑: 我的macbook 开虚拟机挂游戏,边撸代码边挂机杠杠滴。
  • 逍遥的fish:你好!
    lanzhiheng:@逍遥的fish :cry:别 咱们好好说话
    逍遥的fish: @lanzhiheng 前辈在上,受小弟一拜,哈哈😄
    lanzhiheng:@逍遥的fish hi
  • 6173b1966515:对刚入行的人,你一个劲的跟他说去GITHUB学习,那是一个很操蛋的观点
    站在埃菲尔铁塔上看风景: @西迷岛主 有理,所以我去培训班了
    lanzhiheng:@西迷岛主 ok
  • 朵霞:同为前端 已经三四年了
    lanzhiheng:@拜金女孩_ 那恐怕该文章对您并无太大帮助:turtle:
  • 鱼太咸丶:纠正下作者,mac并不是普遍的配置不高哦。只是性价比低,你买个imac,打起游戏也是杠杠的。
    lanzhiheng:@小简的生活丶 :monkey_face:加油 共勉
    鱼太咸丶:@lanzhiheng 那是得改改自己的生活啦:smile: 。正准备自己学学前端的东西。
    lanzhiheng:@小简的生活丶 :mask: 似乎也是,我是用的笔记本,集成显卡。开个虚拟机就几近崩溃。
  • xcodelife:看你这个网友说的话就是逗逼体质,不靠谱的对话,别说培训班,大牛一对一授课 也是个样
    xcodelife:@lanzhiheng 态度问题
    lanzhiheng:@xcodelife 刚入行嘛
  • 上先生:一入前端深似海,惘然回头一场空
    lanzhiheng:@小阳老师 正解
  • 浩风起兮:Mac端 不做评论,系统厉害,win端你会发现装插件多后sublime和atom的差别,atom卡到爆,亲身体会,拼音命名这种,至少相当一部分公司项目还是在使用拼音首字母这种命名的,那种傻傻的全拼就算了,英文命名,一些大众化的还是遵循以下,ad,cnt,tit之类的,特殊一些可以参考规范或这个公司自己的规范来的
    lanzhiheng:@浩风起兮 这样啊,OK,多谢你的提点。
  • 4b88da88c15a:天河区?广州的程序员呀
    4b88da88c15a:@biu小5 我?不是,工作程序狗而已
    904e648b8384: @无西 天河区?某智播客?
    lanzhiheng:@无西 是的
  • 无颜Flower:厉害了我滴哥
    无颜Flower:@lanzhiheng 不明觉厉,果然很腻害
    lanzhiheng:@DaiFlower t h x
  • 长腿学姐:我只看到你说,如果是妹子的话你很愿意帮忙解决问题😀😀
    lanzhiheng:@长腿学姐 哈哈 很不幸就是这个物种
    长腿学姐: @lanzhiheng 哈哈哈,果然程序员。
    lanzhiheng:@长腿学姐 :no_mouth:能帮就帮。对妹子会有耐心一些。
  • mconintet:初学者更应该专注于知识点本身,所以如果是给初学者看的话,还是选择 JetBrains 家的 IDE 比较好,因为各种主要功能 out of box,编辑器搭配插件是可以同样达到 IDE 的功能,但是有些难度上,并且效果上和 IDE 相比还是有些差距。
    lanzhiheng:@浩风起兮 webstorm 确实很强大
    浩风起兮:webstorm确实不错,不过一些简单的小网页焉用宰牛刀,何况启动还慢,嘿嘿
    lanzhiheng:@mconintet 那家公司的产品确实很不错,但是好的服务一般都不是免费的
  • 332e40bd0e1d:刚入行的前端复制粘贴师吧
  • 风的落叶:赞一个,我以前做了三年多前端,现在转成后端。
    风的落叶:@使徒行者via 不需要懂,所以我觉得在学校研究了这么多年算法真是浪费了,果断转后端。
    使徒行者via: @风的落叶 前端需要懂算法吗🤓 刚学html+cdd
    lanzhiheng:@风的落叶 多谢
  • 开发者头条_程序员必装的App:感谢分享!已推荐到《开发者头条》:https://toutiao.io/posts/atp64y 欢迎点赞支持!
    欢迎订阅《一个程序员的自我修养》https://toutiao.io/subject/35168
    lanzhiheng:@开发者头条_程序员必装的App 感谢你的推荐 但是下面的链接是404:fearful:
  • 平凡而简单:楼主,主要只写了与刚入行的前端新人工作相处的一些经历想法,感觉实际的东西基本没看到,目前工作中流行的框架,工作中遇到的一些常见问题等!现在主流的框架angular,vue,react那个比较火,他们的主要特点是什么?
    使徒行者via: @平凡而简单 前端需要懂算法吗🤓 刚学HTML+CSS
    风的落叶:@平凡而简单 面试题哈哈
    lanzhiheng:@平凡而简单 谢谢你的意见 这些我用得不多 因此也不打算在这篇写

本文标题:致刚入行的前端工程师

本文链接:https://www.haomeiwen.com/subject/gxnpattx.html