目次
目を引く Web アプリケーションを作成する上で、アニメーションが重要な役割を果たすことはご存知でしょう。ユーザーがユーザー エクスペリエンスにますます注意を向けるようになるにつれ、販売業者は完璧で楽しいユーザー エクスペリエンスの重要性を認識し始めており、その結果、Web アプリケーションはより重くなり、より動的にインタラクティブな UI を備えています。ユーザーがプロセス全体を通じてよりスムーズに状態から状態に移行できるようにするには、より複雑なアニメーションが必要です。今日では、これは特別なこととは考えられていません。ユーザーはますます選り好みするようになっており、デフォルトでは、応答性の高いインタラクティブなユーザー インターフェイスを期待しています。
Web アニメーションを作成する 2 つの主な方法は、JavaScript と CSS を使用することです。正しい選択も間違った選択もありません。すべては達成したい効果によって決まります。
CSS を使用したアニメーション画面上で要素を動かす最も簡単な方法です。
JavaScript を使用したアニメーションの作成は、CSS トランジションや CSS アニメーションよりも複雑ですが、通常、開発者はより強力な機能を提供します。
自然な遷移効果により、ユーザーは Web アプリケーションをより快適に感じることができ、その結果、ユーザー エクスペリエンスが向上します。
Easing 关键字
Linear 动画
Ease-out 动画
Ease-in 动画
Ease-in-out 动画
自定义 easing
贝塞尔曲线 (Bézier curves)
性能优化
Will-change
JavaScript 动画和 CSS 动画该如果抉择
总结
ホームページ ウェブフロントエンド jsチュートリアル CSS および JS アニメーションの基礎となる原則とそのパフォーマンスを最適化する方法の詳細な説明

CSS および JS アニメーションの基礎となる原則とそのパフォーマンスを最適化する方法の詳細な説明

Dec 10, 2020 pm 05:37 PM
css3アニメーション javascript フロントエンド プログラマー

#javascriptこのコラムでは、CSS および JS アニメーションの基礎となる原則を紹介します

CSS および JS アニメーションの基礎となる原則とそのパフォーマンスを最適化する方法の詳細な説明

#関連する無料学習の推奨事項:

javascript (ビデオ)

概要

目を引く Web アプリケーションを作成する上で、アニメーションが重要な役割を果たすことはご存知でしょう。ユーザーがユーザー エクスペリエンスにますます注意を向けるようになるにつれ、販売業者は完璧で楽しいユーザー エクスペリエンスの重要性を認識し始めており、その結果、Web アプリケーションはより重くなり、より動的にインタラクティブな UI を備えています。ユーザーがプロセス全体を通じてよりスムーズに状態から状態に移行できるようにするには、より複雑なアニメーションが必要です。今日では、これは特別なこととは考えられていません。ユーザーはますます選り好みするようになっており、デフォルトでは、応答性の高いインタラクティブなユーザー インターフェイスを期待しています。

ただし、インターフェイスのアニメーション化は必ずしも単純ではありません。アニメーションとは何なのか、いつアニメーションを使用するのか、アニメーションにはどのようなビデオ効果を持たせる必要があるのか​​、これらはすべて難しい問題です。

JavaScript と CSS アニメーションの比較

Web アニメーションを作成する 2 つの主な方法は、JavaScript と CSS を使用することです。正しい選択も間違った選択もありません。すべては達成したい効果によって決まります。

CSS アニメーション

CSS を使用したアニメーション画面上で要素を動かす最も簡単な方法です。

ここでは、1 秒続く CSS トランジションを使用して要素を X 軸と Y 軸上で 50 ピクセル移動させる方法の簡単な例から始めます。

.box {
  -webkit-transform: translate(0, 0);
  -webkit-transition: -webkit-transform 1000ms;

  transform: translate(0, 0);
  transition: transform 1000ms;
}

.box.move {
  -webkit-transform: translate(50px, 50px);
  transform: translate(50px, 50px);
}
ログイン後にコピー

move

クラスで要素が追加されると、transform の値が変更され、トランジション効果が発生します。 変換時間の他に、実際にアニメーションの移動速度を表す

