Выделение изображения Javascript (объяснение)

#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 Где ... — пример кода, который я предоставил в ответе.