ViewTimeline

Limited availability

This feature is not Baseline because it does not work in some of the most widely-used browsers.

Giao diện ViewTimeline của Web Animations API biểu diễn một dòng thời gian tiến trình khung nhìn (view progress timeline) (xem CSS scroll-driven animations để biết thêm chi tiết).

Truyền một phiên bản ViewTimeline vào hàm khởi tạo Animation() hoặc phương thức animate() để chỉ định nó làm dòng thời gian kiểm soát tiến trình của hoạt ảnh.

AnimationTimeline ScrollTimeline ViewTimeline

Hàm khởi tạo

ViewTimeline()

Tạo một phiên bản đối tượng ViewTimeline mới.

Thuộc tính phiên bản

Giao diện này cũng kế thừa các thuộc tính của cha nó, ScrollTimeline.

subject Read only

Trả về tham chiếu đến phần tử subject mà khả năng hiển thị của nó trong phần tử scrollable tổ tiên gần nhất (scroller) đang điều khiển tiến trình của dòng thời gian và do đó là hoạt ảnh.

startOffset Read only

Trả về CSSNumericValue biểu diễn vị trí cuộn bắt đầu (tiến trình 0%) của dòng thời gian như một độ lệch từ đầu phần nội dung tràn trong scroller.

endOffset Read only

Trả về CSSNumericValue biểu diễn vị trí cuộn kết thúc (tiến trình 100%) của dòng thời gian như một độ lệch từ đầu phần nội dung tràn trong scroller.

Phương thức phiên bản

Giao diện này kế thừa các phương thức của cha nó, ScrollTimeline.

Ví dụ

Hiển thị subject và các offset của dòng thời gian tiến trình khung nhìn

Trong ví dụ này, chúng ta tạo hoạt ảnh cho một phần tử với classsubject dọc theo dòng thời gian tiến trình khung nhìn. Chúng ta cũng xuất các giá trị subject, startOffset, và endOffset ra một phần tử output ở góc trên bên phải.

HTML

html
<div class="content">
  <h1>Content</h1>

  <p>
    Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod
    tempor incididunt ut labore et dolore magna aliqua. Risus quis varius quam
    quisque id. Et ligula ullamcorper malesuada proin libero nunc consequat
    interdum varius. Elit ullamcorper dignissim cras tincidunt lobortis feugiat
    vivamus at augue.
  </p>

  <p>
    Dolor sed viverra ipsum nunc aliquet. Sed risus pretium quam vulputate
    dignissim. Tortor aliquam nulla facilisi cras. A erat nam at lectus urna
    duis convallis convallis. Nibh ipsum consequat nisl vel pretium lectus.
    Sagittis aliquam malesuada bibendum arcu vitae elementum. Malesuada bibendum
    arcu vitae elementum curabitur vitae nunc sed velit.
  </p>

  <div class="subject animation"></div>

  <p>
    Adipiscing enim eu turpis egestas pretium aenean pharetra magna ac. Arcu
    cursus vitae congue mauris rhoncus aenean vel. Sit amet cursus sit amet
    dictum. Augue neque gravida in fermentum et. Gravida rutrum quisque non
    tellus orci ac auctor augue mauris. Risus quis varius quam quisque id diam
    vel quam elementum. Nibh praesent tristique magna sit amet purus gravida
    quis. Duis ultricies lacus sed turpis tincidunt id aliquet. In egestas erat
    imperdiet sed euismod nisi. Eget egestas purus viverra accumsan in nisl nisi
    scelerisque. Netus et malesuada fames ac.
  </p>

  <div class="output"></div>
</div>

CSS

css
.subject {
  width: 300px;
  height: 200px;
  margin: 0 auto;
  background-color: deeppink;
}

.content {
  width: 75%;
  max-width: 800px;
  margin: 0 auto;
}

.output {
  position: fixed;
  top: 5px;
  right: 5px;
}

p,
h1,
div {
  font-family: "Helvetica", "Arial", sans-serif;
}

h1 {
  font-size: 3rem;
}

p {
  font-size: 1.5rem;
  line-height: 1.5;
}

JavaScript

js
const subject = document.querySelector(".subject");
const output = document.querySelector(".output");

const timeline = new ViewTimeline({
  subject,
  axis: "block",
  inset: [CSS.px("200"), CSS.px("300")],
});

subject.animate(
  {
    opacity: [0, 1],
    transform: ["scaleX(0)", "scaleX(1)"],
  },
  {
    fill: "both",
    timeline,
  },
);

output.textContent += `Subject element: ${timeline.subject.nodeName}, `;
output.textContent += `start offset: ${timeline.startOffset}, `;
output.textContent += `end offset: ${timeline.endOffset}.`;

Kết quả

Cuộn để xem phần tử subject được tạo hoạt ảnh.

Thông số kỹ thuật

Specification
Scroll-driven Animations
# viewtimeline-interface

Tương thích trình duyệt

Xem thêm