easing

属性がありますが、このパラメータについては後ほど詳しく紹介します。 上記のコード スニペットのようなアニメーションを実装する個別の CSS クラスを作成する場合は、JavaScript を使用して各アニメーションを切り替えることもできます。

次の要素:

p class="box">
  Sample content.
ログイン後にコピー

次に、JavaScript を使用して各アニメーションを切り替えます。

var boxElements = document.getElementsByClassName('box'),
    boxElementsLength = boxElements.length,
    i;

for (i = 0; i <p>上記のコード スニペットは、</p>move<p> クラスを <code>box</code> クラスを含むすべての要素に追加して、アニメーションをトリガーすることです。 <code></code>これを行うと、アプリケーションのバランスを適切に保つことができます。 JavaScript を使用した状態の管理に集中でき、ターゲット要素に適切なクラスを設定し、ブラウザーにアニメーションを処理させるだけです。この方法を選択すると、要素の </p>transitionend<p> イベントをリッスンできますが、これは Internet Explorer の古いバージョンのサポートを終了した場合に限られます: <code></code></p><p><img src="/static/imghw/default1.png" data-src="https://img.php.cn/upload/image/590/600/983/1607592778931586.png" class="lazy" title="1607592778931586.png" alt="CSS および JS アニメーションの基礎となる原則とそのパフォーマンスを最適化する方法の詳細な説明">Listening</p>transitionend<p> トリガーされるイベントは次のとおりです: <code><pre class="brush:php;toolbar:false">var boxElement = document.querySelector('.box');
boxElement.addEventListener('transitionend', onTransitionEnd, false);

function onTransitionEnd() {
  // Handle the transition finishing.
}
ログイン後にコピー
CSS トランジションの使用に加えて、CSS アニメーションも使用できます。CSS アニメーションを使用すると、個々のアニメーション キーフレーム、持続時間をより適切に制御できます。そしてサイクル数。

キーフレームは、特定の時点で CSS プロパティがどうあるべきかをブラウザーに指示し、ギャップを埋めるために使用されます。

簡単な例を見てみましょう:

.box {
  /* 动画的名字 */
  animation-name: movingBox;

  /* 动画的持续时间 */
  animation-duration: 2300ms;

  /* 动画的运行次数 */
  animation-iteration-count: infinite;

  /* 设置对象动画在循环中是否反向运动的方法 */
  animation-direction: alternate;
}

@keyframes movingBox {
  0% {
    transform: translate(0, 0);
    opacity: 0.4;
  }

  25% {
    opacity: 0.9;
  }

  50% {
    transform: translate(150px, 200px);
    opacity: 0.2;
  }

  100% {
    transform: translate(40px, 30px);
    opacity: 0.8;
  }
}
ログイン後にコピー

効果の例: https://sessionstack.github.i...

CSS アニメーションを使用すると、 target 要素 アニメーション自体を定義し、animation-name プロパティを使用して目的のアニメーションを選択します。

CSS アニメーションでは依然としてブラウザーのプレフィックスがある程度必要であり、Safari、Safari Mobile、Android では -webkit が使用されます。 Chrome、Opera、Internet Explorer、Firefox ではプレフィックスは必要ありません。ソース ファイル内のスタイルにプレフィックスを付ける必要がないように、必要な CSS のプレフィックスを作成するのに役立つツールが多数あります。

JavaScript アニメーション

JavaScript を使用したアニメーションの作成は、CSS トランジションや CSS アニメーションよりも複雑ですが、通常、開発者はより強力な機能を提供します。

JavaScript アニメーションは、コードの一部としてインラインで記述されます。他のオブジェクトにカプセル化することもできます。以下は、JavaScript を使用して初期 CSS トランジションを実装するコードです:

var boxElement = document.querySelector('.box');
var animation = boxElement.animate([
  {transform: 'translate(0)'},
  {transform: 'translate(150px, 200px)'}
])

animation.addEventListener('finish', function() {
  boxElement.style.transform = 'translate(150px, 200px)';
})
ログイン後にコピー

デフォルトでは、Web アニメーションは要素のプレゼンテーションのみを変更します。オブジェクトを移動した位置に留まらせたい場合は、アニメーションが完了したときにその基礎となるスタイルを変更する必要があります。そのため、上記の例では、

finish

イベントをリッスンし、box.style.transform プロパティを translate(150px, 200px) に設定しています。この値は同じ 2 番目のスタイルの遷移が CSS アニメーションによって実行されます。 JavaScript アニメーションを使用すると、すべてのステップで要素のスタイルを完全に制御できます。つまり、必要に応じて、アニメーションの速度を遅くしたり、アニメーションを一時停止したり、停止したり、反転したり、要素を操作したりすることができます。これは、必要なアニメーション動作を正しくカプセル化できるため、複雑なオブジェクト指向アプリケーションを構築している場合に特に便利です。

イージング定義

自然な遷移効果により、ユーザーは Web アプリケーションをより快適に感じることができ、その結果、ユーザー エクスペリエンスが向上します。

当然,没有任何东西从一个点到另一个点线性移动。 实际上,当事物在我们周围的物理世界中移动时,事物往往会加速或减速,因为我们不是在真空中,并且有不同的因素会影响这一点。 人类的大脑会期望感受这样的移动,所以当为网络应用制作动画的时候,利用此类知识会对自己会有好处。

以下是一些术语需要了解一下:

  • ease in  —  相对于匀速,开始的时候慢,之后快
  • ease out —  相对于匀速,开始时快,结束时候间慢
  • ease-in-out —   相对于匀速,开始和结束都慢)两头慢

