2016-02-22 14 views
6

Tôi tìm thấy một vấn đề lạ với phần đầu của tôi cố định theo các điều kiện sau đây:Các vấn đề với vị trí CSS: cố định trong iOS 9 iPhone 6 trở lên trong chế độ phong cảnh

  1. iphone 6 +, chế độ phong cảnh
  2. safari, tại ít nhất hai tab mở
  3. trang của tôi có một vị trí: tiêu đề cố định và một cơ thể và html với position: relative, height: 100%

Sau khi tải trang và khi di chuyển xuống, tất cả hoạt động tốt, tiêu đề là tại chỗ và kiểm tra web ector thấy nó một cách chính xác:

enter image description here enter image description here

Nhưng khi bạn di chuyển lên và kéo trang xuống màn hình và phát hành, tiêu đề là vẫn hiển thị trên trang, nhưng trên thực tế nó được chuyển đâu đó dưới khung nhìn (thấy rằng thanh tra web không làm nổi bật nó).

enter image description here

kết quả thực tế này trong tất cả các yếu tố tiêu đề là unaccessible: bạn không thể mở trình đơn, nhấp vào biểu tượng hoặc nút liên lạc.

Phần header đi trở lại bình thường khi:

  1. bạn cuộn xuống (nhưng phá vỡ một lần nữa khi bạn di chuyển trở lại)
  2. chuyển sang tab khác và ngược lại
  3. hoặc gần các tab khác

Tôi đã thử thay đổi DOM hoặc/và CSS của tiêu đề và nội dung, nhưng không có gì đặt tiêu đề trở lại trạng thái bình thường.

Bất kỳ suy nghĩ nào về cách khắc phục sự cố?

+3

chúng ta có thể có được một fiddle hoặc tốt hơn là một ví dụ sống mà chúng ta có thể gỡ lỗi? –

Trả lời

0

Tôi rất tiếc khi trở thành người đưa tin về tin xấu, nhưng tôi không biết vấn đề thực sự của bạn là gì khi bạn không đăng mã thực sự. Tuy nhiên, tôi đoán rằng vì vấn đề của bạn là position:fixed, cách tốt nhất để khắc phục sự cố là bằng cách ngừng sử dụng position:fixed vì dường như nó không hoạt động cho bạn. Đây là cách bạn có thể bình đẳng-trơn tru thi đua nó chỉ sử dụng định vị tuyệt đối và tương đối:

<html id="eHTML"> 
 
<style> 
 
#eHTML { position: static } 
 
#eBODY { position: relative; overflow:hidden } 
 
#eHTML, #eBODY, #main { width: 100%; height: 100%; margin: 0; top: 0 } 
 
#eBODY>div { position:absolute; left:0;bottom:0 } 
 
#footer {height: 20%;background-color:#88f;width:calc(100% - 14px)/*to account in for 14px scrollbar*/;overflow:hidden} 
 
#main {background-color:#ff8;width:100%;height:100%;overflow:auto} 
 
</style> 
 
<body id=eBODY> 
 
<div id=main> 
 
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.</p> 
 
<p>Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.</p> 
 
<p>Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.</p> 
 
<p>Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum</p> 
 
<p>Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium,</p> 
 
<p>totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo.</p> 
 
<p>Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt.</p> 
 
<p>Neque porro quisquam est, qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit,</p> 
 
<p>sed quia non numquam eius modi tempora incidunt ut labore et dolore magnam aliquam quaerat voluptatem.</p> 
 
<p>Ut enim ad minima veniam, quis nostrum exercitationem ullam corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur?</p> 
 
<p>Quis autem vel eum iure reprehenderit qui in ea voluptate velit esse quam nihil molestiae consequatur,</p> 
 
<p>vel illum qui dolorem eum fugiat quo voluptas nulla pariatur?</p> 
 
<br /><br /><br /><br /> 
 
</div> 
 
<div id="footer"> 
 
Some Random Fixed<br /> 
 
Content! Yay, it workz! 
 
</div> 
 
</body> 
 
</html>

Các vấn đề liên quan