从Java的角度看前端JS各种框架

今天看到一篇不错的文章:

从Java的角度理解前端框架,nodejs,reactjs,angularjs,requirejs,seajs

http://blog.csdn.net/uikoo9/article/details/45999745

(PS:还有另一篇文章也可以看看:http://uikoo9.com/blog/detail/fe web前端漫谈-uikoo9.com)

文章内容如下:

【前端神秘的面纱】
对后端开发来说,前端是神秘的,

眼花缭乱的技术,繁多的框架,

如果你还停留在前端等于只用jQuery做开发,那么你out了,

本文从Java的角度简述下目前前端流行的一些框架。

水平有限,欢迎指正。

【nodejs】
官网:
https://nodejs.org/

简介:
对前端来说极其重要的一个“框架”,简直可以说是开天辟地

类比Java中:JVM

详述:
就前端来说nodejs具有划时代的意义,

做前端的没用过nodejs都不好意思说自己是前端,

做后端的没听过nodejs,

或者说不出nodejs和java的优缺点,也不是一个合格的后端。

nodejs不是一个js框架,千万不要认为是类似jquery的框架,

nodejs是js运行时,运行环境,类比java中jvm,

java的开端是什么,无疑是jvm,自从有了jvm,java才能吹牛说自己是“一次编写处处运行”,

不管你是windows还是linux,只要安装了对应版本的jvm都可以运行.class文件。

同样nodejs的作用和jvm的一样一样的,也是js的运行环境,不管是你是什么操作系统,

只要安装对应版本的nodejs,那你就可以用js来开发后台程序。

这具有划时代的意义,意味着一直以来只能在浏览器上玩来玩去的js,可以做后端开发了,

从有了nodejs后就催生出一大批用js做后台开发的前端人员,这部分人员就是偏前端的“全栈程序员”。

记住,nodejs是和jvm同等地位的js运行环境,打开了前端人员走向后端的道路。
1.png

【js mvc框架】
相关框架:
框架太多,详见下面两篇文章

私人定制,十款最佳Node.js MVC框架

基于NodeJS的14款Web框架

类比Java中的:
ssh1(struts1+spring+hibernate),ssh2(struts2+spring+hibernate),ssm(springmvc+spring+mybatis)

详述:
上面说到nodejs打开了前端开发人员开发后端的大门,而且nodejs类比jvm,

那么学习java的人都知道,学习完jvm(基础)后该学什么了?

对,框架,

java中有哪些框架,正如上面所说,ssh1,ssh2,ssm等等,

这些框架都mvc框架。

既然nodej都有了,jvm出现了,那接下来就是js大神开始封装mvc框架,正如java大神开始封装mvc框架一样,

相对java流行了几种框架,nodejs对应的mvc框架就多的多了,

详见上面两篇文章,足够让你看的眼花缭乱。

其中比较有名的是expressjs。

记住,当你看到这些js框架的时候,微微一笑,原来就是写mvc框架,基于nodejs:
Sails. js,Total.js,Partial.js,Koa. js,Locomotive. js,Express. js,Flatiron. js
2.png

【js模块化】
相关概念:
commonjs,amd,cmd,umd

相关框架:
commonjs,seajs,requirejs,coolie

类比Java中的:
import,对就是import。。

详述:
如上所说,当有了nodejs(jvm),有了mvcjs(ssh)之后,

可想而知,每个mvcjs中会有多少js文件,这个时候js模块化就派上用处了,

当有人和你说js模块化如何如何,感觉自己很吊的时候,甩他一句,不就是java中的import吗?

对,虽然在前端看来js模块化如何牛x,如何吊,但是就java来说就是import。

看看下面两张图片就明白了,对比requirejs(amd)和java导包:

1.png

2.png

但是js中的模块化,还有很多规范,比如commonjs,amd,cmd,umd,感觉头大了吧,

其实简单的来说,就是commonjs是运行在nodejs端,amd,cmd,umd是运行在浏览器,

其作用就是import各种js文件,把js模块化管理,可以理解为java中的包管理,

详见这篇文章:http://coolie.ydr.me/introduction/commonjs-amd-cmd-umd.html 

同样,一个mvc,js能做出来10+种框架,可想而知模块化,js也对应很多框架,

例如commonjs,requirejs,seajs等等。

记住,commonjs,requirejs,seajs等js模块化框架,遵循各种规范(amd,cmd,umd,commonjs),
类比java中的import
3.png

【reactjs】
官网:
http://facebook.github.io/react/

简介:
facebook前不久出的一款框架,众前端膜拜之。

类比Java中的:freemarker的宏。

详述:
facebook前不久出了一款js框架,reactjs,

一时间,凡是用过reactjs,或者听过reactjs的前端开发就高人一等,

那么,这个框架到底是干嘛的,我们来看看官网的一个例子:

5.png

好的,看不懂没关系,我来说说,

左边是一段代码,右边是这段代码在网页中的效果,

左边代码中上面一大段是定义,最后一句话是使用,

左边代码jsx是reactjs的格式,旁边有个compiled js是jsx编译后的js,原生js。

也就是说,你通过写jsx文件,编译后生成一段js文件,这段js文件运行后是右边的效果,

那么好处是什么?

是封装,一大段js定义,最后只需要一句话输出,也就是一行js代码对应右边一个ui组件。

对了reactjs最大的作用就是用来开发ui组件,例如这个:http://material-ui.com/#/components/dropdown-menu
很酷的效果,material ui风格的webui组件,基于reactjs开发的。

做java的不知道用过freemarker没,用过freemarker的不知道用过宏没,看段代码:

10.png

----------------------------------------------

-----------------------------------------------

8.png

------------------------------------

------------------------------------

7.png

第一个图片中是freemarker用宏封装了bootstrap的button组件,

第二个图片是在代码用使用封装后的bsbutton,

第三个图片是效果

有没有发现和reactjs很相似啊,只不过reactjs是在前端实现,

而freemarker是在后端实现,两者的共同点是封装,且可以传参。

记住,facebook出品的reactjs是用来开发ui库的js框架,特点是可以封装大量代码。
11.png

更多精彩内容:http://uikoo9.com/
时间: 2024-10-27 13:39:25

从Java的角度看前端JS各种框架的相关文章

从Java的角度理解前端框架,nodejs,reactjs,angularjs,requirejs,seajs

[突然领悟] 今天看了一遍reactjs,突然发现和自己一直用的freemarker的宏十分相似, 突然领悟了很多前端吊炸天的概念,框架,特写此文,欢迎批评指正. [nodejs] 官网:https://nodejs.org/ 简介:对前端来说极其重要的一个"框架",简直可以说是开天辟地 类比Java中:JVM 详述: 就前端来说nodejs具有划时代的意义,做前端的没用过nodejs都不好意思说自己是前端, 做后端的没听过nodejs,或者说不出nodejs和java的优缺点,也不是

Java 8 角度看注解类型

1.除了在继承关系上的限制(不能添加泛型声明也不能添加extends继承另外的接口),声明时用@interface而不是interface以外,注解类型和普通接口没有区别 2.注解类型中可以包含多个元素,通过方法声明形式来定义,这些方法的声明不能有任何参数或类型参数,也没有方法体:方法返回值类型只能是基本类型.String.Class.Enum.注解类型和数组类型,数组不支持多维数组.注解类型也可以没有任何元素.若注解类型只有一个元素,一般命名为value(作为使用时候的默认传值对象),通过方法

从JVM的角度看JAVA代码--代码优化

从JVM的角度看JAVA代码–代码优化 从JVM的角度看JAVA代码代码优化 片段一反复计算 片段二反复比較 在JVM载入优化为class文件,运行class文件时,会有JIT(Just-In-Time)的介入,它会做进一步优化,这样就须要考虑是否可能被JIT优化. 片段一:反复计算 // 反复计算,这里b()被计算两次 Object a = b() == null ? "" : b(); // 优化代码 Object c = b(); Object a = c == null ? &

java 访问 太平洋网ip接口,解决前端js 跨域访问失败问题

前端 js访问太平洋网IP接口地址,返回结果是403 服务器拒绝处理异常, 于是,想到了使用 服务器端访问,然后再将查询结果返回的前端 这是Java的测试源码,[具体的contronller端源码懒得写,其实基本一样]: 1 public class GetLocationByIP { 2 @Test 3 public void IpUtils(){ 4 String ip = "223.73.101.129"; 5 System.out.println(SendGET(ip)); 6

java 前端js里的console坑人点

之前做的项目,自己用easyUI做为前端框架,调试的时候用console来显示数据,调试好了之后,给客户现场部署,结果现场是IE浏览器,打开后发现点了菜单后没反应.最终在大牛的指导下,才知道console在IE里根本不支持. 在此做个铭记,希望下次再调试前端js代码后,把console给去掉或者注释掉.

从一个程序员的角度看——微信小应用

前言: 最近初步了解了一下微信小应用,APP端的同事也非常感兴趣,于是在公司内部做了一个小小的分享,分享的过程中有很多讨论内容,大家也是非常感兴趣和有自己的看法,当时"混乱"的场面好几次我都没有把持住.以下内容部分来自于内部分享所用ppt.文章对微信小应用的使用做了展示性介绍,并简单介绍了代码结构.后端交互方法.最后提出一些总结和疑问.文章内容比较主观,有不对的地方欢迎大家指出纠正. 前段时间微信小应用公开内测,在朋友圈火了一把,各种阐述疯狂蔓延,干掉APP之类的说法比较突出,确实达到

从一个程序员的角度看——微信小应用(含直播视频)

前言: 最近初步了解了一下微信小应用,APP端的同事也非常感兴趣,于是在公司内部做了一个小小的分享,分享的过程中有很多讨论内容,大家也是非常感兴趣和有自己的看法,当时"混乱"的场面好几次我都没有把持住.以下内容部分来自于内部分享所用ppt.文章对微信小应用的使用做了展示性介绍,并简单介绍了代码结构.后端交互方法.最后提出一些总结和疑问.文章内容比较主观,有不对的地方欢迎大家指出纠正. 前段时间微信小应用公开内测,在朋友圈火了一把,各种阐述疯狂蔓延,干掉APP之类的说法比较突出,确实达到

后端程序猿写的前端js代码模板

看几天的javascript面向对象和基础等之类相关javascript的知识,由于自己是写php的,也写过java,所以想在写javascript代码的时候也能用上面向对象的思想, 折腾了一整天的js继承和封装等,搞得我是吃午饭都想着问题,怎么javascript代码可以如此松散呢?眼看就要下班了,加班到现在不知怎么滴就弄了这样一个js代码模板,想以后每个模块都这样写.大了就各个功能对象提炼出来,如验证的.语言包的. 好了,废话不多说,菜鸟一个,代码没注释也不完整,高手留情指点: reg.ht

前端Js框架汇总【转】

概述: 有些日子没有正襟危坐写博客了,互联网飞速发展的时代,技术更新迭代的速度也在加快.看着Java.Js.Swift在各领域心花路放,也是煞是羡慕.寻了寻.net的消息,也是振奋人心,.net core 1,mono,xamarin等等,但大多都还在狂吼的阶段.其实一直以来对技术的理解是技术服务于业务和产品,产品又在不同程度的推进着技术的演进. Web.无线.物联网.VR.PC从不同方向推进着技术的融合与微创新.程序员在不同业务场景下的角色互换.而随着node.js的出现语言的角色也在发生着转