掌上百科 - PDAWIKI

 找回密码
 免费注册

QQ登录

只需一步,快速开始

查看: 2254|回复: 21

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

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

    [LV.6]常住居民II

    发表于 2018-5-20 16:46:00 | 显示全部楼层 |阅读模式
    本帖最后由 garypang 于 2018-5-20 19:10 编辑 7 _# Y: c' z  f9 v4 U8 v

    5 e% ^0 c/ j* k& v/ e% @以下只针对PC下的ANKI: t, B- u1 ]* f& s2 h% L

    $ {. o! q8 P$ m3 B% \8 L; Y不知大家有发现没,ANKI中的一些JS效果会不断累加,浏览到第几张卡片JS就会在当前卡片上执行多少次,导致除第一张卡片外的其他所有卡片上的JS都不能正常显示, 有个插件能解决这个问题https://ankiweb.net/shared/info/1280253613/ ~+ J# `5 k; M: E' `
    但只针对anki2的, anki2.1还是没办法,8 Q$ W/ [9 Z! F) ?7 q+ x" P/ W
    不用插件行不行呢,% z3 x2 ?1 ~# I- c$ I5 R
    首先得弄清楚为啥会出现这个问题,
    % t. `7 T9 Q6 E% f0 f& _ANKI对所有 document , html ,body 元素对象里相关的JS代码都会累加重复执行,比如
    9 X) ~( k/ O) C
    1. document.body.click(...)# F1 x+ e8 V; u! h) Y
    2. $(window).keyup(...)
      : V* {: O# l- D3 b
    3. $(window).scroll(...)
      * l1 n6 K3 x" r9 |1 d; V1 d% P
    4. $("html,body").animate(...)5 ]8 N1 l1 W2 {; ]( _" x0 e8 }$ m3 v8 r
    5. ...
      ( N( K! D& Y. p2 o& G( c  a- d
    复制代码
    ! p  W& _6 R8 c* P5 i
    举个栗子0 k- y; ~. k9 L& m, B( M" e, u8 N3 E
    1. $("body").click(function(){$ O' z8 b/ v7 `" P+ P. B5 e
    2. alert("test");
      : ]6 e7 O4 K, E% V5 J% D5 h
    3. })
    复制代码
      Z* d$ }5 f6 g$ c5 u+ w
    浏览第一张卡片的时候,鼠标点击body会弹出一次test弹窗,浏览到第二张卡片,点击一次body则会连续弹出两次test弹窗,到第三张卡片,点击一次则会连续弹出三次test弹窗,以此类推,点击事件会不断叠加, 问题不出在click事件本身,而是因为是body对象下的click,如果改为其他比如$(".anki").click(...);则完全不会出现上述问题
    5 t" L0 \4 u3 G! C* t, g: ~4 }, s3 U- M3 X
    解决办法其实很简单,把document , html ,body 元素对象里的相关代码做个限制,只允许执行一次即可.
    % C' u! v& r; [+ Q
    % w. c# M7 e# Z; Y% [比如上述代码可以这样写:  [& v& c. ^4 h/ y! `
    游客,如果您要查看本帖隐藏内容请回复

    ( ]6 G1 t  \7 J* R+ ?; z, u9 M6 f7 @
    另外一个问题,ANKI怎么引入外部JS文件? 直接<script src="..."></script>是无效的,会被anki过滤掉.4 p4 w) k, m# b" _0 m  e

    0 O5 l# ~! y% b/ \2 i( w可以这样写) q" C9 H/ j8 n3 L' c
    1. var script = document.createElement('script');
      : _- J6 @  o8 S7 l5 ]1 e# {
    2. script.type = "text/javascript";6 C# I- U& c+ Q! g% I3 Z
    3. script.src = "_jquery.js";
      ! _3 X% |0 k7 @9 e+ {
    4. document.getElementById("ak_wrap").appendChild(script);
    复制代码

    6 W* s/ t- ^$ L2 p' \3 r这里特别注意,一不小心就会踩了上面那个坑,代码第四行你肯定会想当然用document.body.appendChild(script)吧,前面刚说了document.body对象里的JS会被重复执行,这样写后果就是到第二张卡片的时候就会出现两个<script src="_jquery.js"></script>, _jquery.js被调用了两次,正确的写法是append到除body, html外的其他元素里.+ @# q6 ?9 r4 w1 b% e

    - m, P1 n+ d& h. B以上, 希望对你有帮助

    评分

    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 编辑
    9 I9 l, t* L# s) C! F* N7 c: z& z3 Q* y" Z  y# h, v
    真是个高手,不去微软可惜了

    该用户从未签到

    发表于 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动态效果用不了。  k- L$ r5 E4 S, o$ Z
    我在macOS端和AnkiDroid端尝试过,均有此问题。
    - D; E3 K1 M; O" n: t0 u请问楼主这个问题目前有办法解决么?
  • TA的每日心情
    擦汗
    2020-5-16 20:52
  • 签到天数: 163 天

    [LV.7]常住居民III

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

    [LV.7]常住居民III

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

    2020-5-11 18:09
  • 签到天数: 131 天

    [LV.7]常住居民III

    发表于 2020-1-18 17:38:40 | 显示全部楼层
    2020年1月了,看看最新版解决了没
  • TA的每日心情
    无聊
    2019-1-4 00:43
  • 签到天数: 13 天

    [LV.3]偶尔看看II

    发表于 2020-1-19 14:33:05 | 显示全部楼层
    被困扰很久了

    该用户从未签到

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

    [LV.1]初来乍到

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

    [LV.8]以坛为家I

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

    [LV.6]常住居民II

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

    [LV.6]常住居民II

    发表于 2020-4-21 16:22:52 | 显示全部楼层
    技术干货,感谢分享
  • TA的每日心情

    5 天前
  • 签到天数: 102 天

    [LV.6]常住居民II

    发表于 2020-5-9 14:03:17 | 显示全部楼层
    观摩大神技术贴
    您需要登录后才可以回帖 登录 | 免费注册

    本版积分规则

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

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

    GMT+8, 2020-5-25 22:35 , Processed in 1.651322 second(s), 11 queries , MemCache On.

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

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