Easing 关键字

CSS 过渡和动画允许你选择要使用的 easing 类型。 不同的关键字会影响动画的 easing,你也可以完全自定义 easing 方法。

以下为可以选择用来控制 easing 的 CSS 关键字:

  • linear
  • ease-in
  • ease-out
  • ease-in-out

让我们深入来了解一下这几个兄弟,并看它们各自展示的效果是怎么样。

Linear 动画

easing 方法的的默认为 linear,以下为 linear 过渡效果的图示:

CSS および JS アニメーションの基礎となる原則とそのパフォーマンスを最適化する方法の詳細な説明

随着时间增加,值等比增加,使用 linear 动效,会让动画不自然,一般来说,避免使用 linear 动效。

以下是如何实现简单的线性动画:

transition: transform 500ms linear;
ログイン後にコピー

Ease-out 动画

如前所述,与线性动画相比,easing out 动画开始时快,结束时候间慢,过渡效果的图示如下:

CSS および JS アニメーションの基礎となる原則とそのパフォーマンスを最適化する方法の詳細な説明

一般来说,easing out过渡效果是最适合做界面体验的,因为快速地启动会给人以快速响应的动画的感觉,而结束时让人感觉很平滑这得归功于不一致的移动速度。

有很多方法可以实现 ease-out 效果,但最简单的是 CSS 中的 ease-out 关键字:

transition: transform 500ms ease-out;
ログイン後にコピー

Ease-in 动画

ease-out 动画相反-开始时快,结束时候间慢,过渡效果图如下:

CSS および JS アニメーションの基礎となる原則とそのパフォーマンスを最適化する方法の詳細な説明

ease-out 动画相比, ease-in 可能会让人感到不寻常,由于启动缓慢给人以反应卡顿的感觉,因此会产生一种无反应的感觉。 动画结束很快也会产生一种奇怪的感觉,因为整个动画正在加速,而现实世界中的物体在突然停止时往往会减速。

ease-outlinear 动画类似,使用 CSS 关键字来实现 ease-in 动画:

transition: transform 500ms ease-in;
ログイン後にコピー

Ease-in-out 动画

该动画为 ease-in 和 ease-out 的合集,过渡效果图如下:

CSS および JS アニメーションの基礎となる原則とそのパフォーマンスを最適化する方法の詳細な説明

不要使用太长的动画持续时间,因为它们会让你的 UI 感觉没有响应。

ease-in-out CSS 关键字来实现 ease-in-out 动画:

