Jquery的animate()反应过慢的问题解决
一张网页中少不了回到顶部的按钮,点击页面会自动回到网页顶部,可以使用超链接的方式,但是瞬间就回到顶部的效果实在不太理想,比较好的效果是向上滚动持续大约0.5秒,这就需要用到动画效果了。
我选择使用jquery的animate()方法,回到顶部效果完美实现,但是另外的一个效果却不太理想。
我希望回到顶部按钮的高度在小于屏幕高度时消失,在大于其高度时在显现出来,使用 css 属性 ‘opacity’来控制,但是每一次都是往上拉到顶部了按钮还是不消失,好不容易消失了再拉到底部按钮又不出现,代码如下,css代码就不列出来了:
<!--index.html--> <p class="sideBar"> <p class="goToTop"></p> </p>
//回到顶部 $(".goToTop").on("click",function(){ $("html,body").animate({scrollTop:0},'slow'); });// 控制按钮是否消失 $(function(){ var windowHeight = window.innerHeight; var $goToTop; $(window).scroll(function(){ $goToTop = $(".goToTop"); if(windowHeight < $goToTop.offset().top){ $goToTop.animate({opacity : 1},200); }else{ $goToTop.animate({opacity : 0},200); } }); });
一直有问题,代码查了三四遍都没发现问题,但是效果就是出错,后来实在没办法去google了一下,一下子就找到了答案
StackOverflow:Jquery slow reaction time
well.. you are calling the scroll listener which occurs evry moment while you are scrolling. but you also play an animation which is relatevly slow to scroll. when you call the scroll listener by scrolling, you create multiple nimations calls which try to play all at once (and that is why it slows down the ui).
就是说,鼠标滚动一次就引发一次animate()方法的执行,而每次执行是需要时间的,对于我的代码是一次执行0.2s,虽然一次时间不长,但是好多好多次叠加在一起就造成了执行不同animate()方法的延时
解决方法
One solution would be to call .stop() before you call .animate
也就是这样修改animate()方法:
//在animate()方法之前添加stop()函数 $goToTop.stop().animate({opacity : 1},200);
问题解决!!!
一张网页中少不了回到顶部的按钮,点击页面会自动回到网页顶部,可以使用超链接的方式,但是瞬间就回到顶部的效果实在不太理想,比较好的效果是向上滚动持续大约0.5秒,这就需要用到动画效果了。
我选择使用jquery的animate()方法,回到顶部效果完美实现,但是另外的一个效果却不太理想。
我希望回到顶部按钮的高度在小于屏幕高度时消失,在大于其高度时在显现出来,使用 css 属性 ‘opacity’来控制,但是每一次都是往上拉到顶部了按钮还是不消失,好不容易消失了再拉到底部按钮又不出现,代码如下,css代码就不列出来了:
<!--index.html--> <p class="sideBar"> <p class="goToTop"></p> </p>
//回到顶部 $(".goToTop").on("click",function(){ $("html,body").animate({scrollTop:0},'slow'); });// 控制按钮是否消失 $(function(){ var windowHeight = window.innerHeight; var $goToTop; $(window).scroll(function(){ $goToTop = $(".goToTop"); if(windowHeight < $goToTop.offset().top){ $goToTop.animate({opacity : 1},200); }else{ $goToTop.animate({opacity : 0},200); } }); });
一直有问题,代码查了三四遍都没发现问题,但是效果就是出错,后来实在没办法去google了一下,一下子就找到了答案
StackOverflow:Jquery slow reaction time
well.. you are calling the scroll listener which occurs evry moment while you are scrolling. but you also play an animation which is relatevly slow to scroll. when you call the scroll listener by scrolling, you create multiple nimations calls which try to play all at once (and that is why it slows down the ui).
就是说,鼠标滚动一次就引发一次animate()方法的执行,而每次执行是需要时间的,对于我的代码是一次执行0.2s,虽然一次时间不长,但是好多好多次叠加在一起就造成了执行不同animate()方法的延时
解决方法
One solution would be to call .stop() before you call .animate
也就是这样修改animate()方法:
//在animate()方法之前添加stop()函数 $goToTop.stop().animate({opacity : 1},200);
问题解决!!!
Atas ialah kandungan terperinci Jquery的animate()反应过慢的问题解决. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Bagaimana untuk menggunakan kaedah permintaan PUT dalam jQuery? Dalam jQuery, kaedah menghantar permintaan PUT adalah serupa dengan menghantar jenis permintaan lain, tetapi anda perlu memberi perhatian kepada beberapa butiran dan tetapan parameter. Permintaan PUT biasanya digunakan untuk mengemas kini sumber, seperti mengemas kini data dalam pangkalan data atau mengemas kini fail pada pelayan. Berikut ialah contoh kod khusus menggunakan kaedah permintaan PUT dalam jQuery. Mula-mula, pastikan anda memasukkan fail perpustakaan jQuery, kemudian anda boleh menghantar permintaan PUT melalui: $.ajax({u

Bagaimana untuk mengalih keluar atribut ketinggian elemen dengan jQuery? Dalam pembangunan bahagian hadapan, kita sering menghadapi keperluan untuk memanipulasi atribut ketinggian elemen. Kadangkala, kita mungkin perlu menukar ketinggian unsur secara dinamik, dan kadangkala kita perlu mengalih keluar atribut ketinggian unsur. Artikel ini akan memperkenalkan cara menggunakan jQuery untuk mengalih keluar atribut ketinggian elemen dan memberikan contoh kod khusus. Sebelum menggunakan jQuery untuk mengendalikan atribut ketinggian, kita perlu terlebih dahulu memahami atribut ketinggian dalam CSS. Atribut ketinggian digunakan untuk menetapkan ketinggian elemen

Tajuk: Petua jQuery: Cepat ubah suai teks semua teg pada halaman Dalam pembangunan web, kita selalunya perlu mengubah suai dan mengendalikan elemen pada halaman. Apabila menggunakan jQuery, kadangkala anda perlu mengubah suai kandungan teks semua teg dalam halaman sekaligus, yang boleh menjimatkan masa dan tenaga. Berikut akan memperkenalkan cara menggunakan jQuery untuk mengubah suai teks semua teg pada halaman dengan cepat, dan memberikan contoh kod khusus. Pertama, kita perlu memperkenalkan fail perpustakaan jQuery dan memastikan bahawa kod berikut dimasukkan ke dalam halaman: <

Tajuk: Gunakan jQuery untuk mengubah suai kandungan teks semua teg jQuery ialah perpustakaan JavaScript yang popular yang digunakan secara meluas untuk mengendalikan operasi DOM. Dalam pembangunan web, kita sering menghadapi keperluan untuk mengubah suai kandungan teks tag pautan (tag) pada halaman. Artikel ini akan menerangkan cara menggunakan jQuery untuk mencapai matlamat ini dan memberikan contoh kod khusus. Pertama, kita perlu memperkenalkan perpustakaan jQuery ke dalam halaman. Tambahkan kod berikut dalam fail HTML:

Bagaimana untuk mengetahui sama ada elemen jQuery mempunyai atribut tertentu? Apabila menggunakan jQuery untuk mengendalikan elemen DOM, anda sering menghadapi situasi di mana anda perlu menentukan sama ada sesuatu elemen mempunyai atribut tertentu. Dalam kes ini, kita boleh melaksanakan fungsi ini dengan mudah dengan bantuan kaedah yang disediakan oleh jQuery. Berikut akan memperkenalkan dua kaedah yang biasa digunakan untuk menentukan sama ada elemen jQuery mempunyai atribut khusus, dan melampirkan contoh kod tertentu. Kaedah 1: Gunakan kaedah attr() dan operator jenis // untuk menentukan sama ada elemen mempunyai atribut tertentu

jQuery ialah perpustakaan JavaScript popular yang digunakan secara meluas untuk mengendalikan manipulasi DOM dan pengendalian acara dalam halaman web. Dalam jQuery, kaedah eq() digunakan untuk memilih elemen pada kedudukan indeks tertentu Senario penggunaan dan aplikasi khusus adalah seperti berikut. Dalam jQuery, kaedah eq() memilih elemen pada kedudukan indeks yang ditentukan. Kedudukan indeks mula dikira dari 0, iaitu indeks elemen pertama ialah 0, indeks elemen kedua ialah 1, dan seterusnya. Sintaks kaedah eq() adalah seperti berikut: $("s

jQuery ialah perpustakaan JavaScript yang popular digunakan secara meluas dalam pembangunan web. Semasa pembangunan web, selalunya perlu menambah baris baharu secara dinamik pada jadual melalui JavaScript. Artikel ini akan memperkenalkan cara menggunakan jQuery untuk menambah baris baharu pada jadual dan memberikan contoh kod khusus. Pertama, kita perlu memperkenalkan perpustakaan jQuery ke dalam halaman HTML. Pustaka jQuery boleh diperkenalkan dalam teg melalui kod berikut:

Pemacu kad bunyi ialah program sistem dalam komputer yang mengawal dan mengarahkan kad bunyi Ia boleh membantu kita memainkan bunyi Oleh itu, jika terdapat masalah dengan pemacu kad bunyi, situasi yang paling intuitif ialah dari segi bunyi. tidak akan ada bunyi atau bunyi akan turun naik dan membeku secara tidak normal. Apa yang akan berlaku jika terdapat masalah dengan pemacu kad bunyi: 1. Ralat bunyi 1. Pemacu kad bunyi menyediakan bunyi, jadi masalah yang paling intuitif ialah masalah bunyi. 2. Sama ada tiada bunyi dari komputer, atau bunyi tersekat, tertangguh, bising, atau nada kelantangan tidak normal, ia mungkin berkaitan dengan pemacu kad bunyi. 3. Jadi apabila kami menghadapi masalah yang sama, kami boleh cuba memasang semula atau mengemas kini pemacu kad bunyi. 2. Tanda seru dalam Pengurus Peranti 1. Jika tiada masalah dengan bunyi, dalam kebanyakan kes ia bermakna pemacu kad bunyi adalah normal. 2. Tetapi saya
