Rumah hujung hadapan web tutorial js vue实现页面加载动画代码教程

vue实现页面加载动画代码教程

Feb 05, 2018 pm 04:24 PM
kod memuatkan animasi

我们经常看到数据未出现时,页面中会有一条提示消息, 页面正在加载中,如何实现该效果呢 ,本文主要为大家详细介绍了vue实现页面加载动画效果,vue页面出现正在加载的初始页面与实现动画效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家。

请看下面代码


1

2

3

4

5

6

7

8

9

10

11

12

<template>

 <section class="page" v-if="option"

  :style="{background: option.background,color: option.color||&#39;#fff&#39;}" 

  :class="{&#39;page-before&#39;: option.index < currentPage,

    &#39;page-after&#39;: option.index > currentPage,

    &#39;page-current&#39;: option.index === currentPage}">

  <p :class="{&#39;all-center&#39;: option.isCenter}">

   <slot></slot>

  </p>

 </section>

 <section class="page" v-else>页面正在渲染中。。。</section>

</template>

Salin selepas log masuk

有木有感觉很简单
下面上点干货,实现页面的动画效果


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

174

175

176

177

178

179

180

181

182

183

184

185

186

187

188

189

190

191

192

193

194

195

196

197

198

199

200

201

202

203

204

205

206

207

208

209

<template>

 <nav class="controller">

  <button v-if="option.arrowsType" class="prev-btn" :class="{moving:option.arrowsType === &#39;animate&#39;}" @click="changePage(prevIndex)"></button>

  <ul v-if="option.navbar">

   <li v-for="index in pageNum" @click="changePage(index)" :class="{current:option.highlight && index === currentPage}" :key="&#39;controller-&#39;+index" :data-index="index" class="controller-item"></li>

  </ul>

  <button v-if="option.arrowsType" class="next-btn" :class="{moving:option.arrowsType === &#39;animate&#39;}" @click="changePage(nextIndex)"></button>

 </nav>

</template>

 

<script>

export default {

 name: &#39;page-controller&#39;,

 props: {

 pageNum: Number,

 currentPage: Number,

 option: {

  type: Object,

  default: {

  arrowsType: &#39;animate&#39;,

  navbar: true,

  highlight: true,

  loop: true  //是否开启滚动循环

  }

 }

 },

 methods: {

 changePage (index) {

  this.$emit(&#39;changePage&#39;, index);

 }

 },

 computed: {

 nextIndex () {

  if (this.currentPage === this.pageNum) {

  if(this.option.loop){

   return 1

   }else{

   return this.pageNum

   }

  } else {

  return this.currentPage + 1;

  }

 },

 prevIndex () {

  if (this.currentPage === 1) {

  if(this.option.loop){

   return this.pageNum

   }else{

   return 1

   }

  } else {

  return this.currentPage - 1;

  }

 }

 },

 created () {

 if (this.option.navbar === undefined) {

  this.option.navbar = true;

 }

 },

 mounted () {

 let _this = this;

 let timer = null;

 let start = 0;

 // 滚轮处理

 function scrollHandler (direction) {

  // 防止重复触发滚动事件

  if (timer != null) {

  return;

  }

  if (direction === &#39;down&#39;) {

  _this.changePage(_this.nextIndex);

  } else {

  _this.changePage(_this.prevIndex);

  }

  timer = setTimeout(function() {

  clearTimeout(timer);

  timer = null;

  }, 300);

 }

 // if (Object.hasOwnProperty.call(window,&#39;onmousewheel&#39;)) {

 if (Object.hasOwnProperty.call(window,&#39;onmousewheel&#39;)) {

  // 监听滚轮事件

  window.addEventListener(&#39;mousewheel&#39;,function (event) { // IE/Opera/Chrome

  let direction = event.wheelDelta > 0 ? &#39;up&#39;:&#39;down&#39;;

  scrollHandler(direction);

  },false);

 } else {

  window.addEventListener(&#39;DOMMouseScroll&#39;,function (event) { // Firefox

  let direction = event.detail > 0 ? &#39;up&#39;:&#39;down&#39;;

  scrollHandler(direction);

  },false);

 }

 // 移动端触摸事件处理

 window.addEventListener(&#39;touchstart&#39;, function (event) {

  start = event.touches[0].clientY;

 })

 window.addEventListener(&#39;touchmove&#39;, function (event) {

  event.preventDefault();

 })

 window.addEventListener(&#39;touchend&#39;, function (event) {

  let spacing = event.changedTouches[0].clientY - start;

  let direction; 

  if (spacing > 50) {

  direction = &#39;up&#39;;

  scrollHandler(direction);

  } else if (spacing < -50) {

  direction = &#39;down&#39;;

  scrollHandler(direction);

  }

 })

 }

}