transition: transform 500ms ease-in-out;
ログイン後にコピー

自定义 easing

你也可以定义自己的 easing 曲线,这可以更好地创建自己想要的动画效果。

实际上, ease-inlinearease 关键字映射到预定义 贝塞尔曲线 ,可以在 CSS transitions specification 和 Web Animations specification 中查找更多关于贝塞尔曲线的内容。

贝塞尔曲线 (Bézier curves)

Bézier curve(贝塞尔曲线)是应用于二维图形应用程序的数学曲线。 曲线定义:起始点、终止点(也称锚点)、控制点。通过调整控制点,贝塞尔曲线的形状会发生变化。 1962年,法国数学家Pierre Bézier第一个研究了这种矢量绘制曲线的方法,并给出了详细的计算公式,因此按照这样的公式绘制出来的曲线就用他的姓氏来命名,称为贝塞尔曲线

CSS3 transition-timing-function 属性,其语法如下:

transition-timing-function: linear|ease|ease-in|ease-out|ease-in-out|cubic-bezier(n,n,n,n);
ログイン後にコピー

总而言之可以用cubic-bezier(n,n,n,n)的形式来表示全部的属性值,这里就涉及到贝塞尔曲线(Bézier curve)。

让我们看看贝塞尔曲线的工作原理。 贝塞尔曲线需要四个值,或者更准确地说它需要两对数字。 每对描述立方贝塞尔曲线控制点的 XY 坐标。贝塞尔曲线的起点有一个坐标 (0, 0) ,结束坐标是 (1, 1)。 你可以设置两个对号,两个控制点的 X 值必须在 [0,1] 范围内,并且每个控制点的 Y 值可以超过 [0,1] 限制,尽管规定不清楚多少。

即使每个控制点的 XY 值稍有变化,也会得到完全不同的曲线。让我们看两张贝塞尔曲线的图,两张图相近但坐标的控制结点却不同。

CSS および JS アニメーションの基礎となる原則とそのパフォーマンスを最適化する方法の詳細な説明

CSS および JS アニメーションの基礎となる原則とそのパフォーマンスを最適化する方法の詳細な説明

如您所见,两张图有很大的不同, 第一个控制点矢量差为 (0.045,0.183) 矢量差,而第二控制点矢量差为 (-0.427, -0.054)

第二条曲线的样式为:

transition: transform 500ms cubic-bezier(0.465, 0.183, 0.153, 0.946);
ログイン後にコピー

前两个数字是第一个控制点的 XY 坐标,后两个数字是第二个控制点的 XY 坐标。

性能优化

当你在使用动画的时候,你应该维持 60 帧每秒,否则会影响用户体验。

和世界上的其他事物一样,动画也会有性能的开销。一些属性的动画性能开销相比其它属性要小。例如,为元素的 widthheight 做动画会更改其几何结构并且可能会造成页面上的其它元素移动或者大小的改变,这个过程称为布局。我们在之前的一篇文章 中更详细地讨论了布局和渲染。

通常,你应该避免动画触发布局或重绘的属性。 对于大多数现代浏览器,这意味着把动画局限于 opacitytransform 属性。

Will-change

你可以使用 will-change 知浏览器你打算更改元素的属性,这允许浏览器在进行更改之前进行最适当的优化。但是,不要过度使用 will-change,因为这样做会导致浏览器浪费资源,从而导致更多的性能问题。

will-change 用法如下:

.box {
  will-change: transform, opacity;
}
ログイン後にコピー

该属性在 Chrome, Firefox,Opera 得到很好的兼容。

CSS および JS アニメーションの基礎となる原則とそのパフォーマンスを最適化する方法の詳細な説明

