TA的每日心情 | 慵懒 2018-8-25 12:29 |
---|
签到天数: 91 天 [LV.6]常住居民II
|
本帖最后由 garypang 于 2018-5-20 19:10 编辑
: Z8 u8 \. e7 k' C7 Z h0 k
( }) o& C% Y8 w以下只针对PC下的ANKI
. i7 A: Z2 Y( I* r
: A+ C6 m. ^4 M E1 A* [( G不知大家有发现没,ANKI中的一些JS效果会不断累加,浏览到第几张卡片JS就会在当前卡片上执行多少次,导致除第一张卡片外的其他所有卡片上的JS都不能正常显示, 有个插件能解决这个问题https://ankiweb.net/shared/info/1280253613
- A3 |! b: Q, |. C% ]( a/ c; Y) M9 w但只针对anki2的, anki2.1还是没办法,
, O6 u0 w% b# O& ]7 d不用插件行不行呢,# I+ Z B$ W3 r) M) `6 O# {; {% a
首先得弄清楚为啥会出现这个问题,
1 v8 h+ c- m; S! ~! K, E+ LANKI对所有 document , html ,body 元素对象里相关的JS代码都会累加重复执行,比如6 V( B p. P v2 L9 O! m* h
- document.body.click(...)
+ E9 e) k! } W3 ^ - $(window).keyup(...)) A! m: [! e7 G; c3 [
- $(window).scroll(...)
7 V0 ], n4 K+ T+ d) s - $("html,body").animate(...)
$ B3 [1 V$ G+ J% p! F* p - ...
- k' \+ z" @. n1 p
复制代码
$ s+ u3 n9 d, N V% d举个栗子
4 \& P( i! x* C4 T) ~# a6 F- $("body").click(function(){/ Q l, T& B1 f0 o: @; o
- alert("test");
2 V- \5 ~% u* R1 { ] - })
复制代码
4 @# K _2 Q& J- s( g/ J浏览第一张卡片的时候,鼠标点击body会弹出一次test弹窗,浏览到第二张卡片,点击一次body则会连续弹出两次test弹窗,到第三张卡片,点击一次则会连续弹出三次test弹窗,以此类推,点击事件会不断叠加, 问题不出在click事件本身,而是因为是body对象下的click,如果改为其他比如$(".anki").click(...);则完全不会出现上述问题
" s% {/ m6 y* R! [# e l# V$ V- i, V0 b3 o6 G
解决办法其实很简单,把document , html ,body 元素对象里的相关代码做个限制,只允许执行一次即可.
( i; M* Z. \0 Q( J* v, L9 L4 a* _; N: {7 s2 r; P) d
比如上述代码可以这样写:. u& r+ j# T( K) T/ d+ H0 S5 D
: z; a" A% }- d3 ]( C1 S
. b# Z! Z# x5 m! X# ?- Z另外一个问题,ANKI怎么引入外部JS文件? 直接<script src="..."></script>是无效的,会被anki过滤掉." G- ]3 N- r- l5 ^
3 M( Q6 P* y5 F
可以这样写# G3 B' w+ Q4 L) x* A4 e; N, l
- var script = document.createElement('script');
2 k! H% T# c0 G x" O6 i - script.type = "text/javascript";
" h4 \: U3 h, I6 f# q2 m - script.src = "_jquery.js"; 2 q- Z7 k; N, r: S8 o
- document.getElementById("ak_wrap").appendChild(script);
复制代码
# Q: @! o3 W" o9 k+ Q这里特别注意,一不小心就会踩了上面那个坑,代码第四行你肯定会想当然用document.body.appendChild(script)吧,前面刚说了document.body对象里的JS会被重复执行,这样写后果就是到第二张卡片的时候就会出现两个<script src="_jquery.js"></script>, _jquery.js被调用了两次,正确的写法是append到除body, html外的其他元素里.: G- h; p# l" [8 s" @
# _& b4 G( Z) ]% `" s
以上, 希望对你有帮助 |
评分
-
2
查看全部评分
-
|