其实很简单的,代码是大神的代码,只是作为一个记录而已。那就上代码。
此函数的主要作用为:
function addLoadEvent(func) {
var oldonload = window.onload;
if (typeof window.onload != 'function') {
window.onload=func;
}else {
window.onload = function() {
oldonload();
func();
}
}
}
1. 把现有的 window.onload 的事件处理函数的值存入变量 oldonload 。
2. 如果在这个处理函数上还没有绑定任何函数,则默认把新函数添加给它。
3. 如果在这个处理函数上已经绑定了一些函数,就把新的函数追加到现有指令的末尾。
使用的时候,就类似于这样。
addLoadEvent(函数名);
addLoadEvent(函数名);
例如:
addLoadEvent(a);
function a() {
//something here
}
升级了 WordPress 3.2 之后,主题有些许不兼容了,表现在我的 lazyload 插件不能用了,还有我的返回顶部插件,我的 ajax 评论插件也不能用了,怎么办呢,找问题呗,然后就发现是新版本的 WordPress 使用的 jQuery 库为 1.6.1 版本,和我某些插件的 1.4.2 版本不兼容,OK,问题找到了,那就解决问题。
其实很简单,就是一句代码,在你博客主题文件中的 function.php 文件中,添加一段代码即可。
<?php wp_deregister_script(‘jquery’);?>
作用就是反注册 jQuery 这个 js 库。从而使 WP 不加载 jQuery 这个库。所以 WP 就不加载 1.6.1 版本的这个 jQuery 库了,但是要手动在主题的 header.php 中引用兼容版本的 jQuery 库。
其实,还有一个重要的问题,就是 使用了这个代码之后,WP 后台很多需要 jQuery 的功能都不正常了,那就没办法了,不使用这个代码了。但是去掉之后,如果 jQuery 没有回去,那就用另外一句代码让它回去。
<?php wp_register_script(‘jquery’); >
嘿嘿嘿,重新注册。OK。
其实,还有一种方式可以解决 js 的冲突,那就是使用
<?php wp_enqueue_script( $handle, $src, $deps, $ver, $in_footer ); >
函数。具体介绍请移步这里查看。
具体方法就是在你的主题文件的 function.php 里面,添加
<?php
function my_init_method() {
wp_deregister_script( 'jquery' );
wp_register_script( 'jquery', 'http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js');
wp_enqueue_script( 'jquery' );
}
add_action('init', 'my_init_method');
?>
然后将,里面的 js 的地址,换成你想使用的地址即可。当然了,那个 jquery 关键字,也是要替换的。
不过貌似后台必须使用1.6.1才可以,唉,我的lazyload要割爱了啊。
打完收工。