掌上百科 - PDAWIKI

用户名  找回密码
 免费注册

QQ登录

只需一步,快速开始

查看: 8801|回复: 46

[经验交流] anki里的JS坑以及填坑方案

[复制链接]
  • TA的每日心情
    慵懒
    2018-8-25 12:29
  • 签到天数: 91 天

    [LV.6]常住居民II

    发表于 2018-5-20 16:46:00 | 显示全部楼层 |阅读模式
    本帖最后由 garypang 于 2018-5-20 19:10 编辑
    ' a0 O* y& Q: `7 ^( a
    5 X* U0 l3 s; m: c7 P以下只针对PC下的ANKI( G' ~; d: K- I& z) K3 C7 h
    8 @! w0 |" |* ?. g
    不知大家有发现没,ANKI中的一些JS效果会不断累加,浏览到第几张卡片JS就会在当前卡片上执行多少次,导致除第一张卡片外的其他所有卡片上的JS都不能正常显示, 有个插件能解决这个问题https://ankiweb.net/shared/info/1280253613) F4 m" a  ~# @0 c4 Z, @# J) Z- ^
    但只针对anki2的, anki2.1还是没办法,
    . `8 h& g* r6 V3 \不用插件行不行呢,
    ' a" L. Q1 e( ~' ^% x9 ]+ v1 j7 k首先得弄清楚为啥会出现这个问题,
      U* T4 }1 u2 {- a6 VANKI对所有 document , html ,body 元素对象里相关的JS代码都会累加重复执行,比如2 I  p, _2 |. \/ d6 x* ?
    1. document.body.click(...)
      8 W6 \- w' }9 s3 r8 m; }2 R
    2. $(window).keyup(...)1 P: O$ W/ H4 f8 l: u
    3. $(window).scroll(...), K% {" ?9 H4 W, ]+ `. Z
    4. $("html,body").animate(...)
      6 y0 C' t% \+ p) v/ v
    5. ...% E& |' O! G' l  s# V/ V+ H' W
    复制代码
    $ e$ H' W: a. l6 }7 F& `
    举个栗子
    0 o% a# j2 u: p+ L/ O9 e8 U
    1. $("body").click(function(){
      2 ^- {/ T: p/ s' L* }- y- w7 t
    2. alert("test");
      2 h" {# x) C& Q+ v
    3. })
    复制代码
      c4 b, ?( R/ w0 a" \) w( x2 E
    浏览第一张卡片的时候,鼠标点击body会弹出一次test弹窗,浏览到第二张卡片,点击一次body则会连续弹出两次test弹窗,到第三张卡片,点击一次则会连续弹出三次test弹窗,以此类推,点击事件会不断叠加, 问题不出在click事件本身,而是因为是body对象下的click,如果改为其他比如$(".anki").click(...);则完全不会出现上述问题! \$ K" Z# O1 E) v; d

    4 @. @" _2 f8 A9 `* _( p# H解决办法其实很简单,把document , html ,body 元素对象里的相关代码做个限制,只允许执行一次即可.4 g- Y5 P  B3 B8 j; |1 \' T/ T
    2 V, B+ S8 {" g, p7 W- Z7 }
    比如上述代码可以这样写:
    8 W( x* W# x. }8 ]% V
    游客,如果您要查看本帖隐藏内容请回复

    ) @- {( K# X) S) Z9 t% i1 O% e4 \) X0 I9 A; b" M+ e7 ]
    另外一个问题,ANKI怎么引入外部JS文件? 直接<script src="..."></script>是无效的,会被anki过滤掉.
      v, }* y9 i: C2 r! B/ n6 I& W% ~# N7 N
    可以这样写
    ) {* b2 M% l3 E1 g
    1. var script = document.createElement('script');
      7 I- Q* u6 `7 {& `/ a
    2. script.type = "text/javascript";
      6 z( o$ C0 u3 v$ ?7 b' M4 t# t
    3. script.src = "_jquery.js"; 5 M& Y7 d" ~# x
    4. document.getElementById("ak_wrap").appendChild(script);
    复制代码

    ) c- f& x7 x" S: l5 Q3 p; k这里特别注意,一不小心就会踩了上面那个坑,代码第四行你肯定会想当然用document.body.appendChild(script)吧,前面刚说了document.body对象里的JS会被重复执行,这样写后果就是到第二张卡片的时候就会出现两个<script src="_jquery.js"></script>, _jquery.js被调用了两次,正确的写法是append到除body, html外的其他元素里.6 w+ [1 T, w2 t( i2 m  u
    3 A  a5 `3 r+ N: }
    以上, 希望对你有帮助

    评分

    2

    查看全部评分

    本帖被以下淘专辑推荐:

    该用户从未签到

    发表于 2020-2-7 20:51:12 | 显示全部楼层
    anki的back页面不需要用script导入jquery,我看程序文件里面包含了一个jquery.js的文件不需要导入就可以直接使用。楼主的这个回答刚好解决了我这几天纠结的问题,我遇到了js动态插入iframe换页不会消失的问题,感谢楼主
  • TA的每日心情

    2018-9-22 15:41
  • 签到天数: 4 天

    [LV.2]偶尔看看I

    发表于 2018-9-18 17:51:02 | 显示全部楼层
    目前每次加载新卡片时WebView不会刷新(见GitHub),导致用WordQuery从mdx中提取的内容的JS动态效果用不了。; s( U6 G& i0 u! D& q2 w( w
    我在macOS端和AnkiDroid端尝试过,均有此问题。
    # j# T% \( H% ^$ Y- n请问楼主这个问题目前有办法解决么?

    该用户从未签到

    发表于 2024-7-10 09:47:05 | 显示全部楼层
    本帖最后由 码农爱学习 于 2024-12-9 11:54 编辑 + }8 h$ h3 G* T% R9 h8 `* z4 x
    . Q" G0 ~. `( t& y* E& x
    localstore 存个状态来控制就行了,GitHub上有个什么数据持久化的js也是类似的

    该用户从未签到

    发表于 2018-5-21 10:39:00 来自手机 | 显示全部楼层
    技术贴,学习了。

    该用户从未签到

    发表于 2018-5-21 10:40:25 来自手机 | 显示全部楼层
    评论不行,还要回复?。
  • TA的每日心情

    2018-6-15 17:23
  • 签到天数: 19 天

    [LV.4]偶尔看看III

    发表于 2018-5-31 15:40:55 | 显示全部楼层
    本帖最后由 ywgyf 于 2018-5-31 15:42 编辑 9 N1 t( r3 G6 u# y  \$ _- C& m

    . m) P/ d( m3 Z4 \# c+ K  F真是个高手,不去微软可惜了

    该用户从未签到

    发表于 2018-6-16 11:03:46 | 显示全部楼层
    楼主好功夫,非常希望学习ANKI的高级技巧,特别是javascript的技巧
  • TA的每日心情
    开心
    2018-6-18 09:03
  • 签到天数: 110 天

    [LV.6]常住居民II

    发表于 2018-6-17 08:19:04 | 显示全部楼层
    学习技术,这个问题很恼人,在anki里最好还是用最简单的卡片。
  • TA的每日心情

    2018-9-22 15:41
  • 签到天数: 4 天

    [LV.2]偶尔看看I

    发表于 2018-8-18 23:09:16 | 显示全部楼层
    谢谢楼主分享
  • TA的每日心情
    擦汗
    2020-6-6 16:10
  • 签到天数: 164 天

    [LV.7]常住居民III

    发表于 2019-4-15 10:21:19 | 显示全部楼层
    谢谢楼主分享
  • TA的每日心情

    2022-8-12 22:30
  • 签到天数: 170 天

    [LV.7]常住居民III

    发表于 2019-7-11 00:45:01 | 显示全部楼层
    技术贴,学习了。
  • TA的每日心情

    2024-9-11 14:05
  • 签到天数: 140 天

    [LV.7]常住居民III

    发表于 2020-1-18 17:38:40 | 显示全部楼层
    2020年1月了,看看最新版解决了没
  • TA的每日心情
    开心
    2022-12-26 00:41
  • 签到天数: 17 天

    [LV.4]偶尔看看III

    发表于 2020-1-19 14:33:05 | 显示全部楼层
    被困扰很久了
  • TA的每日心情
    开心
    2020-2-18 11:41
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2020-2-12 23:15:11 | 显示全部楼层
    谢谢楼主,帮助我提前预习该知识
  • TA的每日心情
    开心
    2022-2-12 18:24
  • 签到天数: 438 天

    [LV.9]以坛为家II

    发表于 2020-2-28 19:45:14 | 显示全部楼层
    谢谢楼主分享学习技术
  • TA的每日心情
    擦汗
    2025-4-12 08:04
  • 签到天数: 74 天

    [LV.6]常住居民II

    发表于 2020-3-16 06:34:56 | 显示全部楼层
    谢谢楼主分享这么好的心得!
  • TA的每日心情
    开心
    2021-4-14 18:35
  • 签到天数: 92 天

    [LV.6]常住居民II

    发表于 2020-4-21 16:22:52 | 显示全部楼层
    技术干货,感谢分享
  • TA的每日心情
    郁闷
    2021-1-9 15:32
  • 签到天数: 106 天

    [LV.6]常住居民II

    发表于 2020-5-9 14:03:17 | 显示全部楼层
    观摩大神技术贴
  • TA的每日心情
    奋斗
    2023-12-14 15:58
  • 签到天数: 874 天

    [LV.10]以坛为家III

    发表于 2020-5-29 02:08:43 | 显示全部楼层
    感谢大佬分享经验!

    该用户从未签到

    发表于 2021-1-29 19:49:29 | 显示全部楼层
    感谢楼主,完美解决了我的问题
    您需要登录后才可以回帖 登录 | 免费注册

    本版积分规则

    小黑屋|手机版|Archiver|PDAWIKI |网站地图

    GMT+8, 2025-5-23 11:37 , Processed in 0.026460 second(s), 30 queries .

    Powered by Discuz! X3.4

    © 2001-2023 Discuz! Team.

    快速回复 返回顶部 返回列表