Foros del Web » Programando para Internet » Jquery »

poner enlace en slider jquery

Estas en el tema de poner enlace en slider jquery en el foro de Jquery en Foros del Web. Hola, mi duda es la siguiente Tengo un slider que lo cogí ya hecho, en jquery, y tengo este código: <ul id="pikame"> <li><img src="images/display/thumbs/imagen1.jpg" ref="images/display/imagen2.jpg" ...
  #1 (permalink)  
Antiguo 11/03/2013, 09:49
 
Fecha de Ingreso: marzo-2013
Mensajes: 7
Antigüedad: 11 años, 8 meses
Puntos: 0
poner enlace en slider jquery

Hola, mi duda es la siguiente

Tengo un slider que lo cogí ya hecho, en jquery, y tengo este código:

<ul id="pikame">

<li><img src="images/display/thumbs/imagen1.jpg" ref="images/display/imagen2.jpg" alt="FreelanceSwitch" /><span>Contador de aforos<br /></span></li>

<li><img src="images/display/thumbs/imagen7.jpg" ref="images/display/imagen8.jpg" alt="AppStorm" /><span>Comptador d'aforaments<br /><small>Alta fiabilitat Baix cost</small></span></li>
<li><img src="images/display/thumbs/imagen3.jpg" ref="images/display/imagen4.jpg" alt="Queue3D" /><span>Gestor de colas<br /></span></li>
<li><img src="images/display/thumbs/imagen5.jpg" ref="images/display/imagen6.jpg" alt="Panel" /><span>Tutsplus<br /></span></li>


</ul>

el src es el iconito pequeño y el ref es la imagen grande, por lo que quiero que la gente al hacer click en la imagen grande se vaya a otra página mediante un enlace, pero si pongo un <a href> delante de la imagen, lo que es el enlace es el iconito pequeño y yo no quiero eso, quiero que el enlace sea el ref, hay alguna forma de lograrlo?

Gracias de antemano!

PD: Si sabéis de algún otro slider que permita que le des y se vaya a otro sitio agradecería muchísimo que me lo pasarais.

Última edición por daanii21; 11/03/2013 a las 10:20
  #2 (permalink)  
Antiguo 11/03/2013, 17:56
Avatar de iconogt  
Fecha de Ingreso: septiembre-2004
Ubicación: Guatemala
Mensajes: 576
Antigüedad: 20 años, 2 meses
Puntos: 4
Respuesta: poner enlace en slider jquery

Estás usando algún CMS? a ver y si nos pones el link de la librería que estás usando :) (el slider), creo que así te podría brindar una mejor ayuda.
__________________
_______
Jorge Rojas.
  #3 (permalink)  
Antiguo 11/03/2013, 23:11
Avatar de ipraetoriux  
Fecha de Ingreso: abril-2010
Ubicación: ipraetoriux.com
Mensajes: 1.125
Antigüedad: 14 años, 6 meses
Puntos: 155
Respuesta: poner enlace en slider jquery

...claro, pero mi amigo, no somos adivinos, que plugin estas usando?
  #4 (permalink)  
Antiguo 13/03/2013, 08:32
 
Fecha de Ingreso: marzo-2013
Mensajes: 7
Antigüedad: 11 años, 8 meses
Puntos: 0
Respuesta: poner enlace en slider jquery

No, no estoy usando un cms, simplemente es una plantilla que me venia con ese slider en jquery, en cuanto a la libreria o pluguin creo que es esto a lo que os referis:

http://ajax.googleapis.com/ajax/libs/jquery/1.2.6/jquery.min.js

muchas gracias! un saludo :D
  #5 (permalink)  
Antiguo 13/03/2013, 09:24
 
Fecha de Ingreso: junio-2008
Ubicación: Colombia
Mensajes: 207
Antigüedad: 16 años, 4 meses
Puntos: 12
Respuesta: poner enlace en slider jquery

haber varias cosas primero esto que mencionas => http://ajax.googleapis.com/ajax/libs.../jquery.min.js es el jquery no es ningun slider asi que supongo que debe haber otro archivo js por ahi que efectivamente te haga el slider.

el ref es un atributo custom tuyo? de ser asi te recomiendo que cuando uses atributos custom antepongas el data- esto se usa en html5 para metadatas, por ende quedaria data-ref="xxxx.jpg", no es obligatorio ni pasa nada solo es recomendación por cuestión de estandares

si entendi bien lo que quieres es que al hacer click en la imagen vayas a otra pagina y te la muestre siguiendo la ruta que esta en el ref... podrías hacer algo como esto en jquery

Código:
$('img').click(function(){
    var rutaImagen = $(this).attr('ref');  // guardo el ref en una variable
    window.open(rutaImagen , "_blank");
})

No se si funcione pero es un indicio
  #6 (permalink)  
