AngularJS ng-template寄宿方式用法分析


Posted in Javascript onNovember 07, 2016

本文实例讲述了AngularJS ng-template寄宿方式用法。分享给大家供大家参考,具体如下:

如果你是一个angular的开发者的话,对于ng-html2js你应该 很熟悉。对于angular的指令,我们经常需要定义模板( directive template/templateUrl),你可以选择讲html page 放在真正的的web容器中寄宿,也可以选择angular的ng-template 放在view的page之上,抑或也可以讲html打成一个js文件和directive 的js文件合并在一起发布。

对于直接寄宿在web容器.

这很简单,直接放在jetty,tomcat,iis, 抑或node express public目录下。这里没什么可以多说的,所以我们跳过。

angular ng-template模板:

代码如下:

<script type="text/ng-template" id="/tpl.html">
   Content of the template.
</script>

这将会在angular的compile时候解析,angular将会把它放在angular的$templateCache 中。

对于$templateCache,如其名 这是angular对模板的缓存的service。在启用了$templateCache的$http ajax请求, angular将会首先在$templateCache中查找是否有对此url的缓存:

$templateCache.get('templateId.html')

如果存在缓存,着angular将会直接用缓存中获取,并不会在发送一次ajax。 对于所有的指令和模板angular默认启用了templateCache。

这在于angular所处理的模式开发很有关系的。我们经常提到的SPA(single page application) 我们把view的显示处理等表现逻辑推到了前段,而后端提供只与数据有关的soap/restful service 这样对于一个应用程序业务逻辑来说不变的是处理数据的业务逻辑,这份逻辑你可以共享在不管前端是mobile app 或者是浏览器,或者winform gui的图形化程序,因为对于同一个业务这是不变的。将view的分离推到各自的客户端 将是更好的解决方案。

回到angular $templateCahce,对于一个应用程序view的分离,之后在对于当前的应用程序平台,html/js/css 这类资源是静态的,最好是不变的,那么你可以自由的缓存在客户端,减少服务器的交互,以及为了更大的性能追求,我们 可以把这类静态资源放在Nginx这里反向代理或者CDN上,让我们的程序获取更大的性能和扩展空间。

回到angular的ng-html2js:

有了上边对于$templateCache的理解,那你应该很容易理解html2js的方式了,与ng-template不同的 是ng-template是angular在compile的时候自动加入$templateCache的,html2js是我们在开发 时候利用build自己放入$templateCache。

angular.module('myApp', [])
 .run(function($templateCache) {
   $templateCache.put('templateId.html',
     'This is the content of the template'
   );
 });

形如上面的输出,将html文件打成一个js文件。

这你也许在angular的单元测试karma unit test中看见过, karma-ng-html2js-preprocessor ,还有如果你也希望在build时候做到如此,那么你可以使用grunt plugin grunt-html2js.

但使用grunt plugin的前提是你在你的项目中引入的grunt build的work flow,那么你可以在gruntfile.js中几行代码轻松的搞定。但是如果 你和我一样使用的是java的maven或者是gradle 作为build,那么你可以尝试博主的maven plugin  nghtml2js. 使用方式如下:

<plugin>
  <groupId>com.github.greengerong</groupId>
  <artifactId>nghtml2js</artifactId>
  <version>0.0.3</version>
  <configuration>
    <module>demo.template</module>
    <html>${project.basedir}</html>
    <extensions>
      <param>tpl</param>
      <param>html</param>
    </extensions>
  </configuration>
  <executions>
    <execution>
      <id>nghtml2js</id>
      <phase>generate-resources</phase>
      <goals>
        <goal>run</goal>
      </goals>
    </execution>
  </executions>
</plugin>

希望本文所述对大家AngularJS程序设计有所帮助。

