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.
Hàm khởi tạo
ViewTimeline()-
Tạo một phiên bản đối tượng
ViewTimelinemớ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.
subjectRead 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.
startOffsetRead only-
Trả về
CSSNumericValuebiể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. endOffsetRead only-
Trả về
CSSNumericValuebiể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 class là subject 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
<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
.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
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> |