gpt4 book ai didi

Bottom section is cutting off in mobile safari(在移动狩猎中底部被切断)

转载 作者:bug小助手 更新时间:2023-10-25 11:30:32 26 4
gpt4 key购买 nike



I have this simple page where it is working great in all browsers except mobile safari. Content is getting cutoff and button on the bottom is not showing. I tried setting.

我有一个简单的页面,它在除了移动Safari之外的所有浏览器上都运行得很好。内容被切断,底部的按钮没有显示。我试过布景。


body {
/* mobile viewport bug fix */
min-height: -webkit-fill-available;
}

html {
height: -webkit-fill-available;
}

But it is not working. Is there anyway to fix this.

但这并不奏效。有没有办法解决这个问题。




*,
::before,
::after {
box-sizing: border-box;
/* 1 */
border-width: 0;
/* 2 */
border-style: solid;
/* 2 */
border-color: #e5e7eb;
/* 2 */
}

::before,
::after {
--tw-content: '';
}

/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
5. Use the user's configured `sans` font-feature-settings by default.
6. Use the user's configured `sans` font-variation-settings by default.
*/

html {
line-height: 1.5;
/* 1 */
-webkit-text-size-adjust: 100%;
/* 2 */
-moz-tab-size: 4;
/* 3 */
tab-size: 4;
/* 3 */
font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
/* 4 */
font-feature-settings: normal;
/* 5 */
font-variation-settings: normal;
/* 6 */
}

/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/

body {
margin: 0;
/* 1 */
line-height: inherit;
/* 2 */
}

/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/

hr {
height: 0;
/* 1 */
color: inherit;
/* 2 */
border-top-width: 1px;
/* 3 */
}

/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/

abbr:where([title]) {
-webkit-text-decoration: underline dotted;
text-decoration: underline dotted;
}

/*
Remove the default font size and weight for headings.
*/

h1,
h2,
h3,
h4,
h5,
h6 {
font-size: inherit;
font-weight: inherit;
}

/*
Reset links to optimize for opt-in styling instead of opt-out.
*/

a {
color: inherit;
text-decoration: inherit;
}

/*
Add the correct font weight in Edge and Safari.
*/

b,
strong {
font-weight: bolder;
}

/*
1. Use the user's configured `mono` font family by default.
2. Correct the odd `em` font sizing in all browsers.
*/

code,
kbd,
samp,
pre {
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
/* 1 */
font-size: 1em;
/* 2 */
}

/*
Add the correct font size in all browsers.
*/

small {
font-size: 80%;
}

/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/

sub,
sup {
font-size: 75%;
line-height: 0;
position: relative;
vertical-align: baseline;
}

sub {
bottom: -0.25em;
}

sup {
top: -0.5em;
}

/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/

table {
text-indent: 0;
/* 1 */
border-color: inherit;
/* 2 */
border-collapse: collapse;
/* 3 */
}

/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/

button,
input,
optgroup,
select,
textarea {
font-family: inherit;
/* 1 */
font-feature-settings: inherit;
/* 1 */
font-variation-settings: inherit;
/* 1 */
font-size: 100%;
/* 1 */
font-weight: inherit;
/* 1 */
line-height: inherit;
/* 1 */
color: inherit;
/* 1 */
margin: 0;
/* 2 */
padding: 0;
/* 3 */
}

/*
Remove the inheritance of text transform in Edge and Firefox.
*/

button,
select {
text-transform: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/

button,
[type='button'],
[type='reset'],
[type='submit'] {
-webkit-appearance: button;
/* 1 */
background-color: transparent;
/* 2 */
background-image: none;
/* 2 */
}

/*
Use the modern Firefox focus style for all focusable elements.
*/

:-moz-focusring {
outline: auto;
}

/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/

:-moz-ui-invalid {
box-shadow: none;
}

/*
Add the correct vertical alignment in Chrome and Firefox.
*/

progress {
vertical-align: baseline;
}

/*
Correct the cursor style of increment and decrement buttons in Safari.
*/

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
height: auto;
}

/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/

[type='search'] {
-webkit-appearance: textfield;
/* 1 */
outline-offset: -2px;
/* 2 */
}

/*
Remove the inner padding in Chrome and Safari on macOS.
*/

::-webkit-search-decoration {
-webkit-appearance: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/

::-webkit-file-upload-button {
-webkit-appearance: button;
/* 1 */
font: inherit;
/* 2 */
}

/*
Add the correct display in Chrome and Safari.
*/

summary {
display: list-item;
}

/*
Removes the default spacing and border for appropriate elements.
*/

blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
margin: 0;
}

