学习AngularJS后,发现Js越来越有趣,开发有效率也是非常地高,上手很快。
决定要在JS的道路上一直走下去。
使用Java开发后端代码是一种痛,因此需要JavaScript来解放大脑。
我对选型的平台定义几个目标:
学习成本极低:快速上手,不用学习太多类型技术。
灵活:实现简便,功能模式简单。
热布署:现改现得,不需要太多的布署操作,升级无缝。
稳定:除了系统上的运行稳定,在代码与库,还有生态上需要有比较稳定的发展。
有几种选择方案,业务最好的是Node.js,这个东西性能很强大,不过很多坑,虽然事件模型很优秀,但开发过程发现,代码阅读性实在是比较低。而且第三方库代码实在是少,很多东西还需要自己实现,而且比较多坑。
由此我将目光转向Java平台上,发现了RingoJS。这个东西基本与node.js中的express的东西无差。使用起来比较轻便。但是在学习成本这块比较高,可以说与java无任何关系。例如一些AOP,事务这些东西都没有较好的支持,因此放弃。
从目前的各种框架分析后,主要的一个开发效率,学习成本,第三方库丰富度上的问题为主。
关于开发效率,与学习成本上,主要是因为整个开发链过程中,需要学习与管理的东西太多。从整个系统开发链接中,由前到后需要学习的东西是比较多的,从html,css,js,java,sql。在各环境还会衍生出各种技术。
其中前后端分工最大。其中前后端思想极其不统一。这种情况也是类似于服务程序与数据库不统一。
为了补这个坑,出现了各种ORM,但是还是无法很好地解决设计不统一的问题。
由种种原因,决定尝试统一前端与后端,数据库的开发思想,设计了一套解决方案。
目前为止,打算需要结合JavaScript与Java的优势,其核心思想中前后数统一,新开发一个项目,Argos。
Argos主要针对Web系统开发,使用者只是需要使用JavaScript代码编写。
融入了同步式的事件模型。包括前后端,通过抽象统一对象,统一前后端开发模式。后端为BaaS,后端为服务的模式。
理论太多无用,先上代码试试:
编写服务端代码,建js文件hello.js
var $argos = { $init:function(){ print('hello World'); } }
启动程序
#argos server/hello.js
启动后会输出'hello World'。
以上代码仅启动服务,在启动业务时,平台会调用
$argos
.$init方法。
现在开始做前后端交互的样例,加入一个简单成员appName,
并让前端可以访问appName成员的值。
var $argos= { $init:function(){ print('hello World'); }, appName : 'helloApp' }
编写前端代码:
var $argos= ...//省略初始化过程 $scope.getAppName = function(){ $argos.getAppName(function(resp){ console.info(resp.data); }); }
当调用$scope.getAppName时,前端控制台会打印出“helloApp”字样。
上段代码主要说明了后端$argos对象与前端$argos两者抽象结构尽量保持一样。
因于环境不同无法达到完全一致。不过尽可能地实现同样的效果,前端语法上会统一规范。
后端中$argos对象中存在appName成员变量名,则在前端使用时,在成员名前加上get字眼。
同理,需要更新服务端值时,则需要使用'set'字眼,代码如下:
$scope.setAppName = function(){ var newAppName = $scope.appName; $argos.setAppName(newAppName,function(resp){ console.info(resp.data); }); }
更新完成后,则会输出服务端更新后的新值。
以上代码配后AngularJS框架的$scope对象,当前的前端测试示例基于此情况。
还有一种情况则是服务端某方法的调用,这类调用更加简便,直接在前端调用方法就可以,示例代码如下:
后端代码:
var $app = { $init:function(){ print('hello World'); }, sum : function(param){ var a = param.a?param.a:0; var b = param.a?param.a:0; return a+b; }, appName : 'helloApp' }
前端代码:
$scope.sum = function(){ var datas = { a:1, b:2 } $argos.sum(datas,function(resp){ console.info(resp.data); }); }
sum为服务端一个方法,直接返回param中两个值的和,此时控制台输出3,表明此时sum方法不需要任何变化,可以直接调用。
目前我们再继续配合AngularJS框架,利用框架更进一步简化代码,更优美,见下文!
html代码如下:
<div> AppName:<input type="text" ng-model="$argos.appName" ></input> <a ng-click="updateAppName()">updateAppName</a> </div>
对应Controller代码如下:
$scope.$argos = $argos; $scope.updateAppName = function(){ $argos.setAppName(); }
此时,当用户点击"updateAppName"时,程序自动会将用输在输入框输的内容提交到服务端的,服务端则会将值设置入$argos.appName中。这里一个很重要的地方则是将$argos对象设置入$scope中。
可以直接将$argos当成域其中的一个对象。然而在setAppName()方法的背后,会将appName的值设入
$argos.appName,此时通过双向绑定,将新值输出到页面中,如果是仅需要从服务端更新值到前端,则可以直接调手$argos.getAppName()方法,不需要带回调方法,无论是否回调,都默认更新$argos.appName这一成员的值。
换句话说,在使用argos开发过程中,主要的精力在于通过$argos对象来实现业务逻辑的载体。
不需要太多考虑前后端之间的接口交互,argos会帮你将后端的对象模型与前端做一个映射,从逻辑上讲,前后端的业务模式与流程可以保持一致,除了调用的方法不太相同。
目前看来,这样实现业务效果的感觉非常好,两者之间的思维上基本是统一的,各种值的设置方法名基本一致,调用时轻快简约,不需要写太多ajax相关的方法,后端代码也是简明轻快,不需要搭建太繁杂的东西。配合上AngularJS后,两者的效果达到1+1>2的效果。
目前项目也是在前期开发阶段,现在只是小刀一试,在这个过程中,需要一些具体的项目去实践验证。
欢迎加我QQ(2918418143)或加群(533823007)讨论。