Odpowiedzi:
Możesz uzyskać dostęp do wartości ukrytych pól za pomocą val(), tak jak możesz to zrobić w przypadku każdego innego elementu wejściowego:
<input type="hidden" id="foo" name="zyx" value="bar" />
alert($('input#foo').val());
alert($('input[name=zyx]').val());
alert($('input[type=hidden]').val());
alert($(':hidden#foo').val());
alert($('input:hidden[name=zyx]').val());
To wszystko oznacza to samo w tym przykładzie.
Do tego służy selektor jQuery:
// Get all form fields that are hidden
var hidden_fields = $( this ).find( 'input:hidden' );
// Filter those which have a specific type
hidden_fields.attr( 'text' );
Wyświetli wszystkie ukryte pola wprowadzania i przefiltruje je według tych z określonym type="".
Najbardziej wydajnym sposobem jest identyfikacja.
$("#foo").val(); //by id
Możesz przeczytać więcej tutaj:
https://developer.mozilla.org/en-US/docs/Web/Guide/CSS/Writing_efficient_CSS
https://developers.google.com/speed/docs/best-practices/rendering?hl=it#UseEfficientCSSSelectors
Aby uzyskać wartość, użyj:
$.each($('input'),function(i,val){
if($(this).attr("type")=="hidden"){
var valueOfHidFiled=$(this).val();
alert(valueOfHidFiled);
}
});
lub:
var valueOfHidFiled=$('input[type=hidden]').val();
alert(valueOfHidFiled);
Aby ustawić wartość, użyj:
$('input[type=hidden]').attr('value',newValue);
Nie ma nic specjalnego w <input type="hidden">:
$('input[type="hidden"]').val()
Jeśli chcesz wybrać pojedyncze ukryte pole, możesz je wybrać za pomocą różnych selektorów jQuery:
<input type="hidden" id="hiddenField" name="hiddenField" class="hiddenField"/>
$("#hiddenField").val(); //by id
$("[name='hiddenField']").val(); // by name
$(".hiddenField").val(); // by class
Jeśli masz asp.net HiddenField, musisz:
Aby uzyskać dostęp do wartości HiddenField:
$('#<%=HF.ClientID%>').val() // HF = your hiddenfield ID
Aby ustawić HiddenFieldValue
$('#<%=HF.ClientID%>').val('some value') // HF = your hiddenfield ID
Uważaj, jeśli chcesz odzyskać wartość logiczną z ukrytego pola!
Na przykład:
<input type="hidden" id="SomeBoolean" value="False"/>
(Takie dane wejściowe będą renderowane przez ASP MVC, jeśli używasz @Html.HiddenFor(m => m.SomeBoolean) ).
Następujące polecenie zwróci ciąg znaków 'False', a nie wartość logiczną JS!
var notABool = $('#SomeBoolean').val();
Jeśli chcesz użyć wartości logicznej dla jakiejś logiki, użyj zamiast tego:
var aBool = $('#SomeBoolean').val() === 'True';
if (aBool) { /* ...*/ }
Najbardziej uniwersalnym sposobem jest przyjmowanie wartości według nazwy. Nie ma znaczenia, czy jego dane wejściowe, czy wybierz typ elementu formularza.
var value = $('[name="foo"]');