【前端神秘的面纱】

对后端开发来说,前端是神秘的,

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

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

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

水平有限,欢迎指正。

【nodejs】

官网:

简介:

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

类比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运行环境,打开了前端人员走向后端的道路。

【js mvc框架】

相关框架:

框架太多,详见下面两篇文章

类比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

【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导包:

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

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

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

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

例如commonjs,requirejs,seajs等等。

记住,commonjs,requirejs,seajs等js模块化框架,遵循各种规范(amd,cmd,umd,commonjs),

类比java中的import

【reactjs】

官网:

简介:

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

类比Java中的:freemarker的宏。

详述:

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

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

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

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

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

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

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

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

那么好处是什么?

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

很酷的效果,material ui风格的webui组件,基于reactjs开发的。

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

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

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

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

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

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

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

第三个图片是效果

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

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

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

java reactjs_从Java的角度理解前端框架,nodejs,reactjs,angularjs,requirejs,seajs相关推荐

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

    从Java的角度理解前端框架,nodejs,reactjs,angularjs,requirejs,seajs [前端神秘的面纱] 对后端开发来说,前端是神秘的, 眼花缭乱的技术,繁多的框架, 如果你 ...

  2. 前端框架——bootstrap/knockoutjs/angularjs

    前端框架--bootstrap/knockoutjs/angularjs 转载于:https://blog.51cto.com/caochun/1854522

  3. 【Java Web前端开发】前端框架 bootstrap+jquery+angularjs探索

    文章目录 1 Bootstrap 2 jQuery 3 AngularJS 1 Bootstrap 在Bootstrap的官网介绍中,Bootstrap is the most popular HTM ...

  4. 理解前端框架、前端库,两者有什么区别

    一.前端框架(Framework).前端库(Library)两者的概念和区别是什么 前端框架和库都是前端开发中常见的概念,它们的区别在于它们所解决的问题不同. 1.1.前端框架(Framework)是 ...

  5. web前端框架——一些简单理解

    以下为百度内容+自己总结: 前端框架一般指用于简化网页设计的框架,前端框架分很多种,这些框架封装了一些功能,比如html文档操作,漂亮的各种控件.可以把bootstrap也叫作前端框架,也可以把jQu ...

  6. 前端进击笔记第十二节 掌握前端框架模板引擎的实现原理

    如今说起前端开发,基本上都离不开前端框架.随着前端技术不断迭代,前端框架相关的文档和社区日益完善,前端入门也越来越简单了.我们可以快速上手一些工具和框架,但常常会忽略其中的设计和原理. 对框架和工具的 ...

  7. Web前端框架与类库的思考

    说起前端框架,我也是醉了.现在去面试或者和同行聊天,动不动就这个框架碉堡了,那个框架好犀利. 当然不是贬低框架,只是有一种杀鸡焉用牛刀的感觉.网站技术是为业务而存在的,除此毫无意义,框架也是一样.在技 ...

  8. angularjs 路由---angularjs 搭建前端框架

    前端框架搭建:angularjs,nodejs 安装,git 安装 let toStateCache, fromStateCache, cssToBeEnableList = []export def ...

  9. java后端和web_从java和web角度分析前端好还是后端好

    从java和web角度分析前端好还是后端好 发布时间:2020-06-12 16:58:13 来源:亿速云 阅读:121 作者:元一 对于java来讲前后端哪个的发展会更好 java是前端还是后端这个 ...

  10. Java 并发编程解析 | 如何正确理解Java领域中的多线程模型,主要用来解决什么问题?

    苍穹之边,浩瀚之挚,眰恦之美: 悟心悟性,善始善终,惟善惟道! -- 朝槿<朝槿兮年说> 写在开头 我国宋代禅宗大师青原行思在<三重境界>中有这样一句话:" 参禅之初 ...

最新文章

  1. eclipse lombok插件安装_Eclipse-安装Freemarker插件
  2. Windows 2003系统也玩图片收藏屏保
  3. mysql 插入数据后返回该条数据id
  4. 详解网页中的关键词分布技术
  5. 查看Linux服务器的CPU详细信息
  6. js与设计模式----简单工厂
  7. [在职软件工程]面向对象的分析与设计
  8. Laravel第二章
  9. 平面设计师需要掌握哪些印刷知识
  10. 失意的企业家,排队和俞敏洪做直播
  11. 服装企业信息化面临三大瓶颈
  12. (Raw/High) P-Code Ghidra使用的中间表示语言
  13. 我越脱俗,就会越世俗
  14. 读《春秋》有感之十六:楚共王选谥号
  15. PGO 是啥,咋就让 Go 更快更猛了?
  16. 破解帐户后,黑客重现如何榨干用户的最终价值
  17. (转霄神)HM解码流程图
  18. z变换公式表_小白学物理之狭义相对论(1)——洛伦兹变换
  19. 因男友迟迟没升 P8 分手?? | 每日趣闻
  20. iview-table实现自适应高度渲染表格条数

热门文章

  1. 微信手机端调试工具-微信Web开发者工具使用教程
  2. 最大连续登录天数统计对应的用户数分布的三种实现方式(HQL+Spark Rdd)
  3. 一、pytorch环境配置
  4. 深度优先搜索与广度优先搜索
  5. do还是doing imagine加to_to-do和doing用法及区别
  6. 高中数学解题方法技巧之秒杀解三角形难题(图文讲解)
  7. tween.js 中文使用指南 1
  8. Exp9 Web安全基础 ————20164316张子遥
  9. My console windows won't go away
  10. vue导入音乐_vue中添加mp3音频文件的方法