实习总结

写在前面

首先非常感谢qunar给我的这次宝贵的实习机会,有幸可以在flight-fe实习。在qunar已经工作两个月多的时间,期间学习到很多的新东西,了解并体验了整个开发流程。最重要的是在生产环境下写了一些代码,感受很深。在qunar的这段时间对我成长帮助很大,让我对前端开发也有了新的认识,受益匪浅。

实习过程

1 关于开发环境

在学校的时候,不太可能接触到真实的公司开发环境。所以,一直对开发环境非常好奇。能想到的除了版本控制,可能也就是sublime或者webStorm这些开发工具了。开始入职之后,用了两天的时间配置了开发环境,现在想想也够低能的了。其中包括fekit、qzz、nginx、node等等。搞了半天也不明白自己到底在做什么。当跑起来一个项目之后,瞬间有点受刺激。明明访问的qunar域名,请求到的却是本地文件。后面慢慢的理解,我认为的麻烦实际上是极大的方便了开发。fekit完全包揽了所有的前端开发需求,方便本地开发,静态文件的编译,还可以当包管理器使。最重要的是,打包发布。不知道是哪位前辈所做,在这表达一下敬意。
    touch的开发环境,很有意思。后端是一个项目,前端有一个qzz项目,还有Zeus项目。一直以为qzz项目用不到,直到要发beta的时候我才明白了。原来前端都是在qzz上面。后来一直考虑为什么前端有两个项目,Zeus到底做了什么,想了想发现Zeus支持了本地开发,编译了sass,一个ctrl+s就直接同步到了浏览器。从后台打印信息来看,是用的推送。后来了解了一下,Websocket做的类似热部署。再后来在使用weinre的时候发现,好像weinre应该也用到了同样的东西。然后想想自己low到爆的ajax轮询,默默的在本上记下“推送”这个关键字,加入学习计划。另外,IDEA是一个牛逼的IDE。

2 关于项目经历

1 天地行项目
     参与的第一个项目是“天地行项目”。主要负责PNR导入页、部分mustache模板开发、模板渲染以及一些简单功能比如经停退改签等等的开发。接触到了mustache、kendo等没有接触过的技术。在开发过程中,也学习了公司的开发规范。对于jquery的API使用和原理也有了一些提高。期间也学习了项目中的部分代码,第一次见设计模式的使用还是很新奇的。
     涛哥有一天过来笑呵呵问我说:小伙子有什么问题。技术上的、业务上的、项目上的。当时突然就理清了在“天地行”项目上面的一些问题。PRN导入、黑屏建单、白屏建单、联程、政策等等问题都属于业务问题。而jquery的缓存原理属于技术问题。组件的使用,老代码的维护修改则属于项目问题。现在想想也很简单,但是当时懵到不行,还是不够思维清晰没有理清楚思路。
     在天地行项目中,最大的收获可能不是技术上的而是对于开发环境的熟悉,和项目开发的认识。一个新的项目,在开发之初会做好设计工作。包括类库、框架的选择,项目开发规范的约定。开发完毕之后需要和后端联调,联调完毕需要测试,之后再发布上线。项目在开发过程中可能经历本地开发环境、DEV环境、BETA环境。不同环境需要不同的配置,当然fekit和qzz起到的非常重要的作用。
    2 机票touch改版项目
     touch改版是我第一次负责一个模块的开发,也是第一次尝试移动端的开发。主要负责机票首页和城市列表页的开发。移动端的开发,相对来说可以使用的技术更广泛,HTML5、CSS3、ES5等等相对选择更多。但是麻烦的是,设备的性能决定代码的质量要比较高。减少DOM操作,HTML尽量精简且语义化要好,JS耗时的操作也得尽可能避免。最让人头疼的是浏览器的兼容性问题,因为移动设备的特殊性,调试起来还是相当麻烦的。对于复杂的UI设计和交互效果,做起来还是很吃力的。
     在touch改版项目中,使我的切图技术提高很多。对于标签语义化也有了新的理解。CSS方面,学习使用到了伸缩盒模型flex布局、线性渐变、calc、响应式布局、媒体查询、非对称圆角、水平垂直居中等等。HTML书写上更加注意到语义化标签,模块的划分,DOM的复用,避免多余的wrapper等等问题。选择器的命名规范,严格区分CSS和JS的使用,避免使用标签选择器等等可能造成安全风险和维护困难的问题。JS方面。对于项目组件化有了一些理解,JS文件的页面划分,功能划分也有了一些认识。在review代码的过程中,学习到了很多。对于开发原则、JS代码规范、解耦、面向对象编程也有了新的认识。也尝试着做了一些性能优化的工作,感受很多。
     好代码是改出来的——涛哥。自己写的代码就像自己的孩子——宇欢。对于这两句名言,也是感触很深。开始在解耦首页与城市列表页的逻辑的时候,感觉牵一发动全身改起来相当的困难。然后改着改着就顺利了。感觉思路越来越清晰。同样的在修bug的时候,也是把握不住,不断的打断点来定位。后来bug提上来,想一下大概就知道是什么地方出问题了。很惭愧,估计bug率创纪录了。虽然到现在为止好像没有大的问题了,但是我自己心里了解,代码还是不够清晰不够鲁棒,应该可以做的更好。
     关于移动端兼容性的一点总结:虽然移动端浏览器已经很好的支持了CSS3和HTML5.但是不同厂家在实现标准的时候还是有很大的差异的。比如说UC对于线性渐变的解释就和标准有些不同。首页的搜索记录末尾需要一个模糊遮罩,使用黑色透明零渐变到白色透明零,其他浏览器都是支持的,但是在UC上就有bug,必须使用白色渐变到白色。另外active在UC上也是不被支持的,当你选择使用touchstart和touchend来模拟active时,不好意思UC的touchmove和touchend是有bug的。最后只能在tap事件上做一个延迟的效果来模拟active。对于flex布局,必须严格的按照规范来书写。有时候可能不给父容器确定的宽高可以,但是chrome会告诉你这样做不可以。实际上我所理解的大多数兼容性问题出现在浏览器的容错性上,也就是说我的代码实际上是不那么规范的。但是,也有些情况下是存在不可避免的问题,那么就需要降级处理或者使用hack写法。

