#javascript #jquery #html
#javascript #jquery #HTML
Вопрос:
Привет, я разрабатывал несколько веб-сайтов, используя базовые знания 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("?"))>0amp;amp;parent.frames.length) {
d=parent.frames[n.substring(p 1)].document; n=n.substring(0,p);}
if(!(x=d[n])amp;amp;d.all) x=d.all[n]; for (i=0;!xamp;amp;i<d.forms.length;i ) x=d.forms[i][n];
for(i=0;!xamp;amp;d.layersamp;amp;i<d.layers.length;i ) x=MM_findObj(n,d.layers[i].document);
if(!x amp;amp; 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" amp;amp; args.length > 2) {
if ((img = MM_findObj(args[2])) != null amp;amp; !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 amp;amp; 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>
Большое спасибо
Комментарии:
1. Я думаю, вы можете использовать это напрямую, все перечисленные скрипты были написаны с использованием базового синтаксиса
2. @Paul что ты под этим подразумеваешь.
Ответ №1:
Это похоже на код, оставшийся от старого редактора WYSIWYG ( MM
может быть аббревиатурой MacroMedia
).
К тому времени, как вы де-запутали его и разобрались, что он делает, вы, возможно, также переписали его в удобочитаемом виде с помощью jQuery.
Обновить
Я только что просмотрел ваш сайт, и эффект выглядит так, как будто его можно достичь, используя только 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;
});
});
Комментарии:
1. Хотелось бы, но дело в том, что этот код делает, если вы проверяете эту страницу sundalah.com.au . При наведении курсора мыши меню, созданное с использованием изображений, выделяется. О, и спасибо за реструктуризацию моего поста.
2. Я постоянно использую псевдокласс:hover, проблема в том, что меню не содержит текста, оно состоит из изображений, и на каждой из страниц изображения разные. Я действительно не хочу создавать второе изображение «при наведении курсора» для каждого отдельного изображения меню на всех страницах.
3. @Jason
:hover
может изменитьсяbackground-image
.4. @alex чем это полезно? Мне нужно изменить свойство изображения без изменения самого изображения. Я думал о наложении текста на изображение, однако это становится немного сложнее для простого выделения меню. Я просто хотел оказать аналогичное влияние на то, что в настоящее время делается на www.sundalah.com.au страница
5. @Jason Где
...
— пример кода, который я предоставил в ответе.