JavaScript 动画和 CSS 动画该如果抉择

  • 根据 Google Developer,渲染线程分为 主线程 (main thread)合成线程 (compositor thread)。如果 CSS 动画只是改变 transformsopacity,这时整个 CSS 动画得以在 合成线程 完成(而JS动画则会在 主线程 执行,然后触发合成线程进行下一步操作),在 JS 执行一些昂贵的任务时,主线程繁忙,CSS 动画由于使用了合成线程可以保持流畅
  • 在许多情况下,也可以由合成线程来处理 transformsopacity 属性值的更改。
  • 对于帧速表现不好的低版本浏览器,CSS3可以做到自然降级,而JS则需要撰写额外代码。
  • CSS动画有天然事件支持(TransitionEnd、AnimationEnd,但是它们都需要针对浏览器加前缀),JS则需要自己写事件。
  • 如果有任何动画触发绘画,布局或两者,则需要 “主线程” 才能完成工作。 这对于基于 CSS 和 JavaScript 的动画都是如此,布局或绘制的开销可能会使与 CSS 或 JavaScript 执行相关的任何工作相形见绌,这使得问题没有实际意义。
  • CSS3有兼容性问题,而JS大多时候没有兼容性问题。

总结

如果动画只是简单的状态切换,不需要中间过程控制,在这种情况下,css 动画是优选方案。它可以让你将动画逻辑放在样式文件里面,而不会让你的页面充斥 Javascript 库。然而如果你在设计很复杂的富客户端界面或者在开发一个有着复杂 UI 状态的 APP。那么你应该使用 js 动画,这样你的动画可以保持高效,并且你的工作流也更可控。所以,在实现一些小的交互动效的时候,就多考虑考虑 CSS 动画。对于一些复杂控制的动画,使用 javascript 比较可靠。

以上がCSS および JS アニメーションの基礎となる原則とそのパフォーマンスを最適化する方法の詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

どのAIプログラマーが一番優れているでしょうか? Devin、Tongyi Lingma、SWE エージェントの可能性を探る どのAIプログラマーが一番優れているでしょうか? Devin、Tongyi Lingma、SWE エージェントの可能性を探る Apr 07, 2024 am 09:10 AM

世界初の AI プログラマー Devin の誕生から 1 か月も経たない 2022 年 3 月 3 日、プリンストン大学の NLP チームはオープンソース AI プログラマー SWE-agent を開発しました。 GPT-4 モデルを利用して、GitHub リポジトリの問題を自動的に解決します。 SWE ベンチ テスト セットにおける SWE エージェントのパフォーマンスは Devin と同様で、平均 93 秒かかり、問題の 12.29% を解決しました。専用端末と対話することで、SWE エージェントはファイルの内容を開いて検索したり、自動構文チェックを使用したり、特定の行を編集したり、テストを作成して実行したりできます。 (注: 上記の内容は元の内容を若干調整したものですが、原文の重要な情報は保持されており、指定された文字数制限を超えていません。) SWE-A

PHP と Vue: フロントエンド開発ツールの完璧な組み合わせ PHP と Vue: フロントエンド開発ツールの完璧な組み合わせ Mar 16, 2024 pm 12:09 PM

PHP と Vue: フロントエンド開発ツールの完璧な組み合わせ 今日のインターネットの急速な発展の時代において、フロントエンド開発はますます重要になっています。 Web サイトやアプリケーションのエクスペリエンスに対するユーザーの要求がますます高まっているため、フロントエンド開発者は、より効率的で柔軟なツールを使用して、応答性の高いインタラクティブなインターフェイスを作成する必要があります。フロントエンド開発の分野における 2 つの重要なテクノロジーである PHP と Vue.js は、組み合わせることで完璧なツールと見なされます。この記事では、PHP と Vue の組み合わせと、読者がこれら 2 つをよりよく理解し、適用できるようにするための詳細なコード例について説明します。

C言語の魅力に迫る ~プログラマーの可能性を引き出す~ C言語の魅力に迫る ~プログラマーの可能性を引き出す~ Feb 24, 2024 pm 11:21 PM

C言語学習の魅力:プログラマーの可能性を引き出す テクノロジーの発展に伴い、コンピュータプログラミングは大きな注目を集めている分野です。数あるプログラミング言語の中でもC言語は常にプログラマーに愛されています。そのシンプルさ、効率性、幅広い用途により、C 言語の学習は、多くの人にとってプログラミングの分野に入る最初のステップとなっています。この記事では、C言語を学ぶ魅力と、C言語を学ぶことでプログラマーの可能性を引き出す方法について解説します。 C言語学習の魅力は、まずその簡単さにあります。他のプログラミング言語と比較すると、C言語は