</script>

 

<style scoped>

.controller {

 position: fixed;

 right: 20px;

 top: 50%;

 z-index: 99;

}

.controller ul {

 transform: translate3d(0,-50%,0);

 list-style: none;

 margin: 0;

 padding: 0;

}

.controller-item {

 cursor: pointer;

 width: 20px;

 height: 20px;

 border-radius: 50%;

 margin-top: 10px;

 background-color: rgba(255, 255, 255, 0.3);

 transition: background-color 0.3s ease 0s;

}

.controller-item:hover {

 background-color: rgba(255, 255, 255, 0.7);

}

.controller-item.current {

 background-color: rgba(255, 255, 255, 1);

}

.prev-btn,.next-btn {

 cursor: pointer;

 display: block;

 text-align: center;

 width: 20px;

 height: 20px;

 position: fixed;

 left: 50%;

 margin-left: -10px;

 border: 4px solid #fff;

 background-color: transparent;

 outline: none;

}

.prev-btn {

 top: 80px;

 transform: rotate(-45deg);

 border-bottom-color: transparent;

 border-left-color: transparent;

}

.next-btn {

 bottom: 80px;

 transform: rotate(45deg);

 border-top-color: transparent;

 border-left-color: transparent;

}

.prev-btn.moving {

 animation: prev-up-down 0.7s linear 0s infinite;

}

.next-btn.moving {

 animation: next-up-down 0.7s linear 0s infinite;

}

@keyframes next-up-down {

 0% {

 transform: translate3d(0,0,0) rotate(45deg);

 }

 25% {

 transform: translate3d(0,6px,0) rotate(45deg);

 }

 50% {

 transform: translate3d(0,0,0) rotate(45deg);

 }

 75% {

 transform: translate3d(0,-6px,0) rotate(45deg);

 }

 100% {

 transform: translate3d(0,0,0) rotate(45deg);

 }

}

@keyframes prev-up-down {

 0% {

 transform: translate3d(0,0,0) rotate(-45deg);

 }

 25% {

 transform: translate3d(0,-6px,0) rotate(-45deg);

 }

 50% {

 transform: translate3d(0,0,0) rotate(-45deg);

 }

 75% {

 transform: translate3d(0,6px,0) rotate(-45deg);

 }

 100% {

 transform: translate3d(0,0,0) rotate(-45deg);

 }

}

</style>

Salin selepas log masuk

相关推荐:

页面加载时触发的事件及顺序

php简单计算页面加载时间

HTML页面加载速度加快的介绍

Atas ialah kandungan terperinci vue实现页面加载动画代码教程. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Akan R.E.P.O. Ada Crossplay?
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk menyelesaikan kod pemandu win7 28 Bagaimana untuk menyelesaikan kod pemandu win7 28 Dec 30, 2023 pm 11:55 PM

Sesetengah pengguna mengalami ralat semasa memasang peranti, menyebabkan kod ralat 28. Sebenarnya, ini disebabkan terutamanya oleh pemandu Kami hanya perlu menyelesaikan masalah kod pemandu win7 28. Mari kita lihat apa yang perlu dilakukan . Apa yang perlu dilakukan dengan kod pemandu win7 28: Pertama, kita perlu mengklik pada menu mula di sudut kiri bawah skrin. Kemudian, cari dan klik pilihan "Panel Kawalan" dalam menu pop timbul. Pilihan ini biasanya terletak di atau berhampiran bahagian bawah menu. Selepas mengklik, sistem akan membuka antara muka panel kawalan secara automatik. Dalam panel kawalan, kami boleh melakukan pelbagai tetapan sistem dan operasi pengurusan. Ini adalah langkah pertama dalam tahap pembersihan nostalgia, saya harap ia membantu. Kemudian kita perlu meneruskan dan memasuki sistem dan

