gpt4 book ai didi

Javascript 图像高亮(解释)

转载 作者:可可西里 更新时间:2023-11-01 14:57:38 24 4
gpt4 key购买 nike

嗨我一直在设计一些网站,使用 javascript 的基本知识和透彻的 css 和 html。我最近被指派为另一个网站添加一些简单的下拉菜单,这本身很简单,但是该网站有一些现有的代码,既长又我不明白。简单地说,我希望有人能帮助我将它转换成 jQuery 以及它是如何工作的,即我如何更改它以使其与我的下拉菜单一起工作。在这里:

<script type="text/javascript">
<!--
function MM_preloadImages() { //v3.0
var d=document; if(d.images){ if(!d.MM_p) d.MM_p=new Array();
var i,j=d.MM_p.length,a=MM_preloadImages.arguments; for(i=0; i<a.length; i++)
if (a[i].indexOf("#")!=0){ d.MM_p[j]=new Image; d.MM_p[j++].src=a[i];}}
}

function MM_findObj(n, d) { //v4.01
var p,i,x; if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {
d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}
if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];
for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document);
if(!x && d.getElementById) x=d.getElementById(n); return x;
}

function MM_nbGroup(event, grpName) { //v6.0
var i,img,nbArr,args=MM_nbGroup.arguments;
if (event == "init" && args.length > 2) {
if ((img = MM_findObj(args[2])) != null && !img.MM_init) {
img.MM_init = true; img.MM_up = args[3]; img.MM_dn = img.src;
if ((nbArr = document[grpName]) == null) nbArr = document[grpName] = new Array();
nbArr[nbArr.length] = img;
for (i=4; i < args.length-1; i+=2) if ((img = MM_findObj(args[i])) != null) {
if (!img.MM_up) img.MM_up = img.src;
img.src = img.MM_dn = args[i+1];
nbArr[nbArr.length] = img;
} }
} else if (event == "over") {
document.MM_nbOver = nbArr = new Array();
for (i=1; i < args.length-1; i+=3) if ((img = MM_findObj(args[i])) != null) {
if (!img.MM_up) img.MM_up = img.src;
img.src = (img.MM_dn && args[i+2]) ? args[i+2] : ((args[i+1])? args[i+1] : img.MM_up);
nbArr[nbArr.length] = img;
}
} else if (event == "out" ) {
for (i=0; i < document.MM_nbOver.length; i++) {
img = document.MM_nbOver[i]; img.src = (img.MM_dn) ? img.MM_dn : img.MM_up; }
} else if (event == "down") {
nbArr = document[grpName];
if (nbArr)
for (i=0; i < nbArr.length; i++) { img=nbArr[i]; img.src = img.MM_up; img.MM_dn = 0; }
document[grpName] = nbArr = new Array();
for (i=2; i < args.length-1; i+=2) if ((img = MM_findObj(args[i])) != null) {
if (!img.MM_up) img.MM_up = img.src;
img.src = img.MM_dn = (args[i+1])? args[i+1] : img.MM_up;
nbArr[nbArr.length] = img;
} }
}
//-->
</script>

非常感谢

最佳答案

这看起来像是旧的 WYSIWYG 编辑器遗留下来的代码(MM 可能是 MacroMedia 的首字母缩写词)。

当您对它进行反混淆并弄清楚它的作用时,您可能已经用 jQuery 以可读的方式重写了它。

更新

我刚刚看了your site , 效果看起来可以单独使用 CSS 实现(更具体地说,:hover 伪类)。

更新

我宁愿使用 CSS 和背景图片,但如果您想保留 img 元素,这会起作用。只需将悬停 状态图像命名为理智的名称即可。

另外,为什么每个 li 都有自己的 ul 父级……很奇怪。

$('#nav li a img').each(function() {
var originalSrc = this.src,
hoverSrc = originalSrc.replace(/\.(gif|png|jpe?g)$/, '_hover.$1');

$(this).hover(function() {
this.src = hoverSrc;
}, function() {
this.src = originalSrc;
});
});

关于Javascript 图像高亮(解释),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5786319/

24 4 0