整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

同构 javascript 应用开发的最佳实践(2)

同构 javascript 应用开发的最佳实践(2)

些公司在使用同构 javascript, Yahoo、 Facebook、Netfix 和 Airbnb 这些都接受了同构 javascript。不过同构成本还是很高的,存在一定复杂度。如果对性能要求不高,也无需支持 SEO 需求,可以选择使用 SPA 。同构 javascript 带来的麻烦似乎要大于收益。

同构的本质就是代码复用。

整个项目管理使用 gulp 工具进行管理,由于在服务端使用 nodejs 对模块管理使用 CommonJS。而在浏览器端不是天生支持 CommonJS 模块管理在 es6 中引入更优雅的模块管理。但是在 nodejs 我知道阶段可能还不支持 ES6 的模块管理,所以使用 babel 这个编译工具对我们服务端的 javascript 代码进行转换为 commonJS 模块管理。

这里有时候不会关于详细演示如何使用某个具体的库或框架,例如如何使用 gulp 来构建 javascript 的项目。更多的是关注整体框架是如何搭建的。


定义开发流程


引入构建工具 gulp


var gulp=require('gulp');

gulp.task('default',function(){
    console.log('default task sucess');
})


编译编译任务

引入 babel 和 gulp-babel 的,并且需要 npm 对所需的库进行已安装,除此而外还需要全局安装 gulp 和 babel-cli。编写编译任务来对服务端 js 使用 babel 编译工具进行编译。


const gulp=require('gulp');
const babel=require('gulp-babel');

gulp.task('compile',function(){
    return gulp.src('src/**/*.js')
        .pipe(babel())
        .pipe(gulp.dest('dist'));
});


监听代码变化


gulp.task('watch',()=>{
    gulp.watch('src/**/*.js',['watch'])
})

gulp.task('default',['watch','compile']);


服务端代码更新后重启服务


const nodemon=require('gulp-nodemon');
const sequence=require('run-sequence');

我们需要监控编译好的 index.js ,当这个文件内容发生了变化就需要自动重启服务。


gulp.task('start',()=>{
    nodemon({
        watch:'dist',
        script:'dist/index.js',
        ext:'js',
        env:{'NODE_ENV':'development'}
    });
});

观察的文件是编译好的文件所以我们需要按一定执行顺序来执行一系列的任务。


gulp.task('default',(cb)=>{
    sequence(['watch','compile'],'start',cb);
});

好就是我们应用构建已经完成

同构 javascript 应用开发的最佳实践(1)



参考 《同构 Javascript 应用开发》

注于Java领域优质技术,欢迎关注

作 者:Cherry300

来 源:jianshu.com/p/c86cee16b418

一、前戏

前后端分离已成为互联网项目开发的业界标准使用方式,通过nginx+tomcat的方式(也可以中间加一个nodejs)有效的进行解耦,并且前后端分离会为以后的大型分布式架构、弹性计算架构、微服务架构、多端化服务(多种客户端,例如:浏览器,车载终端,安卓,IOS等等)打下坚实的基础。这个步骤是系统架构从猿进化成人的必经之路。

核心思想是前端html页面通过ajax调用后端的restuful api接口并使用json数据进行交互。

在互联网架构中,名词解释:

Web服务器:一般指像nginx,apache这类的服务器,他们一般只能解析静态资源。

应用服务器:一般指像tomcat,jetty,resin这类的服务器可以解析动态资源也可以解析静态资源,但解析静态资源的能力没有web服务器好。

一般都是只有web服务器才能被外网访问,应用服务器只能内网访问。

二、术业有专攻(开发人员分离)

以前的JavaWeb项目大多数都是java程序员又当爹又当妈,又搞前端,又搞后端。

随着时代的发展,渐渐的许多大中小公司开始把前后端的界限分的越来越明确,前端工程师只管前端的事情,后端工程师只管后端的事情。正所谓术业有专攻,一个人如果什么都会,那么他毕竟什么都不精。

大中型公司需要专业人才,小公司需要全才,但是对于个人职业发展来说,我建议是分开。

1、对于后端java工程师:

把精力放在java基础,设计模式,jvm原理,spring+springmvc原理及源码,linux,mysql事务隔离与锁机制,mongodb,http/tcp,多线程,分布式架构,弹性计算架构,微服务架构,java性能优化,以及相关的项目管理等等。

后端追求的是:三高(高并发,高可用,高性能),安全,存储,业务等等。

2、对于前端工程师:

把精力放在html5,css3,jquery,angularjs,bootstrap,reactjs,vuejs,webpack,less/sass,gulp,nodejs,Google V8引擎,javascript多线程,模块化,面向切面编程,设计模式,浏览器兼容性,性能优化等等。

前端追求的是:页面表现,速度流畅,兼容性,用户体验等等。

术业有专攻,这样你的核心竞争力才会越来越高,正所谓你往生活中投入什么,生活就会反馈给你什么。并且两端的发展都越来越高深,你想什么都会,那你毕竟什么都不精。

通过将team分成前后端team,让两边的工程师更加专注各自的领域,独立治理,然后构建出一个全栈式的精益求精的team。

三、原始人时代(各种耦合)

几曾何时,我们的JavaWeb项目都是使用了若干后台框架,springmvc/struts + spring + spring jdbc/hibernate/mybatis 等等。

大多数项目在java后端都是分了三层,控制层,业务层,持久层。控制层负责接收参数,调用相关业务层,封装数据,以及路由&渲染到jsp页面。然后jsp页面上使用各种标签或者手写java表达式将后台的数据展现出来,玩的是MVC那套思路。

我们先看这种情况:需求定完了,代码写完了,测试测完了,然后呢?要发布了吧?你需要用maven或者eclipse等工具把你的代码打成一个war包,然后把这个war包发布到你的生产环境下的web容器里,对吧?