Javascript 相关文章推荐
js以对象为索引的关联数组
Jul 04 Javascript
禁止选中文字兼容IE、Chrome、FF等
Sep 04 Javascript
js实现多选项切换导航菜单的方法
Feb 06 Javascript
JavaScript中的this使用详解
Jul 27 Javascript
详解vue.js2.0父组件点击触发子组件方法
May 10 Javascript
mui开发中获取单选按钮、复选框的值(实例讲解)
Jul 24 Javascript
Vue+Element使用富文本编辑器的示例代码
Aug 14 Javascript
Vue 进入/离开动画效果
Dec 26 Javascript
JS 数组随机洗牌的实例代码
Sep 12 Javascript
详解原生JS动态添加和删除类
Mar 26 Javascript
Element Badge标记的使用方法
Jul 27 Javascript
vscode 调试 node.js的方法步骤
Sep 15 Javascript
easyui messager alert 三秒后自动关闭提示的实例
Nov 07 #Javascript
基于bootstrap-datetimepicker.js不支持IE8的快速解决方法
Nov 07 #Javascript
AngularJS 应用身份认证的技巧总结
Nov 07 #Javascript
AngularJS解决ng界面长表达式(ui-set)的方法分析
Nov 07 #Javascript
基于KO+BootStrap+MVC实现的分页控件代码分享
Nov 07 #Javascript
浅谈EasyUi ComBotree树修改 父节点选择的问题
Nov 07 #Javascript
EasyUI 中combotree 默认不能选择父节点的实现方法
Nov 07 #Javascript
You might like
php md5下16位和32位的实现代码
2008/04/09 PHP
PHP批量生成缩略图的代码
2008/07/19 PHP
PHP中的函数声明与使用详解
2017/05/27 PHP
阿里云Win2016安装Apache和PHP环境图文教程
2018/03/11 PHP
document.forms[].submit()使用介绍
2014/02/19 Javascript
JavaScript控制图片加载完成后调用回调函数的方法
2015/03/20 Javascript
基于jQuery+Cookie实现的防止刷新的在线考试倒计时
2015/06/19 Javascript
在Web项目中引入Jquery插件报错的完美解决方案(图解)
2016/09/19 Javascript
Angular2-primeNG文件上传模块FileUpload使用详解
2017/01/14 Javascript
vue-cli结合Element-ui基于cropper.js封装vue实现图片裁剪组件功能
2018/03/01 Javascript
vue2.0中set添加属性后视图不能更新的解决办法
2019/02/22 Javascript
vue项目中使用fetch的实现方法
2019/04/25 Javascript
使用vscode快速建立vue模板过程详解
2019/10/10 Javascript
js Math数学简单使用操作示例
2020/03/13 Javascript
[01:08]DOTA2“血战之命”预告片
2017/08/12 DOTA
python 快速排序代码
2009/11/23 Python
python获取本地计算机名字的方法
2015/04/29 Python
使用Python操作MySQL的一些基本方法
2015/08/16 Python
详解常用查找数据结构及算法(Python实现)
2016/12/09 Python
Python及Django框架生成二维码的方法分析
2018/01/31 Python
Odoo中如何生成唯一不重复的序列号详解
2018/02/10 Python
50行Python代码获取高考志愿信息的实现方法
2019/07/23 Python
python处理document文档保留原样式
2019/09/23 Python
Pytorch Tensor 输出为txt和mat格式方式
2020/01/03 Python
使用Pycharm在运行过程中,查看每个变量的操作(show variables)
2020/06/08 Python
python 深度学习中的4种激活函数
2020/09/18 Python
Python高并发和多线程有什么关系
2020/11/14 Python
python 操作excel表格的方法
2020/12/05 Python
Europcar比利时:租车
2019/08/26 全球购物
文秘人员工作职责
2014/01/31 职场文书
500字小学生检讨书
2015/02/19 职场文书
二十年同学聚会感言
2015/07/30 职场文书
高中16字霸气押韵班级口号集锦!
2019/06/27 职场文书
七年级作文(600字3篇)
2019/09/24 职场文书
zabbix自定义监控nginx状态实现过程
2021/11/01 Servers
详解ZABBIX监控ESXI主机的问题
2022/06/21 Servers