关于预加载InstantClick的问题解决方法


Posted in Javascript onSeptember 12, 2017

昨晚在改造的时候代码高亮没法执行,准确的说是只执行一次,第二次就不执行了。所以发文说明一下,而且大致看了InstantClick的文档,主要还是一个黑名单区域的问题。按我个人的理解,黑名单主要包含两种比较常见的过滤类型,一种是a标签,另一种是js。根据其原理实际上就是对黑名单区域不进行处理(按正常手动打开的情况加载刷新),这种不处理才能让相关的结构和js起作用。。

所以在InstantClick执行时,看它的引用语句:

<script type="text/javascript" src="<?php bloginfo('template_directory'); ?>/js/instantclick.min.js" data-no-instant></script>
<script data-no-instant>InstantClick.init();</script>

语句作用就过滤掉了InstantClick它本身,相当于在执行后正常刷新一遍自己。

正常加载刷新js

语句本身的data-no-instant参数意思就是不处理,并且正常刷新这部分结构。所以如果要其他js在InstantClick下起作用,必须将js本身刷新,可以把代码写入instantclick.min.js里面,也可以带上data-no-instant参数独立引用。如果不将自己的js写入instantclick.min.js内,就要利用它的四个参数来重新载入,参考:http://instantclick.io/scripts

<script data-no-instant>
InstantClick.on('change', function() {
// 回调
});
InstantClick.init();
</script>

a标签

InstantClick对新窗口打开的a标签是不处理的,还有在带有data-no-instant参数的标签包裹下的a标签也不会处理。如<div data-no-instant>这部分会按正常情况刷新</div>。

最后总结:data-no-instant属性是用来避免instantclick在页面切换时对该元素重复加载(意思就是按正常刷新)。它可以用在script、style标签中,也能放在a标签中,表示该链接将使用正常方式打开而不用instantclick加速,但对于div标签是没有用的,这一点必须知晓。

搞清楚上面两点就好办了,之前把它当成是ajax来理解,是整个body请求过来。也就是说把不处理的部分放在body标签之外也是可以的。

值得一提的是,我个人还是很中意它缓存后退前进的功能的,这样非常快。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 继承详解 第一篇
Aug 30 Javascript
Javascript面向对象之四 继承
Feb 08 Javascript
jquery实现兼容浏览器的图片上传本地预览功能
Oct 14 Javascript
通过XMLHttpRequest和jQuery实现ajax的几种方式
Aug 28 Javascript
js实现带农历和八字等信息的日历特效
May 16 Javascript
JS封装的三级联动菜单(使用时只需要一行js代码)
Oct 24 Javascript
Bootstrap中data-target 到底是什么
Feb 14 Javascript
bootstrap table 多选框分页保留示例代码
Mar 08 Javascript
基于JavaScript实现五子棋游戏
Aug 26 Javascript
解决vuex刷新状态初始化的方法实现
Aug 15 Javascript
BootstrapValidator实现表单验证功能
Nov 08 Javascript
ant-design-vue 实现表格内部字段验证功能
Dec 16 Javascript
提升页面加载速度的插件InstantClick
Sep 12 #Javascript
详解如何让InstantClick兼容MathJax、百度统计等
Sep 12 #Javascript
使用InstantClick.js让页面提前加载200ms
Sep 12 #Javascript
VueJs组件prop验证简单介绍
Sep 12 #Javascript
js字符限制(字符截取) 一个中文汉字算两个字符
Sep 12 #Javascript
67 个节约开发时间的前端开发者的工具、库和资源
Sep 12 #Javascript
react-native DatePicker日期选择组件的实现代码
Sep 12 #Javascript
You might like
PHP定时更新程序设计思路分享
2014/06/10 PHP
PHP和MYSQL实现分页导航思路详解
2017/04/11 PHP
PHP从零开始打造自己的MVC框架之入口文件实现方法详解
2019/06/03 PHP
js中的escape及unescape函数的php实现代码
2007/09/04 Javascript
javascript 密码框防止用户粘贴和复制的实现代码
2014/02/17 Javascript
php的文件上传入门教程(实例讲解)
2014/04/10 Javascript
javascript数组操作方法小结和3个属性详细介绍
2014/07/05 Javascript
jQuery分组选择器用法实例
2014/12/23 Javascript
JavaScript中pop()方法的使用教程
2015/06/09 Javascript
实例代码详解javascript实现窗口抖动及qq窗口抖动
2016/01/04 Javascript
js仿百度切换皮肤功能(html+css)
2016/07/10 Javascript
angularjs实现下拉列表的选中事件示例
2017/03/03 Javascript
mac下的nodejs环境安装的步骤
2017/05/24 NodeJs
详解Vue Elememt-UI构建管理后台
2018/02/27 Javascript
jQuery实现的两种简单弹窗效果示例
2018/04/18 jQuery
vue、react等单页面项目部署到服务器的方法及vue和react的区别
2018/09/29 Javascript
基于JavaScript实现每日签到打卡轨迹功能
2018/11/29 Javascript
vue解决花括号数据绑定不成功的问题
2019/10/30 Javascript
Vue和React有哪些区别
2020/09/12 Javascript
jQuery实现本地存储
2020/12/22 jQuery
一步步解析Python斗牛游戏的概率
2016/02/12 Python
Python变量和字符串详解
2017/04/29 Python
Windows下python3.7安装教程
2018/07/31 Python
python实现简易动态时钟
2018/11/19 Python
对python多线程SSH登录并发脚本详解
2019/02/14 Python
python开发入门——set的使用
2020/09/03 Python
python利用faker库批量生成测试数据
2020/10/15 Python
军校制空专业毕业生自我鉴定
2013/11/16 职场文书
项目经理任命书范本
2014/06/05 职场文书
聘用意向书
2014/07/29 职场文书
公司委托书格式
2014/08/01 职场文书
白酒营销策划方案
2014/08/17 职场文书
2015年社区宣传工作总结
2015/05/20 职场文书
宾馆安全管理制度
2015/08/06 职场文书
Golang实现AES对称加密的过程详解
2021/05/20 Golang
解决Pytorch中关于model.eval的问题
2021/05/22 Python