Animasi tidak berfungsi dalam PowerPoint [Tetap] Animasi tidak berfungsi dalam PowerPoint [Tetap] Feb 19, 2024 am 11:12 AM

Adakah anda cuba membuat persembahan tetapi tidak boleh menambah animasi? Jika animasi tidak berfungsi dalam PowerPoint pada PC Windows anda, maka artikel ini akan membantu anda. Ini adalah masalah biasa yang dikeluhkan oleh ramai orang. Contohnya, animasi mungkin berhenti berfungsi semasa pembentangan dalam Microsoft Teams atau semasa rakaman skrin. Dalam panduan ini, kami akan meneroka pelbagai teknik penyelesaian masalah untuk membantu anda membetulkan animasi yang tidak berfungsi dalam PowerPoint pada Windows. Mengapa animasi PowerPoint saya tidak berfungsi? Kami mendapati bahawa beberapa sebab yang mungkin menyebabkan animasi dalam PowerPoint tidak berfungsi pada Windows adalah seperti berikut: Disebabkan oleh peribadi

Apa yang perlu dilakukan jika kod skrin biru 0x0000001 berlaku Apa yang perlu dilakukan jika kod skrin biru 0x0000001 berlaku Feb 23, 2024 am 08:09 AM

Apa yang perlu dilakukan dengan kod skrin biru 0x0000001 Ralat skrin biru adalah mekanisme amaran apabila terdapat masalah dengan sistem komputer atau perkakasan Kod 0x0000001 biasanya menunjukkan kegagalan perkakasan. Apabila pengguna tiba-tiba mengalami ralat skrin biru semasa menggunakan komputer mereka, mereka mungkin berasa panik dan rugi. Nasib baik, kebanyakan ralat skrin biru boleh diselesaikan dan ditangani dengan beberapa langkah mudah. Artikel ini akan memperkenalkan pembaca kepada beberapa kaedah untuk menyelesaikan kod ralat skrin biru 0x0000001. Pertama, apabila menghadapi ralat skrin biru, kita boleh cuba untuk memulakan semula

Ralat memuatkan pemalam dalam Illustrator [Tetap] Ralat memuatkan pemalam dalam Illustrator [Tetap] Feb 19, 2024 pm 12:00 PM

Apabila memulakan Adobe Illustrator, adakah mesej tentang ralat memuatkan pemalam timbul? Sesetengah pengguna Illustrator telah mengalami ralat ini semasa membuka aplikasi. Mesej itu diikuti dengan senarai pemalam yang bermasalah. Mesej ralat ini menunjukkan bahawa terdapat masalah dengan pemalam yang dipasang, tetapi ia juga mungkin disebabkan oleh sebab lain seperti fail Visual C++ DLL yang rosak atau fail pilihan yang rosak. Jika anda menghadapi ralat ini, kami akan membimbing anda dalam artikel ini untuk menyelesaikan masalah, jadi teruskan membaca di bawah. Ralat memuatkan pemalam dalam Illustrator Jika anda menerima mesej ralat "Ralat memuatkan pemalam" semasa cuba melancarkan Adobe Illustrator, anda boleh menggunakan yang berikut: Sebagai pentadbir

Komputer kerap berskrin biru dan kodnya berbeza setiap kali Komputer kerap berskrin biru dan kodnya berbeza setiap kali Jan 06, 2024 pm 10:53 PM