我的反思

不得不承认,我有很多的缺点。计划不够,有些急于求成。在实习开始的一段时间,坦白的讲我显的比较急躁。迫切的想投入到项目中去,没有静下心来好好的研究业务。开始的时候,每天会觉得比较闲没有事情要做也很苦恼。后来,和导师交流了一下。导师问我,做完了功能点,那你有没有阅读这个功能相关的代码,航班是怎么渲染的有没有了然于心。这句话点醒了我。实际上是自己的心态问题,还是不够沉稳,急于求进不是一件好事。实习快完了还是有很多的遗憾,计划学习的jquery缓存还没有彻底搞清楚、想用Python来实现一个修改host即改即生效程序也没有实现、使用一次websocket也没有能抽出时间。越想越觉得自己low到没朋友了。好消息是我还有时间去静下心来做想做而没有做完的事情。是时候闭关修炼了。

感谢

1 感谢做了我两天导师的 @佳梅,在我有些凌乱的时候帮助我理清了思路。
2 感谢导师 @张宏,非常有耐心的解释问题甚至举一反三。
3 感谢 @宇欢 导师,数不清回答了我多少问题了。不说了,你懂的。
4 感谢 @地木 多次回答了我的问题,谢谢支持。
5 谢谢 @张老师 @俞斌 的分享,很精彩。另外,张老师真的应该当老师。
6 感谢 @涛哥 @文祥 @君婷 @张哲 @海斌 @Flight-FE @测试 @PM 你们受苦了。

H5定位

依赖jquer

<pre>

  • html方式绑定类名即可
    <div class="h-location">点我定位</div>
  • js方式,传递一个回调到getLocationCity即可
    getLocationCity(function(err,result){ //
    if(err){console.log(err); return false;}
    console.log("定位到的城市是:"+result);
    })
    }
    </pre>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,133评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,682评论 3 390
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,784评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,508评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,603评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,607评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,604评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,359评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,805评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,121评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,280评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,959评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,588评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,206评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,193评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,144评论 2 352

推荐阅读更多精彩内容