angularjs路由如何禁止缓存?

angularjs路由如何禁止缓存?,第1张

angular默认的模板加载都会被缓存起来,使用的缓存服务是$tempalteCache,发送模板请求的服务是$templateRequest,可以有两种方案:

1.每次发送$http请求模板完成后,调用$tempalteCache.remove(url)或removeAll清除所有模板缓存;

2.使用$provide.decorator改写原生的$templateRequest,禁掉缓存,$templateRequest的源码,可以看到它默认使用$tempalteCache作为缓存,可以去掉它。

**

**

一个模板中存在多个ui-view,每个ui-view都存在唯一的名称作为标识,通过v-show来判断当前的ui-view是否显示,实现如下图效果

以上可以实现基本的菜单切换,但是需要注意的是:

1.每个页面模块的controller的命名不能相同,否则会出现调用方法的混乱,可能会进入到另一个同名的controller中调用方法;

2.当使用此方法对页面进行缓存,如果打开多个模块用到websocket接受服务器消息时,不能使用WebSocket.onmessage监听和接受服务器消息,否则可能会调用其他controller中WebSocket.onmessage,当前的页面模块就会监听不到服务器消息,这时我们可以使用

socket.addEventListener('message', function (event) {

console.log('Message from server ', event.data)

})

进行服务器消息的监听,并在方法体内做判断,是否是当前页面需要的。

3.如果某个页面的d出框用到了路由调用则d框中的页面不会显示,所以建议不要在d框中直接调用路由加载页面,或者可以在index.jsp中:

4.如果几个模块views里面的name一样,则会出现加载的页面重复的问题;

5.style样式:如果多个模块存在相同名称的选择器,则样式会冲突;

还有些问题会在后面慢慢补充。

6.页面打开太多会出现卡顿现象

7.一定要引入 <script src="vendor/angular/angular-ui-router-ext/ct-ui-router-extras.min.js"></script>,否则会出现ui-view没有缓存的情况


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6693191.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-26
下一篇 2023-03-26

发表评论

登录后才能评论

评论列表(0条)

保存