在我不知道vue的路由还可以通过addRoutes动态添加时,我只知道vue的路由都是写死在路由表中的,每当跳转时再去加载相应的路由。直到在一个新公司接到需要根据用户的权限显示不同的菜单的需求时才知道了原来vue-router还有一个addRoutes的API,立马研究了一下。 router.addRoutes: 函数签名: router.addRoutes(routes: Array<RouteConfig>)动态添加更多的路由规则。参数必须是一个符合routes选项要求的数组。 点这里去看router.ad...
关于react与vue中的key之前在学习react的时候,常常遇到循环渲染组件时会提示需要在循环组件中加上key属性,比如有一组列表:import React, { Component } from react;export default calss MainApp extends Component {state = {student: [{name: Jenny,id: a001},{name: Jerry,id: a002},]}render() {return (<div><ul>{this.state.student.map(item => {// key是必须的属性,不然浏览器会抛出错误提示return (<li key={item.id}...
缓存对于前端页面来说,是加速页面加载的利器之一,但也同时带来了很多问题,比如新版本发布之后,怎么替换客户端上的缓存文件呢?大家一般的的解决方案主要有以下几种形式, 一般情况1、添加版本号,在静态资源文件的引用链接后面添加版本号,这样每次发布的时候更新版本号,就能让叫客户端加载新的资源文件,避免再次使用缓存的老文件,如 <script src="//m.test.com/build/activity/js/commons.js?v=20170608"></script>2、文件...
1.css同名覆盖,解决方法:父组件加上scoped <style lang="scss" scoped>@import ./unbind.scss </style>子组件同名样式加上deep/deep/ .tabs-row {.items-wrp{padding-left: .34rem;}.item {margin:0 .12rem .16rem 0;}}2.事件全局绑定 绑在window或document或body上的事件,切换到下一个页面同样会被触发,需要销毁,也防止内存泄漏,全局绑定的事件如果是公用组件慎用off().on(),因为可能引用的其他的组件全局绑定的事件被移除des...
vue开发的时候,我们经常会有这样的需求:开发一个详细页面来展示商品的详细信息,根据列表页传入的id进行请求,拿到对应的数据进行渲染。 但是一般在路由上都会加上keep-alive保持数据的状态,除非强制无缓存刷新,这就导致第一次进入详情页面时,可以在created中拿到id,但是返回后,再点击进入,就不会再走相应的生命周期了,无法拿到新的id 这时候可以使用vue的$destroy()方法 这是vue的一个生命周期,完全销毁一个实例。清理它...
相信每一个开发者都知道缓存的重要性。从头至尾有缓存的后台(memcached,xcache等。) 来减轻db的压力。对内容分发网络(CDN)缓存中希望你的浏览器缓存那些不止一次的加载资源。当然, 有客户端缓存,所以你不要重复昂贵的操作(即使是算法或大量的运算)。 这是介绍的是一个不错的javascript的方面的客户端解决方案,可选配支持HTML5本地存储器. Starting Simple 代码如下: function CacheProvider() { // values will be stored here ...
用一句代码即可搞定: 代码如下: document.execCommand("BackgroundImageCache", false, true); 当然为了其它浏览器上能正常通过,需要做下判断后调用,才更安全: 代码如下: if(Browser.isIE6){ try{ document.execCommand("BackgroundImageCache", false, true); } catch(e1){} } 平台检测代码可以这样写,摘自Ext源码: 代码如下: var Browser = {}; try{ (function(){ var idSeed = 0, ua = navigator.userAgent.toLowerC...
今天是发现bug的高产期。 IE在解析innerHTML的时候居然会忽略Cache策略,简单的重复加载图片。请看以下代码: 保存到本地作为一个htm文件,然后用IE打开(允许脚本运行),然后用http监视工具可以看到,IE发起了100个请求,一个都不cache! 在FireFox下面就没有问题,只发起一个请求。 代码如下:用这段代码可以解决这个问题 ">
这篇文章主要介绍了详解基于vue的移动web app页面缓存解决方案,非常具有实用价值,需要的朋友可以参考下现在移动web app越来越热门了,许多公司开始尝试使用angular、react、vue等MVVM框架来开发单页架构的web app。但在开发web app时,如果希望页面的导航体验也接近原生应用,那一般都会遇到这两个问题:识别前进后退行为后退时恢复之前的页面笔者开发了一个基于vue与vue-router的导航库vue-navigation,来帮助开发者来解决这些问...
解决方法一:IE6 Hack脚本 代码如下: if(navigator.appName == "Microsoft Internet Explorer"){ var b_version=navigator.appVersion; var version=b_version.split(";"); var trim_Version=version[1].replace(/[ ]/g,""); if(trim_Version=="MSIE6.0"){ ;//alert("IE 6.0"); try { document.execCommand("BackgroundImageCache", false, fix); }catch(err){ } } } 解决方法二:IE6 Hack注释 代码如下: document.execComma...
原理很简单,让你每次获取远程图片的url不同即可 代码如下:$(".myImg").src("yourUrl.action?randUrl"+Math.ceil(new Date()/3600000);
如果要显示最新的数据需要在页面中进行设置,取消缓存。 在showModalDialog的页面的Head标签内增加如下代码:这样页面就不会被缓存。从而保证了在对数据进行修改后,再次打开页面后显示最新的数据。 HTML方面 禁止浏览器从本地缓存中调阅页面。 网页不保存在缓存中,每次访问都刷新页面。 同上面意思差不多,必须重新加载页面 网页在缓存中的过期时间为0,一旦网页过期,必须从服务器上重新订阅。 .NET方面Response.Expires = -1...
细节决定成败!浏览器缓存的意义在于提高了执行效率,但是也随之而来带来了一些问题,导致服务端修改了js、css,客户端不能更新 方法一 生成随机数字 代码如下: 缺点,浏览器缓存失去意义,每次都动态加载。 方法二 版本号控制,设置全局变量,每次发布前版本号加1 代码如下: “> 推荐这种做法,这种做法比较简单。缺点是HTML页面不能使用,但是这种页面应该不太多 更多方法:采用读取文件大小、文件修改时间生成MD5的方式自动...
.load方法没有设置 cache参数 默认true ,特别在IE浏览器下,一般的ajax的方法都是cache等于true的! 解决办法几个: 1.使用.ajax方法并设置 cache参数为false 代码如下: $.ajaxSetup ({ cache: false }); $(fucntion({ $.ajaxSetup ({ cache: false }); })) 在每次执行load方法前执行,注意不能设置为全局属性 可以写一个方法每次打开页面都引用这个方法 2.修改jquery.js中,load方法,load方法也是调用的.ajax,增加cache:false...
搞了一个微信网站,两套模板切换,但是有缓存,不能立即看的效果,要重新登微信才行 ,这个问题怎么解决回复内容:搞了一个微信网站,两套模板切换,但是有缓存,不能立即看的效果,要重新登微信才行 ,这个问题怎么解决 个人觉得,可以根据检测模板改变状态提示用户重新登录。 查找下缓存原因,可不可以根据你切换的事件进行不清除缓存。这样会根据用户使用自动更新。 如果是服务器的缓存,那是可以在切换的时候做个删除操作。如...