从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/
从Java的角度看前端JS各种框架的更多相关文章
- 站在Java的角度看LinkedList
站在Java的角度看,玩队列不就是玩对象引用对象嘛! public class LinkedList<E> implements List<E>, Deque<E> ...
- 从源码的角度看 React JS 中批量更新 State 的策略(下)
这篇文章我们继续从源码的角度学习 React JS 中的批量更新 State 的策略,供我们继续深入学习研究 React 之用. 前置文章列表 深入理解 React JS 中的 setState 从源 ...
- 从Java的角度理解前端框架,nodejs,reactjs,angularjs,requirejs,seajs
[前端神秘的面纱] 对后端开发来说,前端是神秘的, 眼花缭乱的技术,繁多的框架, 如果你还停留在前端等于只用jquery做开发,那么你out了, 本文从Java的角度简述下目前前端流行的一些框架. 水 ...
- 从源码的角度看 React JS 中批量更新 State 的策略(上)
在之前的文章「深入理解 React JS 中的 setState」与 「从源码的角度再看 React JS 中的 setState」 中,我们分别看到了 React JS 中 setState 的异步 ...
- java前端js和框架内容知识和面试
关于数据库知识和面试 关于JAVA知识和面试 一.多个ajax请求执行顺序问题 若点击一个操作内,发送两个ajax请求,其中一个请求会不会等待另一个请求执行完毕之后再执行? 不会,这两个异步请求会同时 ...
- 从JVM的角度看JAVA代码--代码优化
从JVM的角度看JAVA代码–代码优化 从JVM的角度看JAVA代码代码优化 片段一反复计算 片段二反复比較 在JVM载入优化为class文件,运行class文件时,会有JIT(Just-In-Tim ...
- java 访问 太平洋网ip接口,解决前端js 跨域访问失败问题
前端 js访问太平洋网IP接口地址,返回结果是403 服务器拒绝处理异常, 于是,想到了使用 服务器端访问,然后再将查询结果返回的前端 这是Java的测试源码,[具体的contronller端源码懒得 ...
- json处理总结(前端js和后端java)
前端(js): json是以文本,即字符串的形式传递的,而JS操作的是JSON对象,所以,JSON对象和JSON字符串之间的相互转换是关键,下面将介绍两者之间的相互转换. json字符串:var st ...
- 从JDK源码角度看java并发线程的中断
线程的定义给我们提供了并发执行多个任务的方式,大多数情况下我们会让每个任务都自行执行结束,这样能保证事务的一致性,但是有时我们希望在任务执行中取消任务,使线程停止.在java中要让线程安全.快速.可靠 ...
随机推荐
- docker 删除none镜像
Windows版本,参考官方地址:https://forums.docker.com/t/how-to-remove-none-images-after-building/7050 docker rm ...
- python安装pip和使用pip安装Python库类比如pip安装beautifulsoup4
初学Python时,看到很多不懂得东西,比如 pip, 是python 包管理工具,pip是easy_install的取代. Distribute是对标准库disutils模块的增强,我们知道disu ...
- CSUOJ 1900 锋芒不露
Description 小闪最近迷上了二刀流--不过他耍的其实是剑--新买了一个宝库用来专门存放自己收集的双剑.一对剑有两把,分只能左手用的和只能右手用的,各自有一个攻击力数值.虽然一对剑在小闪刚拿到 ...
- c#/asp.net实现炫酷仿调色板/颜色选择器功能
asp.net 之颜色选择器,仿调色板功能 1. 插件非常容易使用,只需引用相应的js文件和css样式文件即可,见代码示例,插件精小,炫酷 2. 只需要初始化即可使用,并且选择的颜色会在文本框中以16 ...
- 基于特征码文件恢复工具magicrescue
基于特征码文件恢复工具magicrescue 常见类型的文件都包含一些特殊的字节,用来标识文件的类型.这些字节被称为特征码.在磁盘中,当记录文件存储位置的簇损坏后,就可以基于这些特征码来恢复文件. ...
- 【WIN10】VisualStateManager使用說明
Demo下載:http://yunpan.cn/cFjgPtWRHKH9H 访问密码 c4b7 顧名思義,視圖狀態管理器. 在WPF中,它的功能似乎更強大.在UWP中,閹割了GotElementSt ...
- 凡信(超仿微信Android版)开源了,内有源码下载 -
韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_meng_fei_sha 凡信(超仿微信Android版)开源了,内有源码下载 - IM Geek开发者社区-移动 ...
- parcelable 和 serializable 区别
韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_meng_fei_sha serializable 是 java 中的 序列化 接口. parcelable 是 ...
- [BZOJ5125]小Q的书架(决策单调性+分治DP+树状数组)
显然有决策单调性,但由于逆序对不容易计算,考虑分治DP. solve(k,x,y,l,r)表示当前需要选k段,待更新的位置为[l,r],这些位置的可能决策点区间为[x,y].暴力计算出(l+r)/2的 ...
- bzoj 1901: Zju2112 Dynamic Rankings -- 主席树,树状数组,哈希
1901: Zju2112 Dynamic Rankings Time Limit: 10 Sec Memory Limit: 128 MB Description 给定一个含有n个数的序列a[1] ...