1.起因

自己一直做winform,有幸从某个大神手里接了一个node.js,express,angulurJS等集众多开源框架的一个项目,赶鸭子上架,于是一边学习,一边用自己以往的思中去整理,重构代码;

2.问题

在某几个环境下,需要用BootStrap的模态框,咱是学win的么。。 自然而然的想到将boosStrp的模态框整成一个通用的东西,四处调用 。。。

于是用patial引用对话框文件,对话框本身用anglurJS进行了服务器相关的通讯 。

后来发现,当只用一个的时候是好用的,如果多次引用 (调用不同的数据)那么只有一个好使。。

3.分析

查了一些资料才明白, angular.bootstrap 这个调用在页面上只能执行一次,多执行就不好用了,而我之前将所有的angular.module都写成了单独的JS文件中,每一个JS文件最后都调用了 angular.bootstrap 所以,自然而然的会挂掉;

4.期待

于是,想有一种解决机制,让我可以随意的partial各种文件到页面中, 并且js文件之间不会重复引用 ,angulurJS也能完美执行;

5.解决

亲们——虽然这个方式有点恶心,但是绝对直接有效;

思路就是把所有的AngulurJS模块动态维护在一个全局数组,然后进行动态的加载

不说了,贴代码

在框架页(layout ...)head处引用 angulurinit.js文件,代码如下:

Array.prototype.indexOf = function (val) {
for( var i = 0; i < this.length; i++) {
if(this[i] == val) return i;
}
return - 1;
};
var jsModules = new Array();
function Confirm(val){
if (jsModules.indexOf(val) > -1)
return;
else
jsModules.push(val); };

将每一个anglur.js模块内的

angular.bootstrap(document, [modulename]);

替换成

  Confirm(modulename);

在layout(布局页?我也不知道叫啥,反正是那个公共的框架页)尾部加入angulur.js文件,代码如下:

(function () {
var app = angular.module('app', jsModules);
angular.bootstrap(document, ['app']);
})();

嘿嘿~~ 我恶心了。。。 恶心到您了没?

本人WEB 菜鸟小白一个,欢迎大神们留言解决方式;

最新文章

  1. mysql : utf8mb4 的问题
  2. C# 后台获取WebApi 方法
  3. [转] The program can&#39;t start because api-ms-win-crt-runtime-l1-1-0.dll is missing
  4. CSS 包含选择器(九)
  5. MySQL之ALTER
  6. Linux下更好用的帮助命令—cheat
  7. 函数式编程Map()&amp;Reduce()
  8. 欢迎大家提问Android技术及职业生涯等问题
  9. .net 自然排序方式
  10. 单元测试工具之Xunit
  11. 为什么for不能有序遍历数组的所有元素?(Array的设计原理)
  12. ios推送基于YII第三方组件的类库
  13. 动态链接库DLL
  14. cf702A Maximum Increase
  15. 浅谈 PHP 神盾的解密过程
  16. Libgdx Box2D现实------这缓释微丸(一个:项目介绍)
  17. Error C1189: #error: Please use the /MD switch for _AFXDLL builds
  18. Kotlin入门第四课:简单工厂模式
  19. Luogu P1451 求细胞数量
  20. xargs实例

热门文章

  1. Java多线程之CountDownLatch学习
  2. eclipse调试
  3. linux 查看端口号
  4. sorl入门
  5. 关于CSV文件 Excel打开乱码问题的解决方案
  6. pyqt 过滤事件
  7. phpstorm 10注释的双斜线位置不在缩进的位置:
  8. bzoj1001最小割
  9. A library of generic data structures
  10. Linux Shell中单引号、双引号、反引号的区别【转载】