fieldset {
margin: 0;
padding: 0;
}

legend {
padding: 0;
}

ol,
ul,
menu {
list-style: none;
margin: 0;
padding: 0;
}

/*
Reset default styling for dialogs.
*/

dialog {
padding: 0;
}

/*
Prevent resizing textareas horizontally by default.
*/

textarea {
resize: vertical;
}

/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/

input::placeholder,
textarea::placeholder {
opacity: 1;
/* 1 */
color: #9ca3af;
/* 2 */
}

/*
Set the default cursor for buttons.
*/

button,
[role="button"] {
cursor: pointer;
}

/*
Make sure disabled buttons don't get the pointer cursor.
*/

:disabled {
cursor: default;
}

/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
This can trigger a poorly considered lint error in some tools but is included by design.
*/

img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
display: block;
/* 1 */
vertical-align: middle;
/* 2 */
}

/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/

img,
video {
max-width: 100%;
height: auto;
}

/* Make elements with the HTML hidden attribute stay hidden by default */

[hidden] {
display: none;
}

.relative{
position: relative;
}

.z-0{
z-index: 0;
}

.block{
display: block;
}

.flex{
display: flex;
}

.h-10{
height: 2.5rem;
}

.flex-grow{
flex-grow: 1;
}

.items-center{
align-items: center;
}

.justify-center{
justify-content: center;
}

.justify-between{
justify-content: space-between;
}

.overflow-auto{
overflow: auto;
}

.overflow-hidden{
overflow: hidden;
}

.rounded{
border-radius: 0.25rem;
}

.bg-blue-500{
--tw-bg-opacity: 1;
background-color: rgb(59 130 246);
}

.bg-gray-50{
--tw-bg-opacity: 1;
background-color: rgb(249 250 251);
}

.px-2{
padding-left: 0.5rem;
padding-right: 0.5rem;
}

.px-4{
padding-left: 1rem;
padding-right: 1rem;
}

.py-2{
padding-top: 0.5rem;
padding-bottom: 0.5rem;
}

.py-4{
padding-top: 1rem;
padding-bottom: 1rem;
}

.text-white{
--tw-text-opacity: 1;
color: rgb(255 255 255);
}

html{
display: flex;
min-height: 100vh;
flex-direction: column;
align-items: stretch;
overflow: hidden;
-webkit-font-smoothing: auto;
-moz-osx-font-smoothing: auto;
height: -webkit-fill-available;
}

body{
position: relative;
display: flex;
flex: 1 1 0%;
flex-direction: column;
min-height: -webkit-fill-available;
}

<header class="flex items-center justify-between bg-blue-500 px-2 py-4">Header</header>
<main class="h-10 flex-grow overflow-auto bg-gray-50">Main Section</main>
<footer class="relative z-0 flex items-center justify-center py-2">
<button type="button" class="relative flex items-center justify-center overflow-hidden rounded bg-blue-500 px-4 py-2 text-white">
<span class="block">Button</span>
</button>
</footer>




更多回答

Is the behaviour similar to how it's described here: css-tricks.com/the-large-small-and-dynamic-viewports

其行为是否类似于此处所描述的:css-tricks.com/the-large-small-and-dynamic-viewports

Yes it was thank you very much for that link. Would you please post this as an answer so that I can accept it as answer since SO does not allow comment to be marked as answer.

是的,非常感谢你的链接。请您将此作为答案发布,这样我就可以接受它作为答案,因为这样不允许将评论标记为答案。

优秀答案推荐

What's been used here is min-height: 100vh; and is susceptible to the problems that new CSS units such as dvh, lvh, svh are intended to solve.

这里使用的是最小高度:100vh;并且容易受到DVH、LVH、SVH等新的CSS单元想要解决的问题的影响。


Some resources:

https://css-tricks.com/the-large-small-and-dynamic-viewports/

https://ishadeed.com/article/new-viewport-units/

部分资源:https://css-tricks.com/the-large-small-and-dynamic-viewports/https://ishadeed.com/article/new-viewport-units/


Quote from one of the above articles:

引用上述文章中的一篇:



When using 100vh to size an element to take the full height of the viewport on mobile, it will be larger than the space between the top and bottom bars. This will happen in browsers that shrink their UI on scrolling, such as Safari or Chrome on Android.



These units are relatively new, so here are the compatibility tables:

https://caniuse.com/viewport-unit-variants

这些设备相对较新,因此以下是兼容表:https://caniuse.com/viewport-unit-variants


更多回答

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com