フロントエンドの面接官からよく聞かれる質問 フロントエンドの面接官からよく聞かれる質問 Mar 19, 2024 pm 02:24 PM

フロントエンド開発のインタビューでは、HTML/CSS の基本、JavaScript の基本、フレームワークとライブラリ、プロジェクトの経験、アルゴリズムとデータ構造、パフォーマンスの最適化、クロスドメイン リクエスト、フロントエンド エンジニアリング、デザインパターン、新しいテクノロジーとトレンド。面接官の質問は、候補者の技術スキル、プロジェクトの経験、業界のトレンドの理解を評価するように設計されています。したがって、候補者はこれらの分野で自分の能力と専門知識を証明するために十分な準備をしておく必要があります。

簡単な JavaScript チュートリアル: HTTP ステータス コードを取得する方法 簡単な JavaScript チュートリアル: HTTP ステータス コードを取得する方法 Jan 05, 2024 pm 06:08 PM

JavaScript チュートリアル: HTTP ステータス コードを取得する方法、特定のコード例が必要です 序文: Web 開発では、サーバーとのデータ対話が頻繁に発生します。サーバーと通信するとき、多くの場合、返された HTTP ステータス コードを取得して操作が成功したかどうかを判断し、さまざまなステータス コードに基づいて対応する処理を実行する必要があります。この記事では、JavaScript を使用して HTTP ステータス コードを取得する方法を説明し、いくつかの実用的なコード例を示します。 XMLHttpRequestの使用

Django はフロントエンドですか、バックエンドですか?それをチェックしてください! Django はフロントエンドですか、バックエンドですか?それをチェックしてください! Jan 19, 2024 am 08:37 AM

Django は、迅速な開発とクリーンなメソッドを重視した Python で書かれた Web アプリケーション フレームワークです。 Django は Web フレームワークですが、Django がフロントエンドなのかバックエンドなのかという質問に答えるには、フロントエンドとバックエンドの概念を深く理解する必要があります。フロントエンドはユーザーが直接対話するインターフェイスを指し、バックエンドはサーバー側プログラムを指し、HTTP プロトコルを通じてデータと対話します。フロントエンドとバックエンドが分離されている場合、フロントエンドとバックエンドのプログラムをそれぞれ独立して開発して、ビジネス ロジックとインタラクティブ効果、およびデータ交換を実装できます。

フロントエンド モジュラー ESM とは何ですか? フロントエンド モジュラー ESM とは何ですか? Feb 25, 2024 am 11:48 AM

フロントエンド ESM とは何ですか? 特定のコード サンプルが必要です。フロントエンド開発では、ESM は ECMAScript 仕様に基づいたモジュール式開発メソッドである ECMAScriptModules を指します。 ESM は、より優れたコード構成、モジュール間の分離、再利用性など、多くの利点をもたらします。この記事では、ESM の基本概念と使用法を紹介し、いくつかの具体的なコード例を示します。 ESM の基本概念 ESM では、コードを複数のモジュールに分割することができ、各モジュールは他のモジュール用のいくつかのインターフェイスを公開します。

JavaScript で HTTP ステータス コードを簡単に取得する方法 JavaScript で HTTP ステータス コードを簡単に取得する方法 Jan 05, 2024 pm 01:37 PM

JavaScript で HTTP ステータス コードを取得する方法の紹介: フロントエンド開発では、バックエンド インターフェイスとの対話を処理する必要があることが多く、HTTP ステータス コードはその非常に重要な部分です。 HTTP ステータス コードを理解して取得すると、インターフェイスから返されたデータをより適切に処理できるようになります。この記事では、JavaScript を使用して HTTP ステータス コードを取得する方法と、具体的なコード例を紹介します。 1. HTTP ステータス コードとは何ですか? HTTP ステータス コードとは、ブラウザがサーバーへのリクエストを開始したときに、サービスが

See all articles