Sistem win10 ialah sistem kecerdasan tinggi yang sangat baik Kepintarannya yang berkuasa boleh membawa pengalaman pengguna yang terbaik kepada pengguna Dalam keadaan biasa, komputer sistem win10 pengguna tidak akan menghadapi sebarang masalah. Walau bagaimanapun, tidak dapat dielakkan bahawa pelbagai kerosakan akan berlaku pada komputer yang sangat baik Baru-baru ini, rakan-rakan telah melaporkan bahawa sistem win10 mereka sering menghadapi skrin biru. Hari ini, editor akan membawakan anda penyelesaian kepada kod berbeza yang menyebabkan skrin biru kerap berlaku dalam komputer Windows 10 Mari kita lihat. Penyelesaian kepada skrin biru komputer yang kerap dengan kod berbeza setiap kali: punca pelbagai kod kerosakan dan cadangan penyelesaian 1. Punca kerosakan 0×000000116: Seharusnya pemacu kad grafik tidak serasi. Penyelesaian: Adalah disyorkan untuk menggantikan pemacu pengilang asal. 2.

Selesaikan ralat kod 0xc000007b Selesaikan ralat kod 0xc000007b Feb 18, 2024 pm 07:34 PM

Kod Penamatan 0xc000007b Semasa menggunakan komputer anda, kadangkala anda menghadapi pelbagai masalah dan kod ralat. Antaranya, kod penamatan adalah yang paling mengganggu terutamanya kod penamatan 0xc000007b. Kod ini menunjukkan bahawa aplikasi tidak boleh dimulakan dengan betul, menyebabkan ketidakselesaan kepada pengguna. Mula-mula, mari kita fahami maksud kod penamatan 0xc000007b. Kod ini ialah kod ralat sistem pengendalian Windows yang biasanya berlaku apabila aplikasi 32-bit cuba dijalankan pada sistem pengendalian 64-bit. Maksudnya sepatutnya

Sari kata Stremio tidak berfungsi; ralat memuatkan sari kata Sari kata Stremio tidak berfungsi; ralat memuatkan sari kata Feb 24, 2024 am 09:50 AM

Sarikata tidak berfungsi pada Stremio pada PC Windows anda? Sesetengah pengguna Stremio melaporkan bahawa sari kata tidak dipaparkan dalam video. Ramai pengguna melaporkan mengalami mesej ralat yang mengatakan "Ralat memuatkan sari kata." Berikut ialah mesej ralat penuh yang muncul dengan ralat ini: Ralat berlaku semasa memuatkan sari kata Gagal memuatkan sari kata: Ini mungkin masalah dengan pemalam yang anda gunakan atau rangkaian anda. Seperti yang dikatakan oleh mesej ralat, mungkin sambungan internet anda yang menyebabkan ralat. Jadi sila semak sambungan rangkaian anda dan pastikan internet anda berfungsi dengan baik. Selain itu, mungkin terdapat sebab lain di sebalik ralat ini, termasuk sarikata yang bercanggah, sari kata yang tidak disokong untuk kandungan video tertentu dan apl Stremio yang sudah lapuk. suka

Penjelasan terperinci tentang punca dan penyelesaian kod skrin biru 0x0000007f Penjelasan terperinci tentang punca dan penyelesaian kod skrin biru 0x0000007f Dec 25, 2023 pm 02:19 PM

Skrin biru adalah masalah yang sering kita hadapi apabila menggunakan sistem Bergantung pada kod ralat, akan terdapat banyak sebab dan penyelesaian yang berbeza. Sebagai contoh, apabila kita menghadapi masalah berhenti: 0x0000007f, ia mungkin ralat perkakasan atau perisian Mari ikut editor untuk mengetahui penyelesaiannya. 0x000000c5 sebab kod skrin biru: Jawapan: Memori, CPU dan kad grafik tiba-tiba overclocked atau perisian berjalan dengan tidak betul. Penyelesaian 1: 1. Teruskan tekan F8 untuk masuk semasa but, pilih mod selamat, dan tekan Enter untuk masuk. 2. Selepas memasuki mod selamat, tekan win+r untuk membuka tetingkap jalankan, masukkan cmd, dan tekan Enter. 3. Dalam tetingkap command prompt, masukkan "chkdsk /f /r", tekan Enter, dan kemudian tekan kekunci y. 4.

See all articles