2017年年终总结(就是一个程序员的瞎叨叨):
  从来到中科院到现在,很开心可以在这留下来。毕竟对于我来说,这里符合我对自己毕业后前两年的规划。我是一个很慢的人,特别是对于我想做好的事情,我会非常认真仔细的思考,不愿意放过任何一个漏洞。而对于我的专业来说,对于前端,我当时也是知之甚少。我愿意花费更多的时间去补充自己的知识,我非常乐意学习新的知识,新的内容,以及了解所有我不知道的,意料之外的现象。了解他们形成的原理,去避开,或使用他们。但是我不愿意自己在没有很牢固的基础时,去大量的学习内容,我觉得这是一个表面现象,或者说这不是我想要的,想成为的人。我希望自己对所学的一切都知其然知其所以然,不仅会用,更能理解,解决,创造。这大概是我当时的想法吧。
  对于前端,可能很多人都觉得简单,甚至上手非常的快,或者觉得html和css基本不需要学习,js也只用jquery就可以了。最近也在面试一些同学,可能他们也抱着这样的心态,我觉得这是不正确的,我并不觉得一切都很简单,对于html的关注,和css的关注,应丝毫不亚于对js的关注,我不得不承认我当时对js的关注也多于其他两项,我正在调整,去花更多的时间关注他们。这些都是在工作和学习中,时常会感到对这些的理解不够深刻,只是用,很少去想为什么用。在这一年中,我觉得自己的基础在逐渐的牢固。在工作和学习的过程中,也遇到了许多问题,产生了许多想法。使用了更多的库,包括学习深度比较深的像cesium,three,arcgis等,使用了sass,less,gulp,grunt,等内容。写了几篇博客(比较遗憾,没有多抽出时间来写),但是总结了几百个页面甚至更多的知识。使用java,并且优化了自己的代码,别人的代码,进行了重构,自己的前端后台代码也在不断的成长。照着书敲了800多页的内容。等等还有非常多的内容。在这里,所有的问题,都需要自己解决,所有的想法都要自己判断,自己处理。像代码的优化方式,重构都是看书和别人的总结,自己在过程中逐渐认知的内容。总体来说,就是自己一点点的累积和总结,达成了今天的自己。
  接下来总结我现在能想到的一些问题:(这点也是没有进行良好的总结导致,以后还是要多多总结,全面总结):

  第一个是跨域的问题:做项目时,服务端用的python,我在自己的编辑器写web。请求调试时跨域。当时解决方法,使用CROS进行跨域。因为服务器也是可以控制的。所以很顺利。后续给组里写的项目,都是自己需要写后台的,所以基本没有这个问题。直到有一次,需要去调用一个视频流,当时我们有三种格式的,由于某些原因,获取放到了前端。那次真的是尝试了10多种跨域方式,最终通过webscoket解决。也帮助我总结了基本上所有的跨域方式,以及我了解到的他们的特点。

  第二个是转html转pdf,word文档。这个当时在百度和chrome上,都没有现成的,或者说晚上的解决方式,主要是对于内容,格式,图片,表格等导出控制,没有一体化的库或者说一个比较规范的方式。所以我是去发现现有的可能的方式,然后去总结比较,包括结合来达到我想要的结果。这个问题也教会了我当我遇到的问题,可能网上没有答案,或者没有合适的方案时,我自己要怎么思考,怎么分块处理,怎么整合在一起。最终完美解决。只放了word的代码,因为pdf还是有一个比较合适的库,又加上后来没有去放代码。这个在博客和github上都有。
  第三个是重拾java,写前端的同时,写后台的代码。这个主要是心理上的问题,当时我感觉自己是想要吧前端做的更加好,觉得自己有许多要学习的前端的内容,不想花费时间在后台上。但是后来还是接受了,而且在这个过程中学到了许多。比如调整自己的心态,虽然之前在学校也学过,但后来基本丢的差不多了,但是会非常容易理解一种语言,也总结了学习语言的方法。我愿意花时间去看一本springboot的书。所以一切就会变得简单,后来甚至会重构之前的同事们写的后台代码,能发现哪些方法是好的,哪些是不合适的,比如前端列表的获取不应该由后台controller定义。我觉得这是我一开始没有想到的。也感觉代码到一定程度,其实设计应该是相同的。
  第四个是通过不断的写系统,从刚开始的缓慢到后来的速度,自己对系统的设计和组织能力,在不断的提升。知道如何入手,知道要考虑哪些方面的内容,要思考什么样的方式去实现。另外,也懂得与人协作可能会存在的问题。这个只能说是实践出真知。去年大概完成了五个系统。也学习了,修改了别人的系统。
  第五个是数据流展示,这个其实不算什么问题。本来是准备使用原生的websocket,但是之前的同事们采用了一个框架socketjs,所以本着遵循他们的逻辑,后台要求仍然用这种方式,所以就用了。但后来,又增加了两个数据流后,发现后台给的接口,并不能确定数据流的类型,因为是通过rid进行区别的,但是websocket的路径中并没有带rid,所以会发生串流的现象。后来采用了原生的方式进行重写。这个主要是前后端约定方式的问题。教会了我思考扩展问题,思考现存的方式是否合适,以及是否有更好的方式可以代替。 

  第六个也不算是什么问题,当我们决定使用3d地图的时候,自己研究了学习了cesium地球,还有threejs,并且可以实现我们的需求,后来因为我们之前用的平面地图是arcgis,我们也买了arcgis的服务,也参加了arcgis的全球大会,所以改为使用arcgis3d地球。在这个过程中,一直是一个学习的过程,遇到的问题其实都是自己对该库了解不够多,另外还有学习方法的问题。对于问题,其实只要你花时间去解决,基本就能解决。对于库的使用,我觉得只要是库能做到的,我们开发人员就基本应该做到,这没什么特别困难的事。对于学习一个新的,具有深度的库也有了自己的理解。我们应该有正确的方法,比如从类到方法,到属性的去学习。一步步的根据我们的要求学习这个库。如果我们主攻这个库,我建议采取的不是为了要求,而是我们对于每一块自己能理解到的程度去学习。这样会更加有深度,也许可以提出或者创造一些没有的东西。但这个一般对于库的开发人员来说,就像我们对于js一样,能多深,就多深。
  第七个是在写动画的过程中,使用的方式就不说了。主要是在js精准控制动画过程中,产生的问题。由于界面需要的交互动画较多,会导致一些延迟动画在快速操作的过程中,没有进行及时的添加移除,包括延时后产生的各种效应等。教会了我许多对于动画的设计,和控制动画的起始,包括了解了js的高精度计时,以及js的延时操作不可靠。也在处理threejs过程中接触到了大量动画渲染卡顿的问题。也了解了dom树的渲染和利用gpu去解决js的计算问题。包括界面上的盒子。以及脱离文档流后的部分重绘将会节约时间。等等,并不深刻,有待深入了解总结。

