Respuestas:
La forma correcta de hacer esto es usar show
y hide
:
$('#id').hide();
$('#id').show();
Una forma alternativa es usar el método jQuery css :
$("#id").css("display", "none");
$("#id").css("display", "block");
$(".class").css("display", "none");
$('#id').css('display', 'none');
, pero no funcionó. Sin embargo, el uso $('#id').css('color', 'red');
funciona. Sin embargo, no estoy seguro de por qué. ¿Alguien tiene alguna idea? Gracias por adelantado.
Hay varias formas de lograr esto, cada una con su propio propósito.
1. ) Para usar en línea mientras simplemente asigna a un elemento una lista de cosas que hacer
$('#ele_id').css('display', 'block').animate(....
$('#ele_id').css('display', 'none').animate(....
2. ) Para usar mientras se configuran varias propiedades CSS
$('#ele_id').css({
display: 'none'
height: 100px,
width: 100px
});
$('#ele_id').css({
display: 'block'
height: 100px,
width: 100px
});
3. ) Para llamar dinámicamente al comando
$('#ele_id').show();
$('#ele_id').hide();
4. ) Para alternar dinámicamente entre bloque y ninguno, si es un div
$ ('# # ele_id'). toggle ();
Si la visualización del div está bloqueada de manera predeterminada, puede usar .show()
y .hide()
, o incluso más simple, .toggle()
alternar entre la visibilidad.
Para ocultar:
$("#id").css("display", "none");
Para mostrar:
$("#id").css("display", "");
Manera simple:
function displayChange(){
$(content_id).click(function(){
$(elem_id).toggle();}
)}
(function($){
$.fn.displayChange = function(fn){
$this = $(this);
var state = {};
state.old = $this.css('display');
var intervalID = setInterval(function(){
if( $this.css('display') != state.old ){
state.change = $this.css('display');
fn(state);
state.old = $this.css('display');
}
}, 100);
}
$(function(){
var tag = $('#content');
tag.displayChange(function(obj){
console.log(obj);
});
})
})(jQuery);
En caso de que desee ocultar y mostrar un elemento, dependiendo de si ya está visible o no, puede usar alternar en lugar de .hide()
y.show()
$('elem').toggle();
En mi caso, estaba haciendo mostrar / ocultar elementos de un formulario según si un elemento de entrada estaba vacío o no, de modo que al ocultar los elementos el elemento que seguía a los ocultos se reposicionó ocupando su espacio era necesario hacer un flotador: izquierda del elemento de tal elemento. Incluso usando un complemento como depende De era necesario usar float.
Utilizar este:
$("#id").(":display").val("block");
O:
$("#id").(":display").val("none");
<style> #choosepath { display: none; } </style> <script> $(document).ready(function () { $('#btn_journey').click(function () { alert("button click"); $('#choosepath').css({"display":"normal"}); }); }); </script> </head> <body> <a href="#" class="btn btn-primary btn-lg" id="btn_journey">Start your journey</a> <div class="col-lg-3 col-md-6 mb-4" id="choosepath"> </div> </body></html>
Utilizar:
$(#id/.class).show()
$(#id/.class).hide()
Esta es la mejor manera.
#id
usado para identificadores ¿qué pasa si quiero usarclass
?