Как изменить атрибут alt изображения несколько раз с помощью jQuery?
Этот вопрос завершает первый вопрос, который я задал здесь о том, как изменить изображение при клике с помощью jQuery.
Я забыл сказать (даже если я отредактировал свой пост позже), что я ищу способ иметь другой атрибут alt каждый раз, когда изображение изменяется при щелчке.
(Это для лучшей доступности и оптимизации SEO.)
Вот фактический HTML-код благодаря altCognito:
<img id="radio_btn1" src="originalimage1.jpg" />
<br />
<input type="radio" name="radio_btn1" value='image1.jpg' />
<input type="radio" name="radio_btn1" value='image2.gif' />
<input type="radio" name="radio_btn1" value='image3.png' />
<input type="radio" name="radio_btn1" value='image4.jpeg' />
И JQuery:
imgFldr = 'images/nameofthesubfolder/';
$("input[type='radio']").click(function() {
$('#'+this.name).attr('src', imgFldr+this.value).attr('alt', 'newattribute');
});
Это может быть отредактировано в jsbin.
5 ответов
Ну... SEO и контент, которым манипулирует Javascript, не должны быть в одном посте с самого начала. Что бы вы ни делали, если вы используете Javascript для отображения своего контента, вы ухудшаете видимость своей поисковой системы.
Тем не менее, вы можете либо получить эти изображения в хеш-массиве (imagename->alt) и получить оттуда alt, либо вы можете поместить alt в значение радио, объединенного с именем файла, с разделителем, таким как | а затем разобрать их в функции, которую вы используете для отображения изображения.
... так короче либо:
<img id="radio_btn1" src="originalimage1.jpg" />
<br />
<input type="radio" name="radio_btn1" value='image1.jpg|Image 1' />
<input type="radio" name="radio_btn1" value='image2.gif|Image 2' />
<input type="radio" name="radio_btn1" value='image3.png|Image 3' />
<input type="radio" name="radio_btn1" value='image4.jpeg|Image 4' />
+
imgFldr = 'images/nameofthesubfolder/';
$("input[type='radio']").click(function() {
var strarr = this.value.split('|');
if(strarr.length < 2) return;
$('#'+this.name).attr('src', imgFldr+strarr[0]).attr('alt', strarr[1]);
});
...или же:
<img id="radio_btn1" src="originalimage1.jpg" />
<br />
<input type="radio" name="radio_btn1" value='image1.jpg' />
<input type="radio" name="radio_btn1" value='image2.gif' />
<input type="radio" name="radio_btn1" value='image3.png' />
<input type="radio" name="radio_btn1" value='image4.jpeg' />
+
imgFldr = 'images/nameofthesubfolder/';
var imagesarr = {'image1.jpg': 'Image 1', 'image2.gif': 'Image 2','image3.png': 'Image 3','image4.jpeg': 'Image 4'}
$("input[type='radio']").click(function() {
$('#'+this.name).attr('src', imgFldr+this.value).attr('alt', imagesarr[this.value]);
});
Я бы не стал использовать name
атрибут в переключателях для этого. Определите пользовательский атрибут: data-Img
или что-то типа того. Это также поможет вам соответствовать следующему стандарту HTML.
var imgFldr = 'images/nameofthesubfolder/';
$("input[type='radio']").click(function() {
var img = '#'+ $(this).attr('data-Img');
var url = imgFldr + $(this).attr('value');
$(img).attr('src', url)
.attr('alt', 'newattribute');
});
Возможно, вы могли бы сделать это в одну строку... но я не вижу смысла на самом деле. Сделайте это читабельным в первую очередь.
Почему бы не указать значение alt в rel входного значения, а затем поместить его на изображение:
<img id="radio_btn1" src="originalimage1.jpg" />
<br />
<input type="radio" name="radio_btn1" value='image1.jpg' rel="alt text 1" />
<input type="radio" name="radio_btn1" value='image2.gif' rel="alt text 1" />
<input type="radio" name="radio_btn1" value='image3.png' rel="alt text 1" />
<input type="radio" name="radio_btn1" value='image4.jpeg' rel="alt text 1" />
And the jquery:
imgFldr = 'images/nameofthesubfolder/';
$("input[type='radio']").click(function() {
$("#radio_btn1").attr("src", imgFldr + $(this).val()).attr("alt", $(this).attr("rel"));
});
Просто скопируйте вставить на новую страницу... у вас есть 2 способа изменить это.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<meta http-equiv="Content-type" content="text/html; charset=utf-8" />
<title>Sandbox</title>
<style type="text/css" media="screen">
body { background-color: #000; font: 16px Helvetica, Arial; color: #fff; }
</style>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
<script type="text/javascript">
imgFldr = 'http://www.kde-look.org/CONTENT/content-m1/';
$(document).ready(function(){
$("input[type='radio']").each( function(index) {
var $radio = this;
var alt = '';
switch (index + 1) {
case 1: alt = 'alt 1'; break;
case 2: alt = 'alt 2'; break;
case 3: alt = 'alt 3'; break;
case 4: alt = 'alt 4'; break;
}
console.log('img ' + (index+1) + ': ' + $radio.value + ' with alt: ' + alt);
$(this).click(function() {
// 1st way: using mynewalt attribute of the radio button (you can delete the switch case if you choose to use this)
$('#myImage').attr('src', imgFldr+$radio.value).attr('alt', $(this).attr('mynewalt'));
//2nd way: using the switch
$('#myImage').attr('src', imgFldr+$radio.value).attr('alt', alt);
});
});
});
</script>
</head>
<body>
<img id="myImage" src="http://www.kde-look.org/CONTENT/content-m1/m100860-1.png" />
<br />
<input type="radio" name="radio_btn1" value='m102389-1.png' mynewalt='new alt 1' />
<input type="radio" name="radio_btn1" value='m100856-1.png' mynewalt='new alt 2' />
<input type="radio" name="radio_btn1" value='m100857-1.png' mynewalt='new alt 3' />
<input type="radio" name="radio_btn1" value='image4.jpeg' mynewalt='new alt 4' />
</body>
</html>
Вы можете попробовать что-то вроде этого:
<img id="radio_btn1" src="originalimage1.jpg" />
<br />
<input type="radio" name="radio_btn1" value='image1' />
<input type="radio" name="radio_btn1" value='image2' />
<input type="radio" name="radio_btn1" value='image3' />
<input type="radio" name="radio_btn1" value='image4' />
imgFldr = 'images/nameofthesubfolder/';
var images = {
image1: {'img': 'image1.jpg', 'alt': 'Alt for img1'},
image2: {'img': 'image2.gif', 'alt': 'Alt for img2'},
image3: {'img': 'image3.png', 'alt': 'Alt for img3'},
image4: {'img': 'image4.jpeg', 'alt': 'Alt for img4'}
}
$("input[type='radio']").click(function() {
var imgObject = images[this.value];
$('#'+this.name).attr('src', imgFldr+imgObject['img']).attr('alt', imgObject['alt']);
});