其实还有许多问题,没有进行好的总结,所以或许一时想不起来,像vertical-align和line-height之间的关系,像transform的matrix。等等,当我遇到的时候可能就会想起来了,这里就不把几百页的内容列举出来献丑了。
总结一下学到的知识吧:
1.跨域
2.webStorage
3.各种各样的插件使用。
3.html content 转world,pdf。
4.java springboot
5.sass, less
6.gulp, grunt
7. websocket
8.flex布局
9.canvas
10.svg
11.播放各种格式的视频流
12.cesium,arcgis
13.three.js
14.动画
15.看并敲了七八百页的基础书。
16.写了几篇博客
17.看了半本设计模式
18.看了半本算法。
19.学习了es6
....
等等许多css和html,js细节的内容就不说了,实在是临时想,很尴尬。。

总结展望:
1.总结:学习了大量的内容,巩固了自己的基础知识。也使用了很多的插件和框架,对于基础,对于html,css,js都有了自己的理解。对于插件和库有了自己的学习和使用方法。也依靠自己解决了许多问题,对于问题,能形成良好的思路。缺乏总结整理。对于知识的掌握缺少深入思考和联系,对于前端的架构了解较少,对于算法数据结构,设计模式使用较少。看书较少。总体还算可以吧(我夸自己一下)。
2.展望:今年要对基础进行更加深刻的理解,争取能够成为真正意义上的精通。其次,多多思考学习方法,学习管理自己。多读一些书,还是有整体上的许多内容需要进一步学习。多多使用算法数据结构和设计模式的思想。学习vue和react,webpack。了解angular.js。多多学习源码。任重道远,砥砺前行。

