修复了在 iOS Safari 中导致不需要的重新定位的背景图像?

Fixed Background Image Causing Unwanted Repositioning in iOS Safari?

我在 div 中有一个固定的背景图片,它不会在移动版 Safari 中始终显示。刷新页面时显示正常,但主要问题出现在我尝试向后和向前提示到其他站点页面时,导致浏览器笨拙地重新定位背景原点。

注意:第一个图像显示正确显示的背景图像,而第二个图像显示在 Safari 移动浏览器中导航 back/forward 时发生的变换原点偏移,(主要问题)。

这是一个片段,供进一步参考:

body,
html {
  height: 100%;
  width: 100%;
  background-size: cover;
  background-repeat: no-repeat;
}

body {
  background: white;
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  z-index: -2;
}

.sitebg {
  background: url("http://maxpixel.freegreatpicture.com/static/photo/1x/Seamless-Repeating-Tiling-Tile-able-Tileable-1889447.jpg");
  background-repeat: repeat;
  background-position: center;
  background-size: 720px 720px;
  -webkit-animation: 180s rotatebg infinite linear;
  -moz-animation: 180s rotatebg infinite linear;
  -o-animation: 180s rotatebg infinite linear;
  -ms-animation: 180s rotatebg infinite linear;
  animation: 180s rotatebg infinite linear;
  width: 750px;
  height: 750px;
  position: fixed;
  top: 50%;
  left: 50%;
}

.sitebg-parent {
  position: absolute;
  height: 100%;
  width: 100%;
  margin: auto;
  padding: 0;
  overflow: hidden;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
}

@-webkit-keyframes rotatebg {
  0% {
    -webkit-transform: rotate(0deg) translate(-50%, -50%);
    -webkit-transform-origin: top left;
  }
  100% {
    -webkit-transform: rotate(360deg) translate(-50%, -50%);
    -webkit-transform-origin: top left;
  }
}

@keyframes rotatebg {
  0% {
    transform: rotate(0deg) translate(-50%, -50%);
    transform-origin: top left;
  }
  100% {
    transform: rotate(360deg) translate(-50%, -50%);
    transform-origin: top left;
  }
}
<body>
  <div class="sitebg-parent">
    <div class="sitebg"></div>
  </div>
</body>

请尝试下面的代码。
我稍微更改了您的代码并删除了不必要和有效的 css 规则。

html, body {
  height: 100%; width: 100%;
  margin: 0; padding: 0;
}

.sitebg {
  position: absolute;
  top: 50%; left: 50%;
  width: 2000px; height: 2000px;
  margin: -1000px 0 0 -1000px;
  background: url("http://s3.gomedia.us/wp-content/uploads/2008/06/skullbg-green.gif");
  transform-origin: 50% 50%;
  -webkit-animation: 180s rotatebg infinite linear;
  animation: 180s rotatebg infinite linear;
}

.sitebg-parent {
  position: absolute; z-index: -1;
  top: 0; right: 0; bottom: 0; left: 0;
  overflow: hidden;
}

@-webkit-keyframes rotatebg {
  0% {-webkit-transform: rotateZ(0deg)}
  100% {-webkit-transform: rotateZ(360deg)}
}

@keyframes rotatebg {
  0% {transform: rotateZ(0deg)}
  100% {transform: rotateZ(360deg)}
}
<body>
  <div class="sitebg-parent">
    <div class="sitebg"></div>
  </div>
</body>