旨在脱离后端环境的前端开发套件 - IDT之Server篇
IDT,一个基于Nodejs的,旨在脱离后端环境的前端开发套件,目的就是能让前端开发完全脱离后端的环境,无论后端是什么模板引擎(主流),都能应付自如。
IDT主要包括两大部分:Server + Build,这一篇主要介绍Server篇。
为了辅助前端开发,一个本地的类似于Apache的服务器是少不了的,但是有个问题,如果项目中的html,是php的smarty模板怎么办?使用纯粹的静态服务器是不行的,因为对前端开发来说,这个html必须由php的smarty模板引擎来解析,前端人员不懂php怎么办,可以让后端人员来协助搭建环境;但是项目是java,而html是velocity模板引擎呢?让后端人员来搭建java环境吧。。。好繁琐呀。而且,我想根据前后端的接口来自己mock数据怎么办?。。这些都是问题,IDT应运而生。
适用于Django Template、PHP Smarty、Java Velocity、Java Freemarker的Integration Develop Tool [ 集成开发工具 ]
其实,IDT中的server使用的是grunt-conect组件,然后通过了middleware的概念,来处理各种类型的数据:
例如:html middleware做的事情,就是把与请求的url相对应的html文件,与自己的mock数据的文件,通过对应的模板引擎渲染,呈现给浏览器:
ajax middleware做的事情也是一样的。
目前,IDT支持了Python Django、PHP Smarty、Velocity、Freemarker的模板引擎的渲染,大大提高了前端开发的效率。
如何安装IDT:传送门
在安装完成以后,就可以开始开发了,在终端输入:idt -V 有正常输出,则安装正常~
在安装的源文件目录中,有一个:example-ws 目录,这里面就是示例目录,在这里可以切换各种模板引擎,进行测试:
.
├── django
│ ├── base.html
│ └── test.html
├── freemarker
│ ├── list.html
│ ├── test.tpl
│ └── view.html
├── idt-config.js
├── mock
│ └── html
│ ├── commonmock
│ │ └── common.js
│ ├── django
│ │ └── test.html.js
│ ├── freemarker
│ │ └── test.tpl.js
│ ├── smarty
│ │ └── test.tpl.js
│ └── velocity
│ └── test.html.js
├── smarty
│ ├── footer.tpl
│ └── test.tpl
└── velocity
├── dep.html
├── header.html
└── test.html
可以把这个目录拷出一份来,并且cd进入此目录,则可以直接执行:
idt ws start
那么这个例子就跑起来了,想结束server,只需要Ctrl+C。
在切换引擎的时候,唯一需要修改的地方就是:
- // 模板引擎根目录【只需要修改最后一个参数即可】
- templates: path.join( webContent, secondary, 'velocity' ),
- // 模板引擎切换: smarty / django / velocity / freemarker [ 默认velocity ]
- /**
- * velocity模板引擎采用:
- * https://www.npmjs.com/package/velocity
- *
- * django模板引擎采用'A wrapper of Django's template engine'方式(桥接原理)
- * 详见:https://www.npmjs.com/package/django
- * 在启用之前请确保python环境已经ready,然后安装django:
- * # pip install -v Django==1.7
- * //or
- * # easy_install "Django==1.7"
- *
- * smarty模板引擎采用:
- * https://www.npmjs.com/package/nsmarty
- *
- * freemarker模板引擎采用:(桥接原理)
- * 在启用之前,请确保java环境,并且需要安装:http://fmpp.sourceforge.net/
- * https://www.npmjs.com/package/freemarker.js#readme
- */
- tplEngine: 'velocity',
idt-config.js中的第50行,用来修改模板引擎的view的根目录,71行则是切换引擎的配置。
还有需要注意的地方就是上面代码中的注释部分:
django需要安装好python环境,并且,通过python安装好django,详细地则可以通过上面给出的链接去查看;
同理,freemarker也需要java环境,并且下载fmpp这个东东,而且要把fmpp中的bin目录加入环境变量;
django和freemarker的原理类似,node层次的代码,只是一层wrapper,它会通过命令行形式静默地去掉用python的接口或者java的接口,从而完成渲染。
IDT的功能不止这些,还有反向代理、远程调试、Less的实时编译(通过less middleware,less在请求过程中,直接被编译成css),批量导出静态文件、Build构建(调用了Edp进行build)等等功能,接下来会慢慢的介绍它的每一个功能。
感兴趣的可以看它的源代码就会了解~
旨在脱离后端环境的前端开发套件 - IDT之Server篇的更多相关文章
- 旨在脱离后端环境的前端开发套件 - IDT Server篇
IDT,一个基于Nodejs的,旨在脱离后端环境的前端开发套件,目的就是能让前端开发完全脱离后端的环境,无论后端是什么模板引擎(主流),都能应付自如. IDT主要包括两大部分:Server + Bui ...
- openresty 前端开发入门五之Mysql篇
openresty 前端开发入门五之Mysql篇 这章主要演示怎么通过lua连接mysql,并根据用户输入的name从mysql获取数据,并返回给用户 操作mysql主要用到了lua-resty-my ...
- Uix Kit 快速建站前端开发套件-工具箱
这个产品维护已经有一年了(由于业务需求不同,目前没有做中文版,产品本身是针对国外网站),自己本身是做UI出生,开发只是业余爱好,仅仅作为平时工作的需要.杂七杂八会一些前后端开发.并非职业码农! 我是一 ...
- 1. web前端开发分享-css,js入门篇
关注前端这么多年,没有大的成就,就入门期间积累了不少技巧与心得,跟大家分享一下,不一定都适合每个人,毕竟人与人的教育背景与成长环境心理活动都有差别,但就别人的心得再结合自己的特点,然后探索适合自己的学 ...
- web前端开发分享-css,js入门篇(转)
转自:http://www.cnblogs.com/jikey/p/3600308.html 关注前端这么多年,没有大的成就,就入门期间积累了不少技巧与心得,跟大家分享一下,不一定都适合每个人,毕竟人 ...
- 2. web前端开发分享-css,js进阶篇
一,css进阶篇: 等css哪些事儿看了两三遍之后,需要对看过的知识综合应用,这时候需要大量的实践经验, 简单的想法:把qq首页全屏另存为jpg然后通过ps工具切图结合css转换成html,有无从下手 ...
- 3. web前端开发分享-css,js提高篇
一. css基础知识掌握之后(个人的标准是:弄清块元素与内联元素的区别,弄清float的应用场景,弄清position[pə'zɪʃən] 下五个属性static['stætɪk],relative[ ...
- 4. web前端开发分享-css,js工具篇
web前端开发乃及其它的相关开发,推荐sublime text, webstorm(jetbrains公司系列产品)这两个的原因在于,有个技术叫emmet, http://docs.emmet.io, ...
- 5. web前端开发分享-css,js深化篇
一. css练习网易专题: 1. http://news.163.com/ 新闻 跟腾讯的新闻版式大体没有大的变化,只是细节. 2. http://news.163.com/photo/#Curren ...
随机推荐
- 第六节:宿主如何使用AppDomain
前面已经讨论了宿主以及宿主加载CLR的方式.同时还讨论了宿主如何告诉CLR创建和卸载AppDomain.为了使这些讨论更加具体,下面将描述一些常见的宿主和AppDomain使用情形.特别地,我要解释不 ...
- Test,Nginx Hello World Module
ngx_addon_name=ngx_http_mytest_module HTTP_MODULES="$HTTP_MODULES ngx_http_mytest_module" ...
- android ptl
Gerrit android update sdk --no-uiadb logcat MyActivity:* *:S Connecting adb over Wi-Fiadb tcpip 5555 ...
- WPF中线性渐变画刷的一个小窍门
最近被项目里面控件的设计搞的死去活来的,大部分的设计都会需要使用进度条的功能,因为UI形状的变态,使用ProgressBar不能满足需求,没办法就自己想办法实现进度显示.折腾的多了发现一个很不错的方法 ...
- Java动态替换InetAddress中DNS的做法简单分析2
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.i ...
- 关于使用,NI采集卡+labview信号采集,问题交流【第二贴】
*** 采集卡 NI PCI-6534: max sample rate 20MHz:32位的数字输入,数字输出. ***输入信号: 峰峰值,4.16V 最小值 -80mV 频率 ...
- 34.pad designer警告
1.Drill hole size is equal or larger than smallest pad size. Pad will be drilled away 原因:钻孔直径太大,直接把p ...
- C++ MFC实现基于RFID读写器的上位机软件
C++ MFC实现基于RFID读写器的上位机软件 该博客涉及的完整工程托管在https://github.com/Wsine/UpperMonitor,觉得好请给个Star (/▽\=) 运行和测试环 ...
- Matlab实现抽样定理
Matlab实现抽样定理 正弦信号的抽样: 首先时间跨度选择 -0.2 到 0.2,间隔0.0005取一个点,原信号取 sin(2π*60t) ,则频率为60Hz. 由于需要输出原始信号的波形,我选 ...
- VIM实用基本操作技巧
文本编辑器有很多,图形模式下有gedit.kwrite等编辑器,文本模式下的编辑器有vi.vim(vi的增强版本)和nano.vi和vim是Linux系统中最常用的编辑器.有人曾这样的说过在世界上有三 ...