Выделите выбранное изображение в форме с помощью jQuery?

Я искал Google для ответа и нашел nada, поэтому даже ссылка на страницу, показывающую, как сделать следующее, будет высоко оценена.

в основном у меня есть форма только с изображениями

<form>
<input type="image" src="image.jpg" value="image_value">
<input type="image" src="image2.jpg" value="image_value2">
</form>

Я хочу иметь возможность каким-то образом выделить изображение, выбранное пользователем. Даже просто контур вокруг изображения 1, когда пользователь нажимает на изображение 1 будет идеальным.

Я уже использую Jquery в этом проекте, поэтому, если есть решение jquery это будет самое удобное.

5 ответов


An работает подход будет заключаться в стиле метки переключателей, чтобы вести себя как изображение выберите:

<form action="#" method="post">
    <input type="radio" class="radio" name="example" id="ex1" value="ex1" checked />
    <label for="ex1" class="label">Example 1</label>
    <input type="radio" class="radio" name="example" id="ex2" value="ex2" />
    <label for="ex2" class="label">Example 2</label>
</form>

а затем CSS. Как вы можете видеть, сами радиостанции скрыты с непрозрачностью 0:

.radio {
    opacity: 0;
    position: absolute;
}
.label {
    background: url(http://i.imgur.com/mW6xr2I.png);
    text-indent: -999em;
    border: 10px solid white;
    width: 126px;
    height: 126px;
    display: block;
    float: left;
    margin: 10px;
}
input[type="radio"]:checked + label {
    border: 10px solid orange;
}

вот пример в действии:http://jsfiddle.net/RH98R/

это имеет дополнительное преимущество, не имея зависимости от jQuery (или даже javascript, если на то пошло)!


обновление: пожалуйста, смотрите bryanbraun это. Его гораздо лучше.


в HTML <input type="image"> это просто кнопка отправки с изображением в качестве лица. Не думаю, что ты этого хочешь. Вероятно, вам нужен список реальных изображений, который при нажатии устанавливает скрытое значение формы в соответствии с атрибутом "data-value". Поэтому ваш HTML должен выглядеть примерно так:

<form id="select-form">
    <img src="image.jpg" data-value="image_value">
    <img src="image2.jpg" data-value="image_value2">
    <input type="hidden" id="image-value" name="selected_image" value="">
</form>

затем в вашем javascript вы хотите как выделить изображение, так и установите скрытое значение, например:

$('#select-form img').click(function() {
    // Set the form value
    $('#image-value').val($(this).attr('data-value'));

    // Unhighlight all the images
    $('#select-form img').removeClass('highlighted');

    // Highlight the newly selected image
    $(this).addClass('highlighted');
});

наконец, установите некоторые стили для класса выделения в файле CSS:

img.highlighted {
    border: 2px solid blue;
}

должно работать что-то вроде следующего, вы можете сделать классы CSS стилей и изменить стиль более легко.

$("input[type='image']")
    .focus(function() { $(this).css("border","solid 1px #f00"); })
    .blur(function() { $(this).css("border","0"); });

что-то вроде

CSS:

.selected { border: 1px solid black; }

javascript:

$(function() {
     $("input[type=image]").click(function(){ $(this).addClass('selected'); });
});

следующее даст каждому входному изображению границу 1px и заполнение 10px при нажатии, но в идеале вы должны дать им класс для их целевого использования:$(".imgs2higlight").bind()

  $(document).ready(function() {
            $("input[type='image']").bind('click',function(e) {
e.preventDefault();
            $(this).css({padding : '10px', border: "1px solid blue"});
            })
            })