星空网 > 软件开发 > Java

非正规方法处理AngulurJS模块管理问题

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 菜鸟小白一个,欢迎大神们留言解决方式;

 




原标题:非正规方法处理AngulurJS模块管理问题

关键词:JS

JS
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

2000亿中国商品关税25%正式实施 / 安克创新发布招股书:https://www.ikjzd.com/articles/91452
Facebook 联合创始人公开发文支持拆分公司:https://www.ikjzd.com/articles/91454
速看!皮卡丘带你造爆款!:https://www.ikjzd.com/articles/91456
中东“土豪”平台NOON销量猛增,你GET到了吗?:https://www.ikjzd.com/articles/91457
亚马逊出台新计划助力中国卖家:https://www.ikjzd.com/articles/91458
小心!Feedback被限制竟是因为这2个操作:https://www.ikjzd.com/articles/9146
宠物梳专利查询分析:https://www.kjdsnews.com/a/1842293.html
温州旧货市场有玻璃柜卖吗?:https://www.vstour.cn/a/411246.html
相关文章
我的浏览记录
最新相关资讯
海外公司注册 | 跨境电商服务平台 | 深圳旅行社 | 东南亚物流