sebenarnya jQuery hanya membersihkan nilai properti 'display', dan tidak mengaturnya menjadi 'block' (lihat implementasi internal jQuery.showHide ()) -
function showHide(elements, show) {
var display, elem, hidden,
...
if (show) {
// Reset the inline display of this element to learn if it is
// being hidden by cascaded rules or not
if (!values[index] && display === "none") {
elem.style.display = "";
}
...
if (!show || elem.style.display === "none" || elem.style.display === "") {
elem.style.display = show ? values[index] || "" : "none";
}
}
Harap dicatat bahwa Anda dapat mengganti $ .fn.show () / $. Fn.hide (); menyimpan tampilan asli dalam elemen itu sendiri ketika bersembunyi (misalnya sebagai atribut atau dalam $. Data ()); dan kemudian menerapkannya kembali saat ditampilkan.
Juga, menggunakan css penting! mungkin tidak akan berfungsi di sini - karena menetapkan inline gaya biasanya lebih kuat daripada aturan lainnya