一个web程序员的年终总结的更多相关文章

  1. 一个java程序员的年终总结

    年底了,该给自己写点总结了! 从毕业到现在已经快4年啦,一直在Java的WEB开发行业混迹.我不是牛人,但是自我感觉还算是个合格的程序员,有必要写下自己将近4年来的经历,给自我以提示,给刚入行的朋友提 ...

  2. Web程序员开发App系列 - 开发我的第一个App,源码下载

    Web程序员开发App系列 Web程序员开发App系列 - 认识HBuilder Web程序员开发App系列 - 申请苹果开发者账号 Web程序员开发App系列 - 调试Android和iOS手机代码 ...

  3. 一个10年Java程序员的年终总结,献给还在迷茫中的你

    我越来越担心我作为一个Java程序员的未来. 恍然间,发现自己在这个行业里已经摸爬滚打将近10年了,原以为自己就凭已有的项目经验和工作经历怎么着也应该算得上是一个业内比较资历的人士了,但是今年在换工作 ...

  4. 2016 Java程序员的年终总结(转)

    2016 Java程序员的年终总结 技术积累 (1)代码规范 1.1.1.通常的模块分布:一般如果你要实现一个web 应用,你从后台将数据展示到前端页面,在一个比较大的公司,你少不了跟其他项目有交集( ...

  5. .NET WEB程序员需要掌握的技能

    本来这个是我给我们公司入职的新人做一个参考,由于 @张善友 老师在他的微信号转了我的这篇文章<<.Net WEB 程序员需要掌握的技能>>,很多人觉得比较有用,说是看了后知道一 ...

  6. Web程序员开发App系列 - 调试Android和IOS手机代码(补图)

    Web程序员开发App系列 Web程序员开发App系列 - 认识HBuilder Web程序员开发App系列 - 申请苹果开发者账号 Web程序员开发App系列 - 调试Android和iOS手机代码 ...

  7. Web程序员开发App系列 - 申请苹果开发者账号

    Web程序员开发App系列 Web程序员开发App系列 - 认识HBuilder Web程序员开发App系列 - 申请苹果开发者账号 Web程序员开发App系列 - 调试Android和iOS手机代码 ...

  8. Web程序员开发App系列 - 认识HBuilder

    Web程序员开发App系列 Web程序员开发App系列 - 认识HBuilder Web程序员开发App系列 - 申请苹果开发者账号 Web程序员开发App系列 - 调试Android和iOS手机代码 ...

  9. 一个.net程序员教你使用less

    我是一个.net 程序员,虽然说一直做后台,但是web 前端也会去学,虽然说技术只是层窗户纸,但是像我这种多动症患者,不捅破我心难受啊! 好!废话不多提,下面直接正题,至于less 是什么这里不多讲因 ...

随机推荐

  1. 转发—Android开发常用的插件及工具

    作者:蓝之风 出处:http://www.cnblogs.com/vaiyanzi/ Android开发常用的插件及工具 1.GitHub,这个不管是做安卓还是其他,只要是开发就必上的网站,也是天朝没 ...

  2. Java基础学习笔记一 Java介绍

    java语言概述 Java是sun公司开发的一门编程语言,目前被Oracle公司收购,编程语言就是用来编写软件的. Java的应用 开发QQ.迅雷程序(桌面应用软件) 淘宝.京东(互联网应用软件) 安 ...

  3. 用Python登录好友QQ空间点赞

    记得之前跟我女票说过,说要帮她空间点赞,点到999就不点了.刚开始还能天天记得,但是后来事情一多,就难免会忘记,前两天点赞的时候忽然觉得这样好枯燥啊,正好也在学Python,就在想能不能有什么方法能自 ...

  4. 【Alpha版本】冲刺阶段 - Day6 - 乘风

    今日进展 袁逸灏:1.实现了碰撞的判定:2.代码规范化:3.解决了项目基本代码.(7h) 刘伟康:补充了上次未完成的任务,即检查代码规范,增加AS规范并整理上传至码云.除此之外,学习了部分 Andro ...

  5. Beta冲刺NO.5

    Beta冲刺 第五天 1. 昨天的困难 1.昨天的困难主要是在类的整理上,一些逻辑理不清,也有一些类写的太绝对了,扩展性就不那么好了,所以,昨天的困难就是在重构上. 页面结构太凌乱,之前没有统筹好具体 ...

  6. Numpy - 多维数组(上)

    一.实验说明 numpy 包为 Python 提供了高性能的向量,矩阵以及高阶数据结构.由于它们是由 C 和 Fortran 实现的,所以在操作向量与矩阵时性能非常优越. 1. 环境登录 无需密码自动 ...

  7. win10 安装mingw ruby rails

    原文可以参考 https://ruby-china.org/topics/17581 在window10 安装ruby rails https://rubyinstaller.org/download ...

  8. 进军ABP第一天:ABP理论知识

    1.2.3 领域层领域层就是业务层,是一个项目的核心,所有业务规则都应该在领域层实现. ( 实体(Entity ) 实体代表业务领域的数据和操作,在实践中,通过用来映射成数据库表. ( 仓储(Repo ...

  9. Python内置函数(18)——bin

    英文文档: bin(x) Convert an integer number to a binary string. The result is a valid Python expression. ...

  10. 使用 vi 命令

    一.vi是什么 vi命令是UNIX操作系统和类UNIX操作系统中最通用的全屏幕纯文本编辑器. Linux中的vi编辑器叫vim,它是vi的增强版(vi Improved),与vi编辑器完全兼容,而且实 ...