几个星期前,我将这个javascript添加到我的网站,并在我的网站上正常运行,但现在它似乎无法正常运行。
该脚本被称为:
tooltips.js
这是一个javascript,可以使<abbr>
标记变得具有响应性,因此当某人在移动设备上查看该网站时,他们可以点击而不是将鼠标悬停在该对象上允许他们查看信息。
不幸的是,即使页面正在调用javascript,它也没有预先确定它的功能。因此,观看者在手机或平板电脑上根本无法看到信息。
代码如下:
jQuery( document ).ready( function($)
{
var targets = $( '[rel~=tooltip]' ),
target = false,
tooltip = false,
title = false;
targets.bind( 'mouseenter', function()
{
target = $( this );
tip = target.attr( 'title' );
tooltip = $( '<div id="tooltip"></div>' );
if( !tip || tip == '' )
return false;
target.removeAttr( 'title' );
tooltip.css( 'opacity', 0 )
.html( tip )
.appendTo( 'body' );
var init_tooltip = function()
{
if( $( window ).width() < tooltip.outerWidth() * 1.5 )
tooltip.css( 'max-width', $( window ).width() / 2 );
else
tooltip.css( 'max-width', 340 );
var pos_left = target.offset().left + ( target.outerWidth() / 2 ) - ( tooltip.outerWidth() / 2 ),
pos_top = target.offset().top - tooltip.outerHeight() - 20;
if( pos_left < 0 )
{
pos_left = target.offset().left + target.outerWidth() / 2 - 20;
tooltip.addClass( 'left' );
}
else
tooltip.removeClass( 'left' );
if( pos_left + tooltip.outerWidth() > $( window ).width() )
{
pos_left = target.offset().left - tooltip.outerWidth() + target.outerWidth() / 2 + 20;
tooltip.addClass( 'right' );
}
else
tooltip.removeClass( 'right' );
if( pos_top < 0 )
{
var pos_top = target.offset().top + target.outerHeight();
tooltip.addClass( 'top' );
}
else
tooltip.removeClass( 'top' );
tooltip.css( { left: pos_left, top: pos_top } )
.animate( { top: '+=10', opacity: 1 }, 50 );
};
init_tooltip();
$( window ).resize( init_tooltip );
var remove_tooltip = function()
{
tooltip.animate( { top: '-=10', opacity: 0 }, 50, function()
{
$( this ).remove();
});
target.attr( 'title', tip );
};
target.bind( 'mouseleave', remove_tooltip );
tooltip.bind( 'click', remove_tooltip );
});
});
我为子主题创建了一个function.php,该主题只在此特定页面上调用了代码:
<?php
if ( !function_exists( 'tool_tips' ) ) {
function tooltips() {
if ( is_page( 'services' ) ) {
wp_enqueue_script( 'tooltips', get_stylesheet_directory_uri() . '/js/tooltips.js', '', '1.0', true );
}
}
}
add_action( 'wp_enqueue_scripts', 'tooltips' );
?>
就像我之前所说的那样,它在过去的几周里一直没有问题(我甚至在上周末检查了它),今天我注意到它停止了工作。
由于页面实际上正在调用脚本,但它无法正常运行,我相信我的脚本有问题或者其他脚本正在影响它。我是jQuery的新手,因此我很难通过代码找到问题,因为我知道很多人在这里很容易看到。
非常感谢。