发布完了之后,你要启动你的web容器,开始提供服务,这时候你通过配置域名,dns等等相关,你的网站就可以访问了(假设你是个网站)。那我们来看,你的前后端代码是不是全都在那个war包里?包括你的js,css,图片,各种第三方的库,对吧?

好,下面在浏览器中输入你的网站域名(www.xxx.com),之后发生了什么?(这个问题也是很多公司的面试题)我捡干的说了啊,基础不好的童鞋请自己去搜。

浏览器在通过域名通过dns服务器找到你的服务器外网ip,将http请求发送到你的服务器,在tcp3次握手之后(http下面是tcp/ip),通过tcp协议开始传输数据,你的服务器得到请求后,开始提供服务,接收参数,之后返回你的应答给浏览器,浏览器再通过content-type来解析你返回的内容,呈现给用户。

那么我们来看,我们先假设你的首页中有100张图片,此时,用户的看似一次http请求,其实并不是一次,用户在第一次访问的时候,浏览器中不会有缓存,你的100张图片,浏览器要连着请求100次http请求(有人会跟我说http长连短连的问题,不在这里讨论),你的服务器接收这些请求,都需要耗费内存去创建socket来玩tcp传输(消耗你服务器上的计四、JSP的痛点

以前的javaWeb项目大多数使用jsp作为页面层展示数据给用户,因为流量不高,因此也没有那么苛刻的性能要求,但现在是大数据时代,对于互联网项目的性能要求是越来越高,因此原始的前后端耦合在一起的架构模式已经逐渐不能满足我们,因此我们需要需找一种解耦的方式,来大幅度提升我们的负载能力。

1、动态资源和静态资源全部耦合在一起,服务器压力大,因为服务器会收到各种http请求,例如css的http请求,js的,图片的等等。一旦服务器出现状况,前后台一起玩完,用户体验极差。

2、UI出好设计图后,前端工程师只负责将设计图切成html,需要由java工程师来将html套成jsp页面,出错率较高(因为页面中经常会出现大量的js代码),修改问题时需要双方协同开发,效率低下。

3、jsp必须要在支持java的web服务器里运行(例如tomcat,jetty,resin等),无法使用nginx等(nginx据说单实例http并发高达5w,这个优势要用上),性能提不上来。

4、第一次请求jsp,必须要在web服务器中编译成servlet,第一次运行会较慢。

5、每次请求jsp都是访问servlet再用输出流输出的html页面,效率没有直接使用html高(是每次哟,亲~)。

6、jsp内有较多标签和表达式,前端工程师在修改页面时会捉襟见肘,遇到很多痛点。

7、如果jsp中的内容很多,页面响应会很慢,因为是同步加载。

8、需要前端工程师使用java的ide(例如eclipse),以及需要配置各种后端的开发环境,你们有考虑过前端工程师的感受吗。

基于上述的一些痛点,我们应该把整个项目的开发权重往前移,实现前后端真正的解耦!

五、开发模式

以前老的方式是:

1、产品经历/领导/客户提出需求

2、UI做出设计图

3、前端工程师做html页面

4、后端工程师将html页面套成jsp页面(前后端强依赖,后端必须要等前端的html做好才能套jsp。如果html发生变更,就更痛了,开发效率低)

5、集成出现问题

6、前端返工

7、后端返工

8、二次集成

9、集成成功

10、交付

新的方式是:

1、产品经历/领导/客户提出需求

2、UI做出设计图

3、前后端约定接口&数据&参数

4、前后端并行开发(无强依赖,可前后端并行开发,如果需求变求变更,只要接口&参数不变,就不用两边都修改代码,开发效率高)

5、前后端集成

6、前端页面调整

7、集成成功

8、交付

六、请求方式

以前老的方式是:

1、客户端请求

2、服务端的servlet或controller接收请求(后端控制路由与渲染页面,整个项目开发的权重大部分在后端)

3、调用service,dao代码完成业务逻辑

4、返回jsp

5、jsp展现一些动态的代码

新的方式是:

1、浏览器发送请求

2、直接到达html页面(前端控制路由与渲染页面,整个项目开发的权重前移)

3、html页面负责调用服务端接口产生数据(通过ajax等等,后台返回json格式数据,json数据格式因为简洁高效而取代xml)

4、填充html,展现动态效果,在页面上进行解析并操作DOM。

总结一下新的方式的请求步骤:

大量并发浏览器请求--->web服务器集群(nginx)--->应用服务器集群(tomcat)--->文件/数据库/缓存/消息队列服务器集群

同时又可以玩分模块,还可以按业务拆成一个个的小集群,为后面的架构升级做准备。

七、前后分离的优势

1、可以实现真正的前后端解耦,前端服务器使用nginx。前端/WEB服务器放的是css,js,图片等等一系列静态资源(甚至你还可以css,js,图片等资源放到特定的文件服务器,例如阿里云的oss,并使用cdn加速),前端服务器负责控制页面引用&跳转&路由,前端页面异步调用后端的接口,后端/应用服务器使用tomcat(把tomcat想象成一个数据提供者),加快整体响应速度。(这里需要使用一些前端工程化的框架比如nodejs,react,router,react,redux,webpack)

2、发现bug,可以快速定位是谁的问题,不会出现互相踢皮球的现象。页面逻辑,跳转错误,浏览器兼容性问题,脚本错误,页面样式等问题,全部由前端工程师来负责。接口数据出错,数据没有提交成功,应答超时等问题,全部由后端工程师来解决。双方互不干扰,前端与后端是相亲相爱的一家人。

3、在大并发情况下,我可以同时水平扩展前后端服务器,比如淘宝的一个首页就需要2000+台前端服务器做集群来抗住日均多少亿+的日均pv。(去参加阿里的技术峰会,听他们说他们的web容器都是自己写的,就算他单实例抗10万http并发,2000台是2亿http并发,并且他们还可以根据预知洪峰来无限拓展,很恐怖,就一个首页。。。)

4、减少后端服务器的并发/负载压力。除了接口以外的其他所有http请求全部转移到前端nginx上,接口的请求调用tomcat,参考nginx反向代理tomcat。且除了第一次页面请求外,浏览器会大量调用本地缓存。

5、即使后端服务暂时超时或者宕机了,前端页面也会正常访问,只不过数据刷不出来而已。

6、也许你也需要有微信相关的轻应用,那样你的接口完全可以共用,如果也有app相关的服务,那么只要通过一些代码重构,也可以大量复用接口,提升效率。(多端应用)

7、页面显示的东西再多也不怕,因为是异步加载。

8、nginx支持页面热部署,不用重启服务器,前端升级更无缝。

9、增加代码的维护性&易读性(前后端耦在一起的代码读起来相当费劲)。

10、提升开发效率,因为可以前后端并行开发,而不是像以前的强依赖。

11、在nginx中部署证书,外网使用https访问,并且只开放443和80端口,其他端口一律关闭(防止黑客端口扫描),内网使用http,性能和安全都有保障。

12、前端大量的组件代码得以复用,组件化,提升开发效率,抽出来!

八、注意事项

1、在开需求会议的时候,前后端工程师必须全部参加,并且需要制定好接口文档,后端工程师要写好测试用例(2个维度),不要让前端工程师充当你的专职测试,推荐使用chrome的插件postman或soapui或jmeter,service层的测试用例拿junit写。ps:前端也可以玩单元测试吗?

2、上述的接口并不是java里的interface,说白了调用接口就是调用你controler里的方法。

3、加重了前端团队的工作量,减轻了后端团队的工作量,提高了性能和可扩展性。

4、我们需要一些前端的框架来解决类似于页面嵌套,分页,页面跳转控制等功能。(上面提到的那些前端框架)。

5、如果你的项目很小,或者是一个单纯的内网项目,那你大可放心,不用任何架构而言,但是如果你的项目是外网项目,呵呵哒。

6、 以前还有人在使用类似于velocity/freemarker等模板框架来生成静态页面,仁者见仁智者见智。

7、这篇文章主要的目的是说jsp在大型外网java web项目中被淘汰掉,可没说jsp可以完全不学,对于一些学生朋友来说,jsp/servlet等相关的java web基础还是要掌握牢的,不然你以为springmvc这种框架是基于什么来写的?

8、如果页面上有一些权限等等相关的校验,那么这些相关的数据也可以通过ajax从接口里拿。

9、对于既可以前端做也可以后端做的逻辑,我建议是放到前端,为什么?因为你的逻辑需要计算资源进行计算,如果放到后端去run逻辑,则会消耗带宽&内存&cpu等等计算资源,你要记住一点就是服务端的计算资源是有限的,而如果放到前端,使用的是客户端的计算资源,这样你的服务端负载就会下降(高并发场景)。类似于数据校验这种,前后端都需要做!

10、前端需要有机制应对后端请求超时以及后端服务宕机的情况,友好的展示给用户。

九、扩展阅读

1、其实对于js,css,图片这类的静态资源可以考虑放到类似于阿里云的oss这类文件服务器上(如果是普通的服务器&操作系统,存储在到达pb级的文件后,或者单个文件夹内的文件数量达到3-5万,io会有很严重的性能问题),再在oss上配cdn(全国子节点加速),这样你页面打开的速度像飞一样, 无论你在全国的哪个地方,并且你的nginx的负载会进一步降低。

2、如果你要玩轻量级微服务架构,要使用nodejs做网关,用nodejs的好处还有利于seo优化,因为nginx只是向浏览器返回页面静态资源,而国内的搜索引擎爬虫只会抓取静态数据,不会解析页面中的js,这使得应用得不到良好的搜索引擎支持。同时因为nginx不会进行页面的组装渲染,需要把静态页面返回到浏览器,然后完成渲染工作,这加重了浏览器的渲染负担。浏览器发起的请求经过nginx进行分发,URL请求统一分发到nodejs,在nodejs中进行页面组装渲染;API请求则直接发送到后端服务器,完成响应。

3、如果遇到跨域问题,spring4的CORS可以完美解决,但一般使用nginx反向代理都不会有跨域问题,除非你把前端服务和后端服务分成两个域名。JSONP的方式也被淘汰掉了。

4、如果想玩多端应用,注意要去掉tomcat原生的session机制,要使用token机制,使用缓存(因为是分布式系统),做单点,对于token机制的安全性问题,可以搜一下jwt。

5、前端项目中可以加入mock测试(构造虚拟测试对象来模拟后端,可以独立开发和测试),后端需要有详细的测试用例,保证服务的可用性与稳定性。

十、总结

前后端分离并非仅仅只是一种开发模式,而是一种架构模式(前后端分离架构)。千万不要以为只有在撸代码的时候把前端和后端分开就是前后端分离了,需要区分前后端项目。前端项目与后端项目是两个项目,放在两个不同的服务器,需要独立部署,两个不同的工程,两个不同的代码库,不同的开发人员。

前后端工程师需要约定交互接口,实现并行开发,开发结束后需要进行独立部署,前端通过ajax来调用http请求调用后端的restful api。前端只需要关注页面的样式与动态数据的解析&渲染,而后端专注于具体业务逻辑。

4、如果想玩多端应用,注意要去掉tomcat原生的session机制,要使用token机制,使用缓存(因为是分布式系统),做单点,对于token机制的安全性问题,可以搜一下jwt。


最近无意中发现了一个巨牛的人工智能教程,忍不住分享一下给大家。教程不仅是零基础,通俗易懂,而且非常风趣幽默,像看小说一样!觉得太牛了,所以分享给大家。点下面链接可以跳转到教程。

https://www.captainbed.net/suga

者 | 六小登登

责编 | 屠敏

从 2013 年专科毕业开始,一路跌跌撞撞走了很多弯路,做过餐厅服务员,进过工厂干过流水线,做过客服,干过电话销售可以说经历相当的“丰富”。

最后的机缘巧合下,走上了前端开发之路,作为一个非计算机专业且低学历的人来说,自学编程其实不是件容易的事情,不过庆幸的是自己坚持下来了。

目前工作还算不错,收入在目前所在的城市不算高,不算低,生活也还过得去,继续加油努力,也希望自己在今后更上一层。

从 2016 年下半年开始,我真正接触前端,到现在 2 年多的时间。开始之初,我没有任何的语言基础,完全从零的小白开始,就连「对象」我都弄不明白,更别说那些高深莫测的什么封装、继承、多态等。

当时自己也不知从何入手,怎么办呢?于是每当自己遇到困难时,就厚着脸皮去请教前辈大牛,然后就是去查阅资料,很多时候自己也很觉得不好意思,现在才发现人很多时候都耻于相别人请教,怕自己丢面子。

但作为一个过来人,我要告诉你请教前辈大牛真的很重要,可以让你少走很多的弯路,不要怕丢人,没面子,面子值几个钱?学到真本事才最重要。没有技能才叫真的没有面子。当然了我们在请教别人时,一定要掌握「度」,不要打扰到了别人的工作。

我现在非常感谢前辈们的赐教,也感谢那些在网上写博客、文章分享的大牛们,给了我们这些自学的小白很多的资料,经验,心得。从中受益很多。

向优秀的前辈们学习,我开始写博客,希望也能帮到和我一样,学渣、从零开始、喜欢技术的一群志同道合的人。

我深知自己的技术并不高,还处在继续学习的路上,离大牛还差的很远,我本身也非常敬畏技术,也知道自己的渺小,只希望这篇文章的「学习之路」对于那些「从零开始」学习前端的同学有一些指引作用,不像自己一开始那样的那么盲目,哪怕对你有一点点的帮助,就足够了。

说了这么多,下面我们直接进入正题,都是我平时学习和收集的一些资料希望能够帮到你。

前言

  1. 首先我得告诉你,自学是件很苦的事情,学习本身就是件反人性的过程,更何况在一个从零开始的全新领域独自奋斗,这里不是要打击你,而是要你认真想好,结合自身的环境、条件。不然半途而废浪费的不仅是时间,还有精力、金钱。
  2. 如果你已经想好决定去做,那就不要犹豫,坚持下去你就可以成功,像我这样的学渣都可以,你没有什么不可以的,一定要相信自己。
  3. 兴趣是最好的老师,很多人对这句话非常反感,被生活所迫,谈兴趣不可笑吗?其实不是,问问自己对技术有没有兴趣,做自己喜欢和感兴趣的事情才能够走的更远和更久,很多人不理解这一点,总有一天你会明白的,我当时转前端的时候也是因为自己挺喜欢,而且最接近用户,都是所见所得的东西很好玩,另外一方面也觉得工资也挺高,所以自己打心里觉得做前端挺好。
  4. 做好持续学习,时刻保持学习的心态,说实话现在社会,科技的发展非常之快,技术的更新更是如此,如果你觉得学习一门技术就可以吃到老,我劝你还是打住,可能考个公务员更适合你(不要杠精,我并不是说公务员不要学习,自己体会就好)。
  5. 永远不要觉得迟,只要行动然后坚持下去,你就干掉了 80% 的人,自学的人很多,但是坚持下来的没有几个。就像郭德纲说过,不是我的相声说的多好而是我活了下来。著名营销人员「小马宋」毕业时烧了很多年的锅炉,但是自己对广告营销感兴趣,所以离职从零开始,现在已经是很有名的营销大师。
  6. 与其把时间花在学与不学的纠结上,不如把这个时间放在行动上,如果发现自己不合适也坚持不下去,那就换个赛道,专注的去做一件事情,会提高你的成功概率。

工具篇

工欲善其事,必先利其器,所以在开始之前选择一个合适好用的编辑器是很重要的,工具不再多,在于好用就行,除了编辑器,我们也要掌握其他的一些工具,才能够让我们在学习的道路上更加的顺畅。

1. WebStorm

不必多说,前端最强大的编辑器,特别是那无敌的智能提示,但是它的缺点在于如果项目多于大时,出现的卡顿让很多人苦恼。

  • WebStorm 官网下载地址:https://www.jetbrains.com/webstorm/。
  • WebStorm 有哪些过人之处?(https://www.zhihu.com/question/20936155)
  • 激活 WebStorm2018(https://blog.csdn.net/qq_32135281/article/details/82696280)

2. Visual Studio Code

微软开源免费产品,受到非常多技术人员的喜爱,基本上成为前端开发者的必备编辑器,强大的插件扩展,可以灵活的打造自己喜欢的风格。给你们送上常用插件列表拿走不谢。

  • Visual Studio Code 官网下载地址:https://code.visualstudio.com/。
  • VSCode 拓展推荐:https://github.com/varHarrie/varharrie.github.io/issues/10
  • 使用顶级 VSCode 扩展来加快开发 JavaScript:https://www.html.cn/archives/9507
  • vscode 插件推荐:https://segmentfault.com/a/1190000006697219

3. atom

也是一款免费开源的编辑器,受到很多人的喜爱,但是我本人用的较少,所以插件方面就不推荐了,大家可以按照自己的爱好去寻找。

4. 科学上网

每个程序员都应该具备的工具和能力,否则很多事情都无法办到,至于怎么做,你可以自己查阅资料,这里不就不在多说了。而且下面推荐的很多资源都是需要科学上网之后才能访问,所以一定要学会。

5. Google

在使用「Google」之前必须学会科学上网,不然无法访问,学会使用搜索可以帮助我们解决很多问题,一个人的知识是有限的,掌握了搜索的技巧才能以不变应万变,很多时候百度出来的东西重复性很大,最重要的是垃圾信息很多,在百度找不到的答案,在这里很容易找到,Google 是我的必备搜索。

6. Github

全球最大的「同性」开源交流社区,没有账号的赶紧注册,在这有很多优秀的资源项目,各种大神。观摩优秀代码是我们学习的很好路径。另外在开发过程中,很多时候任务重、时间紧,应该避免重复造轮子,这里能够找到你需要的工具或代码。

7. Stack Overflow

国外著名的技术问答交流社区,开发时碰到的很多问题在这里都能找到答案。

8. SegmentFault

对应的国内版的技术问答交流社区,如果你英文不好,也可以在这里找找答案。

9. Markdown

Markdown 轻量级标记语言,简洁的语法,让作者专注内容而非复杂的格式要求,我认为人人都应该掌握,特别是经常写博客的人。想想你在用 world 时的场景,每次写完文章之后,不得不话费很多时间进行格式的排版,使用它你就可以避免这些烦恼。

  • Markdown 中文文档:https://markdown-zh.readthedocs.io/en/latest/

HTML 篇

一些准备就绪之后,开始我们的学习之旅,首先我们先从 HTML 开始。

HTML名为「超文本标记语言」,是整个页面的结构基础,它承载了我们的页面内容。

1. 基础

  • w3school 在线教程(http://www.w3school.com.cn/h.asp):内容非常的基础,适合小白学习,对 HTML 有一个入门了解。
  • freeCodeCamp(https://www.freecodecamp.cn/):一个非常好的入门学习网站,采用闯关的模式,就像游戏打怪升级一样,非常的有乐趣,准备自学的小伙伴不妨试试。

2. 进阶

  • MDN HTML(https://developer.mozilla.org/zh-CN/docs/Web/HTML):这里的内容质量更好,错误更少,内容也更加的全面。
  • HTML 和 CSS 编码规范(https://codeguide.bootcss.com/):掌握一些代码技巧,写出更好,更高质量的代码。

CSS 篇

HTML 承载了页面的内容,但是有时候会略显单调与「丑陋」,CSS 的作用就是为这些内容加上样式,就像一个美女也要有漂亮的外衣去修饰才会更加漂亮,「人靠衣装马靠鞍」,网页的内容也是需要穿上一件漂亮的外衣去吸引用户。而 CSS 则完成了这个装饰。

1. 基础

  • 学习 CSS 布局(http://zh.learnlayout.com/):带你一步一步的完成 CSS 的学习。
  • CSS 参考手册(https://css.doyoe.com/):对CSS可以有一个全面入门的学习。
  • w3school CSS 参考手册(http://www.w3school.com.cn/cssref/index.asp):同上也是非常基础的知识,适合入门。

2. 进阶

书籍:

《CSS揭秘》(https://book.douban.com/subject/26745943/):非常推荐的一本 CSS 书籍,可以学到很多鲜为人知的技巧。

在线系列:

  • MDN CSS(https://developer.mozilla.org/zh-CN/docs/Web/CSS):和 HTML 都是 MDN 社区文档,质量保障。
  • HTML和CSS编码规范(https://codeguide.bootcss.com/):掌握一些代码技巧,写出更好,更高质量的代码。
  • 大漠老师的CSS系列(https://www.w3cplus.com/CSS3):大漠老师对CSS有非常深入的认识和丰富的实践经验,《图解CSS3:核心技术与案例实战》的作者。
  • 大漠老师的SASS系列(https://www.w3cplus.com/blog/tags/302.html):大漠老师的 sass 文章系列。
  • SASS中文网(https://www.sasscss.com/):成熟、稳定、强大的 CSS 扩展语言解析器,它可以让你使用变量,条件语句等书写 CSS。
  • Stylus官网(https://stylus.bootcss.com/):同样是 CSS 预编译器,但它省去了一些符号,让 CSS 写起来更加的简洁,清爽。
  • HTML5和CSS3(https://github.com/qianguyihao/Web/tree/master/07-HTML5%E5%92%8CCSS3):详解HTML5 和 CSS3。

知识点:

  • 别说你懂CSS相对单位(http://wuyuying.com/blog/archives/css-in-depth-relative-units/):深入了解 CSS 的相对单位rem,em区别。
  • CSS 进阶内容(https://github.com/coconilu/Blog/issues/29):常见知识点的深入了解。
  • Flex 布局教程:语法篇(http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html):阮一峰老师的flex讲解。
  • Flex 布局教程:实例篇(http://www.ruanyifeng.com/blog/2015/07/flex-examples.html):阮一峰老师的flex讲解。
  • “CSS相关”目录存档(https://www.zhangxinxu.com/wordpress/category/css/):张鑫旭大佬的CSS系列文章,深入浅出,《CSS世界》作者。
  • CSS绘制的40种形状和图形(http://www.open-open.com/lib/view/open1476240478941.html):利用CSS绘制出的40各种图形形状。
  • CSS-大前端(http://www.daqianduan.com/tag/css):一些 CSS 的知识点。

JavaScript 篇

有了 HTML 与 CSS,网页也就有了内容和样式,但是会缺少与用户的互动,所有的内容都静静的躺在那里死气沉沉。就好比一个美女穿着漂亮的衣服在你面前一动不动好像也没有什么吸引力,但如果又唱歌,又跳舞,还向你抛媚眼,那可真就把持不住了。JavaScript 就是给网页添加这样的「行为」。

Javascript 简史(https://blog.csdn.net/qq_32135281/article/details/81667714):可以简单了解下,JavaScript 发展由来。

1. 基础

书籍

  • 《JavaScript权威指南 (第6版)》(https://book.douban.com/subject/10549733/):俗称「犀牛书」,JS 的经典之作,提升JS技能的必备书籍,我的JS基础知识全都是啃这本书啃下来的,刚开始读时可能有会有些吃力,但是只要坚持下来收获满满。
  • 《JavaScript高级程序设计(第3版)》(https://book.douban.com/subject/10546125/):俗称「红宝书」,JavaScript 超级畅销书,全书阐述了JavaScript语言实现的各个组成部分,ECMAScript,DOM,BOM,事件,面向对象等等,随时拿出来翻翻,更加深入了学习 JS。

在线系列

除了书籍之外,也有很多优秀的在线教程,可以帮助我们更好的学习。

  • 现代 Javascript 教程(https://zh.javascript.info/):非常全面的JavaScript 学习教程,从基础到高阶,非常详细,相信你会爱上它的。
  • 廖雪峰的JavaScript教程(https://www.liaoxuefeng.com/wiki/001434446689867b27157e896e74d51a89c25cc8b43bdb3000):廖雪峰系列教程。
  • JavaScript 标准参考教程(alpha)(https://javascript.ruanyifeng.com/):阮一峰老师的系列教程,通俗易懂,案例丰富。

2. 进阶

  • JavaScript语言精粹(https://github.com/qibaoguang/Study-Step-by-Step/blob/master/%E8%AF%BB%E4%B9%A6%E7%AC%94%E8%AE%B0/javascript_the_good_parts.md):揭示JavaScript中的精华。
  • JavaScript 秘密花园(http://bonsaiden.github.io/JavaScript-Garden/zh/#other.timeouts):对 JS 一些的核心知识点进行梳理讲解,例如:this,闭包/作用域,构造函数,原型等等,都是面试必考知识点。
  • ECMAScript 6 入门(http://es6.ruanyifeng.com/):阮一峰老师ES6入门书籍,全面介绍 ECMAScript 6 新引入的语法特性。
  • JavaScript使用技巧(http://www.jstips.co/zh_CN/):可以认识到一些你平时没有接触过的小技巧。
  • 深入理解javascript原型和闭包系列(http://www.cnblogs.com/wangfupeng1988/p/4001284.html):详细解释了原型和闭包,看完之后对原型与闭包让你彻底明白。
  • 大漠老师的JavaScript系列(https://www.w3cplus.com/JavaScript):大漠老师的JavaScript系列文章。
  • JavaScript 算法与数据结构(https://github.com/trekhleb/javascript-algorithms/blob/master/README.zh-CN.md):基于 JavaScript 的算法与数据结构,让你愉快的学习。
  • JavaScript中的正则表达式(https://blog.csdn.net/qq_32135281/article/details/78274563):我自己的一篇正则表达式的文章,希望对你有帮助。
  • 30分钟掌握ES6/ES2015核心内容(上)(https://segmentfault.com/a/1190000004365693)
  • 30分钟掌握ES6/ES2015核心内容(下)(https://segmentfault.com/a/1190000004368132):阐述了一些常用的ES6的知识点。
  • 学用 JavaScript 设计模式(https://www.oschina.net/translate/learning-javascript-design-patterns):阐述JavaScript编程语言中经典和现代的设计模式。
  • 你不懂JS(系列丛书)(https://github.com/getify/You-Dont-Know-JS/tree/1ed-zh-CN)
  • InterviewMap(https://yuchengkai.cn/docs/frontend/#%E5%86%85%E7%BD%AE%E7%B1%BB%E5%9E%8B):聚集了很多知识点,包括JS,浏览器,性能等。
  • 30 秒就能理解的 JavaScript 代码片段(https://www.html.cn/30-seconds-of-code/):让你更好的理解一些有用的JS代码片段。

TypeScript篇

ES6 的超集扩展,严格的数据类型,带来更好的维护,适合大型项目的开发工作,有人说它是未来的发展趋势,你说要不要了解?

  • TypeScript 中文手册(https://typescript.bootcss.com/):官网翻译版。
  • TypeScript Handbook(中文版)(https://zhongsp.gitbooks.io/typescript-handbook/content/):中文版。
  • RxJS 中文文档(https://cn.rx.js.org/):中文官网。
  • 30 天精通 RxJS (01):認識 RxJS(https://ithelp.ithome.com.tw/articles/10186104):繁体字可能阅读起来并没有那么顺畅。

Jquery篇

虽说现在已经是单页面应用时代,有React,Vue 这种强大的框架可以使用,但也不缺乏一些老的项目需要维护,而且在学习之初,可以用它做两个简单的应用还是不错的,可以相对了解下基本用法,它可以让你更好,更方便的操作DOM。但不建议再深度学习。

  • 《锋利的jQuery(第2版)》(https://book.douban.com/subject/10792216/):一本很不错的 Jquery 学习书籍。
  • jQuery API中文文档(https://www.jquery123.com/):JQuery 中文教程。

Ajax篇

掌握了的HTML、CSS、JavaScript时,这时候可以尝试自己做一些项目了,而项目中肯定会有数据的交互,这时候就是 Ajax 的用武之地了。

  • 廖雪峰AJAX(https://www.liaoxuefeng.com/wiki/001434446689867b27157e896e74d51a89c25cc8b43bdb3000/001434499861493e7c35be5e0864769a2c06afb4754acc6000):廖雪峰大佬的博客知识。
  • XMLHttpRequest 对象(https://wangdoc.com/javascript/bom/xmlhttprequest.html):阮一峰老师的AJAX详解。
  • JSON风格指南(https://github.com/liuxiaodeng/free-programming-books/blob/master/free-programming-books-zh.md#javascript):前后端的交互数据通常都是 JSON 格式,所以了解 JSON 是必要的。

NodeJS与模块化

NodeJs 的出现让前端发展进入了一个新的领域,并且滋生出专业的 Node 工程师,不仅如此 Node 在前端模块化,工程化起到很重要的作用,所以了解是必须的,如果感兴趣的可以深入学习,可以向全栈工程师发展。

  • Javascript模块化编程(一)(http://www.ruanyifeng.com/blog/2012/10/javascript_module.html):模块的写法
  • Javascript模块化编程(二):AMD规范
  • Javascript模块化编程(三):require.js的用法
  • 前端模块化开发那点历史(https://github.com/seajs/seajs/issues/588):了解下,前端模块化的发展。
  • Node.js 官方(https://nodejs.org/zh-cn/)
  • 狼叔:如何正确的学习Node.js(https://github.com/i5ting/How-to-learn-node-correctly):狼叔江湖地位颇高,《更了不起的 Node.js》的作者。
  • 全栈工程师之路-Node.js(http://i5ting.github.io/nodejs-fullstack/)

框架篇

随着日益复杂的用户需求,与系统的复杂度上升,传统的开发模式日渐的很难满足,此时的三大框架孕育而生,让开发者更加高效,可复用,把关注点都放在数据层的操作,免去那些繁琐而又重复的视图操作。

现在框架的能力已经是前端开发人员必备的技能之一也是趋势,三大框架的「最终目的」都是一致的,我认为开发者不必纠结于到底应该选择哪一个学习,可以选择其中的两个是最好的。对于刚入门的人来说,建议选择 Vue 入手,比较简单,灵活。

  • MVC,MVP 和 MVVM 的图示(http://www.ruanyifeng.com/blog/2015/02/mvcmvp_mvvm.html):在学习框架之前,你应该了解下MVVM的设计思想。
  • 框架原理(https://yuchengkai.cn/docs/frontend/framework.html):了解一些框架的基本原理。

1. Angular

  • Angular(https://angular.cn/):Angular官方社区。
  • Angular开发者(http://www.ngfans.net/):大漠穷秋老师维护的站点,Angular中国布道者。
  • NG-ZORRO(https://ng.ant.design/docs/introduce/zh#%E8%AE%BE%E8%AE%A1%E8%A7%84%E8%8C%83):Angular UI 组件库,阿里巴巴出品。

2. Vue

  • Vue(https://cn.vuejs.org/index.html):官网,最好的学习资料。
  • 我的Vue进阶之路(https://blog.csdn.net/qq_32135281/column/info/29689)
  • 使用vue全家桶制作博客网站(https://www.cnblogs.com/xiaohuochai/p/9228543.html)
  • Element(http://element-cn.eleme.io/#/zh-CN):一个高质量的 Vue UI 组件库。饿了么前端团队出品。
  • Vue 项目里戳中你痛点的问题及解决办法(更新)(https://juejin.im/post/5b174de8f265da6e410e0b4e):做项目难免回去到坑,这里你或许可以找到答案。

3. React

React我了解不多,所以就没什么好推荐的了,大家可自行学习。

  • React官网(https://www.reactjscn.com/)

图形可视化

随着日益增长的数据,如何利用高效的利用数据,是每个企业都考虑的问题,而人的眼睛看到的东西要胜过阅读的问题,俗话说「一图胜千言」就是这个道理,所以数据的可视化就会格外的重要,以下都是我常看的一些技术,书籍,和关注的可视化开源库。

  • 《HTML5 Canvas核心技术》(https://book.douban.com/subject/24533314/):学习 Canvas 比较好的一本书籍。
  • Canvas系列(https://www.w3cplus.com/search/node/canvas):大漠老师的 Canvas 系列。
  • Echarts(https://www.echartsjs.com/index.html)
  • D3(https://d3js.org/)
  • Highcharts(https://www.highcharts.com.cn/)
  • AntV(https://antv.alipay.com/zh-cn/index.html)
  • Mapv(https://mapv.baidu.com/)

工程化与版本控制篇

1. Git

版本控制工具,很多新手往往把 git 与 github 傻傻分不清楚,二者是不同的东西,一定要去区分清楚。

  • Git教程(https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000):廖雪峰老师的教程。
  • Learn Git Branching(https://learngitbranching.js.org/):一种有趣的学习 Git 的方式。
  • GitHub 漫游指南(https://github.com/phodal/github):作者是一个极客。
  • git - 简易指南:http://www.bootcss.com/p/git-guide/

2. Gulp

自动化构建工具,项目打包部署前的压缩合并,节省时间,提高开发效率。

  • Gulp 中文网(https://www.gulpjs.com.cn/):官方教程。
  • gulp详细入门教程(http://www.ydcss.com/archives/18):非常详细的实现步骤。

3. Webpack

Webpack 是当下最热门的前端资源模块化管理和打包工具。它可以将许多松散的模块按照依赖和规则打包成符合生产环境部署的前端资源。

  • Webpack中文文档:https://www.webpackjs.com/
  • webpack原理:https://juejin.im/entry/5b0e3eba5188251534379615
  • Webpack揭秘——走向高阶前端的必经之路:https://juejin.im/post/5badd0c5e51d450e4437f07a
  • Webpack HMR 原理解析:https://zhuanlan.zhihu.com/p/30669007
  • webpack 热加载原理探索:http://shepherdwind.com/2017/02/07/webpack-hmr-principle/

4. Babel

JavaScript代码编译器,可以让ES6及以上语法转换成浏览器支持的语法,一般会在框架的脚手架中自行配置。

  • Babel(https://babel.bootcss.com/):官网教程。

5. 代码质量

  • ESLint(https://eslint.bootcss.com/):javascript代码检测工具帮助我们写出更规范的代码。

浏览器与HTTP

  • 浏览器的常见知识点(https://yuchengkai.cn/docs/frontend/browser.html):需要我们了解的常见知识。
  • 网站安全(https://yuchengkai.cn/docs/frontend/safety.html):几种常见安全问题。
  • 同源限制(https://wangdoc.com/javascript/bom/same-origin.html)
  • 从URL输入到页面展现到底发生什么?(https://github.com/ljianshu/Blog/issues/24)
  • 深入理解浏览器的缓存机制(https://github.com/ljianshu/Blog/issues/23)
  • 网页性能管理详解(http://www.ruanyifeng.com/blog/2015/09/web-page-performance-in-depth.html)
  • 关于Http协议,你必须要知道的(https://github.com/ljianshu/Blog/issues/22)
  • HTTP 协议(https://github.com/coconilu/Blog/issues/135)
  • HTTP2 协议(https://github.com/coconilu/Blog/issues/134)
  • 浏览器同源政策及其规避方法(http://www.ruanyifeng.com/blog/2016/04/same-origin-policy.html)
  • 跨域资源共享 CORS 详解(http://www.ruanyifeng.com/blog/2016/04/cors.html)
  • 总结 XSS 与 CSRF 两种跨站攻击(https://segmentfault.com/a/1190000004623125)

性能优化

  • 性能优化(https://yuchengkai.cn/docs/frontend/performance.html):常见性能优化。
  • 前端性能优化的七大手段(https://www.cnblogs.com/xiaohuochai/p/9178390.html)
  • 延迟加载(Lazyload)三种实现方式(https://zhuanlan.zhihu.com/p/25455672)
  • 详解懒加载和预加载(https://www.geekjc.com/post/58d94d0f16a3655650d6fafe)
  • 前端优化带来的思考,浅谈前端工程化(http://www.cnblogs.com/yexiaochai/p/4901341.html)
  • 推荐几本与Web性能优化有关的书籍(https://w3ctech.com/topic/108)
  • vue + webpack 前端性能优化(https://juejin.im/post/5bc5c106e51d450e7a253e1b)

SEO

  • SEO优化实战(https://imweb.io/topic/5682938b57d7a6c47914fc00)

博客系列

1. 个人

现在是一个信息爆炸的时代,网上有很多优秀的博客文章,每个人的精力都是有限的,不可能关注到所有的博客,每个人关注点可能不太一样,所以关注的个人博客也会不同,这些推荐几个我比较常看的几个高质量博客。而且是持续更新的。

  • 阮一峰的个人网站(http://www.ruanyifeng.com/home.html):阮一峰老师江湖地位不必多说,博客不止有技术,现在阿里任职。
  • 廖雪峰的官方网站(https://www.liaoxuefeng.com/):廖雪峰老师写过很多优秀的系列教程,值得去学习。
  • 张鑫旭(https://www.zhangxinxu.com/):专注前端技术的大牛之一,出版《css世界》一书。
  • W3cplus(https://www.w3cplus.com/):大漠老师在手淘任职,CSS,HTML 有着丰富的经验。
  • 前端入门和进阶学习笔记(https://github.com/qianguyihao/Web):从零开始自学,然后进入京东,记录作者一路走来的学习笔记。
  • 六小登登(https://blog.csdn.net/qq_32135281):我自己的个人博客,记录自己的一些学习总结,个人成长,认识思维,虽然自己还是个菜鸟,但一直在路上。

2. 团队

  • 奇舞周刊(https://weekly.75team.com/):收集每周前端精华文章。
  • 美团技术团队(https://tech.meituan.com/):分享一些美团的技术路线。
  • JavaScript Weekly(https://javascriptweekly.com/):每周都会分享一些 JavaScript 优质内容。
  • 印记中文周刊(https://weekly.docschina.org/):如果你对英文有阅读障碍的话,印记帮你翻译。
  • 凹凸实验室(https://aotu.io/index.html):京东团队。
  • 淘宝前端团队FED(http://taobaofed.org/):淘宝前端团队,不必多说了。
  • 网易FEG前端团队(http://feg.netease.com/):网易的前端团队,网易的产品一直都是我最喜欢的。
  • IMWeb前端博客(https://www.imweb.io/):腾讯公司前端团队,负责QQ的相关业务你就知道了,都是亿级别。
  • tutorialzine(https://tutorialzine.com/):高质量教程和文章库。

项目资源

  • 前端技能汇总(http://html5ify.com/fks/):一个前端工程师需要的技能点和学习资料。
  • You-need-to-know-css(https://lhammer.cn/You-need-to-know-css/#/):一个CSS的优质项目,纯 CSS 实现我们项目中很多常用,不常用的样式。
  • JavaScript libraries(https://www.javascripting.com/):一些优秀的JavaScript 开源库。
  • awesome-web-dev-books(https://github.com/jobbole/awesome-web-dev-books):前端经典学习书单。
  • 前端 TOP 100(https://www.awesomes.cn/rank):基本涵盖了所有前端在用的开源项目,我觉得收藏这一个就够了。

常用工具

  • CSS Sprites Generator(https://www.toptal.com/developers/css/sprite-generator):雪碧图的在线制作工具。
  • Lorem Picsum(https://picsum.photos/):好用的图片临时占位符。
  • Md2All(http://md.aclickall.com/):优秀的现在 Markdown 编辑器。
  • 优波设计(https://ubuuk.com/):优秀的设计导航网站,帮助你更好的寻找资料。
  • 搬书匠(http://www.banshujiang.cn/):书籍搜索下载。
  • 史莱姆导航(http://www.slimegps.cn/):资源搜索。
  • codePen(https://codepen.io/):在线代码编辑工具。
  • Iconfont(https://www.iconfont.cn/):阿里的字体图标库,支持多种格式,下载图片,在线使用,SVG等等。
  • Can I use(https://www.caniuse.com/):可以查看浏览器兼容 CSS 情况。
  • 在线工具(https://tool.lu/):工具资源导航。

最后

以上是我这两年多一路走来收藏的一些资料,整理这份资料也花了我好几天的时间,希望能够在自学的道路上帮到你。

再次声明,我并不是什么大神,我自认为技术也没有到达这个层级,但是我会一直坚持学下去,另外一定不要误会这里面的知识我全部都会,这些都是我学习的一些资料想整理出来,免去小白的一些不知道如何查阅资料。

这里的资源可能并不适合每一个人,你也不一定全部都需要,只需要挑选自己想要的部分就行,任何事情并不是越多越好。

作者:六小登登,个人公众号:六小登登(ID:liuxiaodengdeng)。目前在某创业公司任职前端开发工作,近 3 年前端开发经验,爱技术、爱写作、爱分享。

声明:本文为作者投稿,版权归其个人所有。