Antiguo 14/03/2013, 08:26
 
Fecha de Ingreso: marzo-2013
Mensajes: 7
Antigüedad: 11 años, 8 meses
Puntos: 0
Respuesta: poner enlace en slider jquery

el jquery es este:

jQuery.iPikaChoose = {
build : function(user_options)
{
var user_options;
var defaults = {
show_captions: true,
slide_enabled: true,
auto_play: true,
show_prev_next: true,
slide_speed: 5000,
thumb_width: 50,
thumb_height: 40,
buttons_text: { play: "Play", stop: "Stop", previous: "", next: "" },
delay_caption: false,
user_thumbs: true,
transition: [5]
};

return jQuery(this).each(
function() {
//bring in options
var options = jQuery.extend(defaults, user_options);
// grab our images
var images = jQuery(this).children('li').children('img');
//hide the images so the user doesn't see crap
images.fadeOut(1);

//save our list for future ref
var ulist = jQuery(this);
images.each(LoadImages);
//start building structure
jQuery(this).before("<div class='pika_main'></div>");
// houses eveything about the UL
var main_div = jQuery(this).prev(".pika_main");

//add in slideshow elements when appropriate
if(options.slide_enabled){
main_div.append("<div class='pika_play'></div>");
var play_div = jQuery(this).prev(".pika_main").children(".pika_pl ay");
play_div.html("<a class='pika_play_button'>" + options.buttons_text.play + "</a><a class='pika_stop_button'>" + options.buttons_text.stop + "</a>");
play_div.fadeOut(1);
var play_anchor = play_div.children('a:first');
var stop_anchor = play_div.children('a:last');
}
//this div is used to make image and caption fade together
main_div.append("<div class='pika_subdiv'></div>");
var sub_div = main_div.children(".pika_subdiv");

//the main image we'll be using to load
sub_div.append("<img />");
var main_img = sub_div.children("img");

//create the caption div when appropriate
if(options.show_captions){
sub_div.append("<div class='pika_caption'></div>");
var caption_div = sub_div.children(".pika_caption");
}

//navigation div ALWAYS gets created, its refrenced a lot
jQuery(this).after("<div class='pika_navigation'></div>");
var navigation_div = jQuery(this).next(".pika_navigation");
//fill in sub elements
navigation_div.prepend("<a class='pika_play_next'>" + options.buttons_text.previous + "</a><a class='pika_play_previous'>" + options.buttons_text.next + "</a>");
var previous_image_anchor = navigation_div.children('a:first');
var next_image_anchor = navigation_div.children('a:last');

//hide the navigation if the user doesn't want it
if(!options.show_prev_next){
navigation_div.css("display","none");
}

//playing triggers the loop for the slideshow
var playing = options.auto_play;

main_img.wrap("<a></a>");
var main_link = main_img.parent("a");

function LoadImages()
{
jQuery(this).bind("load", function()
{
//had to make a seperate function so that the thumbnails wouldn't have problems
//from beings resized before loaded, thus not h/w

var w = jQuery(this).width();
var h = jQuery(this).height();
if(w===0){w = jQuery(this).attr("width");}
if(h===0){h = jQuery(this).attr("height");}
//grab a ratio for image to user defined settings
var rw = options.thumb_width/w;
var rh = options.thumb_height/h;

//determine which has the smallest ratio (thus needing
//to be the side we use to scale so our whole thumb is filled)
if(rw<rh){
//we'll use ratio later to scale and not distort
var ratio = rh;
var left = ((w*ratio-options.thumb_width)/2)*-1;
left = Math.round(left);
//set images left offset to match
jQuery(this).css({left:left});
}else{
var ratio = rw;
//you can uncoment this lines to have the vertical picture centered
//but usually tall photos have the focal point at the top...
//var top = ((h*ratio-options.thumb_height)/2)*-1;
//var top = Math.round(top);
var top = 0;
jQuery(this).css({top:top});
}
//use those ratios to calculate scale
var width = Math.round(w*ratio);
var height = Math.round(h*ratio);
jQuery(this).css("position","relative");
jQuery(this).width(width).height(height);
var imgcss={
width: width,
height: height
};
jQuery(this).css(imgcss);
jQuery(this).hover(
function(){jQuery(this).fadeTo(250,1);},
function(){if(!jQuery(this).hasClass("pika_selecte d")){jQuery(this).fadeTo(250,0.6);}}
);
jQuery(this).fadeTo(250,0.6);

if(jQuery(this).hasClass('pika_first')){
jQuery(this).trigger("click",["auto"]);
}

});

//clone so the on loads will fire correctly
var newImage = jQuery(this).clone(true).insertAfter(this);

jQuery(this).remove();

//reset images to the clones
images = ulist.children('li').children('img');
}
function activate()
{
//sets the intial phase for everything

//image_click is controls the fading
images.bind("click",image_click);
//hiding refrence to slide elements if slide is disabled
if(options.slide_enabled){
if(options.auto_play){
playing = true;
play_anchor.hide();
stop_anchor.show();
}else{
play_anchor.show();
stop_anchor.hide();
}
}

images.filter(":last").addClass("pika_last");
images.filter(":first").addClass("pika_first");
//css for the list
var licss = {
width: options.thumb_width+"px",
height: options.thumb_height+"px",
"list-style": "none",
overflow: "hidden"
};
images.each(function(){
jQuery(this).parent('li').css(licss);
//fixes a bug where images don't get the correct display after loading
if(jQuery(this).attr('complete')==true && jQuery(this).css('display')=="none")
{
jQuery(this).css({display:'inline'});
}
});
//previous link to go back an image
previous_image_anchor.bind("click",previous_image) ;
//ditto for forward, also the item that gets auto clicked for slideshow
next_image_anchor.bind("click",next_image);
}//end activate function

function image_click(event, how){
//catch when user clicks on an image Then cancel current slideshow
if(how!="auto"){
if(options.slide_enabled){
stop_anchor.hide();
play_anchor.show();
playing=false;
}
main_img.stop();
main_img.dequeue();
if(options.show_captions)
{
caption_div.stop();
caption_div.dequeue();
}
}
//all our image variables
if(options.user_thumbs)
{
var image_source = jQuery(this).attr("ref");
}else
{
var image_source = jQuery(this).attr("src");
}
var image_link = jQuery(this).attr("ref");
var image_caption = jQuery(this).next("span").html();

//fade out the old thumb
images.filter(".pika_selected").fadeTo(250,.6);
images.filter(".pika_selected").removeClass("pika_ selected");
//fade in the new thumb
jQuery(this).fadeTo(250,1);
jQuery(this).addClass("pika_selected");
//fade the old image out and the new one in
if(options.show_captions)
{
if(options.delay_caption)
{
caption_div.fadeTo(800,0);
}
caption_div.fadeTo(500,0,function(){
caption_div.html(image_caption);
caption_div.fadeTo(800,1);
});
}

main_img.fadeTo(500,0.07,function(){
main_img.attr("src",image_source);
main_link.attr("href", image_link);

main_img.fadeTo(800,1,function(){
if(playing){
jQuery(this).animate({top:0},options.slide_speed, function(){
//redudency needed here to catch the user clicking on an image during a change.
if(playing){next_image_anchor.trigger("click",["auto"]);}
});
}
});
});
}//end image_click function

function next_image(event, how){
if(images.filter(".pika_selected").hasClass("pika_ last")){
images.filter(":first").trigger("click",how);
}else{
images.filter(".pika_selected").parent('li').next( 'li').children('img').trigger("click",how);
}
}//end next image function

function previous_image(event, how){
if(images.filter(".pika_selected").hasClass("pika_ first")){
images.filter(":last").trigger("click",how);
}else{
images.filter(".pika_selected").parent('li').prev( 'li').children('img').trigger("click",how);
}
}//end previous image function

function play_button(){
main_div.hover(
function(){play_div.fadeIn(400);},
function(){play_div.fadeOut(400);}
);
play_anchor.bind("click", function(){
main_img.stop();
main_img.dequeue();
if(options.show_captions)
{
caption_div.stop();
caption_div.dequeue();
}
playing = true;
next_image_anchor.trigger("click",["auto"]);
jQuery(this).hide();
stop_anchor.show();
});
stop_anchor.bind("click", function(){
playing = false;
jQuery(this).hide();
play_anchor.show();
});
}
if(options.slide_enabled){play_button();}
activate();

});//end return this.each
}//end build function

//activate applies the appropriate actions to all the different parts of the structure.
//and loads the sets the first image
};//end jquery.ipikachoose
jQuery.fn.PikaChoose = jQuery.iPikaChoose.build;
  #7 (permalink)  
Antiguo 14/03/2013, 08:29
 
Fecha de Ingreso: marzo-2013
Mensajes: 7
Antigüedad: 11 años, 8 meses
Puntos: 0
Respuesta: poner enlace en slider jquery

y en el html tengo esto:

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.2.6/jquery.min.js"></script>
<script type="text/javascript" src="js/pikachoose.js"></script>
<script type="text/javascript">
<!--
$(document).ready(function(){
$("#pikame").PikaChoose();
});
-->
</script>

Simplemente con que la imagen grande no fuera a un enlace donde sale la imagen y no diera esa opcion ya estaria contento.. si alguien sabe algún modo..

Última edición por daanii21; 14/03/2013 a las 10:04

Etiquetas: diseño-web, enlace, página, slider
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 09:23.