掌上百科 - PDAWIKI

 找回密码
 免费注册

QQ登录

只需一步,快速开始

查看: 1056|回复: 12

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

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

    [LV.6]常住居民II

    发表于 2018-5-20 16:46:00 | 显示全部楼层 |阅读模式
    本帖最后由 garypang 于 2018-5-20 19:10 编辑
    & A; z3 z, |! O  }* c- X# {& v# q3 H( i) w3 j' `
    以下只针对PC下的ANKI: i9 \/ f0 G5 U: w& P
    # C# p% q0 i) L) ]
    不知大家有发现没,ANKI中的一些JS效果会不断累加,浏览到第几张卡片JS就会在当前卡片上执行多少次,导致除第一张卡片外的其他所有卡片上的JS都不能正常显示, 有个插件能解决这个问题https://ankiweb.net/shared/info/1280253613& P' V) A/ w, L7 u4 _3 ^- w
    但只针对anki2的, anki2.1还是没办法,0 y% F1 B9 i" k9 ~. k
    不用插件行不行呢,
    . F- m& W7 l* ^( I0 \/ P首先得弄清楚为啥会出现这个问题," t$ K' Q1 j; \7 S6 P7 _
    ANKI对所有 document , html ,body 元素对象里相关的JS代码都会累加重复执行,比如: k4 w3 j1 U* @- q. T; F+ z
    1. document.body.click(...)
        X9 V7 e5 t8 O  L$ D
    2. $(window).keyup(...)
      3 y  E/ N7 m0 a. \
    3. $(window).scroll(...)' W) g9 s, r5 |3 t
    4. $("html,body").animate(...)
      : @* c, t3 C7 H5 Y! P" s
    5. ...
      1 l8 G9 v6 c$ R% A! x& Z9 F9 v
    复制代码

    * x& q4 ^& {, }# W- o) W举个栗子/ K6 B( h8 @; E8 o8 S  [8 C* y
    1. $("body").click(function(){+ m! X& b) u) V9 Z1 n# }: L( v
    2. alert("test");
      " ]! I3 a2 ^. \+ X( B. B
    3. })
    复制代码

    ( L9 S" g' c, ^& {1 {" O; Y0 V浏览第一张卡片的时候,鼠标点击body会弹出一次test弹窗,浏览到第二张卡片,点击一次body则会连续弹出两次test弹窗,到第三张卡片,点击一次则会连续弹出三次test弹窗,以此类推,点击事件会不断叠加, 问题不出在click事件本身,而是因为是body对象下的click,如果改为其他比如$(".anki").click(...);则完全不会出现上述问题
    3 N0 f0 m1 I  d' P$ p. a- y5 h& V6 H- j  f4 |* K, @
    解决办法其实很简单,把document , html ,body 元素对象里的相关代码做个限制,只允许执行一次即可.: g! ~2 V. P' g, E6 W" l2 `. M( w

    - t& u, d+ x, \6 s比如上述代码可以这样写:& m( ^6 w2 t( T/ C% g% {7 k8 x
    游客,如果您要查看本帖隐藏内容请回复

    , X$ x9 R4 t* V  d" D9 W, G
    9 T  j6 |' @6 `5 f另外一个问题,ANKI怎么引入外部JS文件? 直接<script src="..."></script>是无效的,会被anki过滤掉.- i8 ~6 j  {3 g/ H6 |) {
    * ?1 H; P0 K; T0 X2 }; c, _0 H" r2 I3 E
    可以这样写" I  F+ \; B9 C) n# y
    1. var script = document.createElement('script');# C: v, T0 G3 N$ b/ v6 w$ D
    2. script.type = "text/javascript";( k  [2 z) Y& \( k) D- U
    3. script.src = "_jquery.js";
      6 |* \2 l  R! l9 J2 e
    4. document.getElementById("ak_wrap").appendChild(script);
    复制代码
    " r* G% h+ M8 b/ e! a" u/ M
    这里特别注意,一不小心就会踩了上面那个坑,代码第四行你肯定会想当然用document.body.appendChild(script)吧,前面刚说了document.body对象里的JS会被重复执行,这样写后果就是到第二张卡片的时候就会出现两个<script src="_jquery.js"></script>, _jquery.js被调用了两次,正确的写法是append到除body, html外的其他元素里.0 Q9 g$ l- ~. F' y' B6 k
    " A& d7 R# E/ O! M! b! D' O' e8 N. V8 ]
    以上, 希望对你有帮助

    评分

    2

    查看全部评分

    本帖被以下淘专辑推荐:

    该用户从未签到

    发表于 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 编辑 0 T) M' y2 w& T
    ; d7 H5 Q0 F7 p7 o4 i; I
    真是个高手,不去微软可惜了

    该用户从未签到

    发表于 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的每日心情

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

    [LV.2]偶尔看看I

    发表于 2018-9-18 17:51:02 | 显示全部楼层
    目前每次加载新卡片时WebView不会刷新(见GitHub),导致用WordQuery从mdx中提取的内容的JS动态效果用不了。% _. z  U' c, t
    我在macOS端和AnkiDroid端尝试过,均有此问题。& J. H& N  Y$ X
    请问楼主这个问题目前有办法解决么?
  • TA的每日心情

    3 小时前
  • 签到天数: 63 天

    [LV.6]常住居民II

    发表于 2019-4-15 10:21:19 | 显示全部楼层
    谢谢楼主分享
  • TA的每日心情
    开心
    2019-8-11 20:43
  • 签到天数: 162 天

    [LV.7]常住居民III

    发表于 2019-7-11 00:45:01 | 显示全部楼层
    技术贴,学习了。
    您需要登录后才可以回帖 登录 | 免费注册

    本版积分规则

    顶部qrcode底部
    关注公众号送论坛充值码
    关注微信公众平台
    关注微信公众号 pdawiki,获取邀请码,看文抢积分,抽奖得浮云! Follow our Wechat official account "pdawiki", get invitation codes, and play the lottery to earn points (积分)!

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

    GMT+8, 2019-8-25 10:58 , Processed in 0.171627 second(s), 13 queries , MemCache On.

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

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