掌上百科 - PDAWIKI

 找回密码
 免费注册

QQ登录

只需一步,快速开始

查看: 893|回复: 13

[求助] [已解决]请教 js 调用次数的问题

[复制链接]
  • TA的每日心情
    慵懒
    2021-11-14 21:48
  • 签到天数: 90 天

    [LV.6]常住居民II

    发表于 2018-5-9 21:42:34 | 显示全部楼层 |阅读模式
    本帖最后由 vigorous 于 2018-5-10 19:32 编辑
    9 ?3 G9 u8 F- p7 [4 |9 ^
    : C& r1 y4 T! G! D- EGoldenDict 开启构词法之后,有时会出现多个词条,比如输入 "apartment" 会出现两个词条(apartment 和 apart)显示在一个页面。' f& J# G4 a( J, Y# w1 D; T. D' j, P
    但是不清楚怎么回事,会出现同一个 js (函数?)调用两次情况,应该如何避免呢?
    ! Z( d1 P6 }+ T, D5 S' x0 b( `3 a
    test.html 代码(在 GoldenDict 中大概显示这个样子):! Z8 `* |5 L- T- `9 H5 K
    1. <html>7 ?6 Q: Q1 N( V% `$ l$ U( A0 O0 P
    2.     <head> </head>
      ( Q/ h% [! i3 `& I" B1 |; t# a
    3.     <body>
      - {# O7 }6 V. G8 O+ H- t
    4.         <div class="mdict">/ I, N8 t& J  y# R9 `
    5.             <script src="jquery-3.js" charset="utf-8" type="text/javascript" language="javascript"></script>; @  J! K4 p. K# N1 l, U" x
    6.             <script src="test.js" charset="utf-8" type="text/javascript" language="javascript"></script>7 d: O. x7 M% \% {3 X7 X) A
    7.             <div class="a">2 a- u7 p- _( D8 J* z+ I7 N
    8.                 AAA2 [( e+ v" Y# c' @4 i) z" W7 C
    9.                 <span class="b"># c- k4 z! i$ d6 n4 R' S% ^* R
    10.                     BBB) {, C3 V( c9 O# f& ]6 X( P1 p
    11.                 </span>
      5 q* J1 T8 q! Y- l4 W
    12.             </div>
      ! `; ]  f! L$ R2 {; ^! u: U
    13.         </div>, B% V2 f0 Z* T* L; r, i
    14.         <div class="mdict">1 b; t( o$ M; B
    15.             <script src="jquery-3.js" charset="utf-8" type="text/javascript" language="javascript"></script>+ e. t5 m& x' y' \
    16.             <script src="test.js" charset="utf-8" type="text/javascript" language="javascript"></script>
      3 U. v+ k+ ?$ O* c. M3 Y/ p
    17.             <div class="a">
      & ?  T' C. S" c9 p( F
    18.                 CCC
      / z* u3 R* i) y* \6 S
    19.                 <span class="b">) s9 w: ~+ T2 P$ @2 ?6 ~
    20.                     DDD3 Q) R! h* h" G, Y( O3 \4 V' `- M# `
    21.                 </span>
      $ V6 k1 \4 L# g
    22.             </div>5 m8 v  T% [2 D
    23.         </div>        5 H7 @5 e1 n' K/ @
    24.     </body>3 J% q* Z/ P0 }" h4 u& ^, c
    25. </html>
    复制代码

    , P/ C2 U+ {8 u. xtest.js 代码:
    % @; h+ ^  G! @: ]: S7 J
    1. jQuery(function(){# Y6 @3 E- d1 B
    2.     $(".a").click(function(){$(this).children(".b").toggle();});7 E; a' D* y; r- D# Q! }
    3. });
    复制代码
    0 J& K" P: W1 C4 F  N5 t" k* T
    我想点击 AAA 或者 CCC 实现切换显示后面的 BBB 或 DDD。
    9 L) ?4 g9 \) p5 ^9 D但实际上点击 AAA 后,调用了两次 toggle(为什么会这样?),等于没有效果。( E+ Y8 ?- K: a, \! Z1 A0 q
    ; i$ [. G5 z) z' {" Q
    本人完全小白,有没有稍微简单一点的方法,能让我明白这个问题该怎么解决,先谢谢了。( N) a( J* H4 j/ d0 S4 |

    0 z- H$ N$ n. i6 R8 _$ w0 a----------$ ?5 S6 r# t0 t
    更新:
    ' c! F1 A% I, \7 B4 g4 I" R谢谢各位,都是不错的方法,很受用!2 Y3 ~# _2 E: w/ y5 I9 D

    评分

    1

    查看全部评分

  • TA的每日心情
    开心
    2019-1-21 17:00
  • 签到天数: 376 天

    [LV.9]以坛为家II

    发表于 2018-5-9 22:28:59 来自手机 | 显示全部楼层
    可以在底部加一个全局变量,前面函数执行的时候对这个全局变量做个判断,true则返回。false才执行。

    评分

    1

    查看全部评分

  • TA的每日心情
    慵懒
    2018-8-25 12:29
  • 签到天数: 91 天

    [LV.6]常住居民II

    发表于 2018-5-10 00:43:26 | 显示全部楼层
    本帖最后由 garypang 于 2018-5-10 00:45 编辑 4 g) k# `0 ^; _+ m: ^. P. R
    须佐之男 发表于 2018-5-9 22:28- Y6 ]4 N5 i) i' o) o$ J+ |. u
    可以在底部加一个全局变量,前面函数执行的时候对这个全局变量做个判断,true则返回。false才执行。 ...
    # q5 X; L' F5 q) [4 B% Z

    3 {* {" l" ]! P$ ]好想法,但这全局变量肯定不能加在这词典里面,不然每次都会被初始化掉,Goldendict的话除了词典,没有其他途径加载JS了,问题是有哪部词典能做到查所有词都有结果呢,词典词条又不支持正则匹配所有词条
  • TA的每日心情
    开心
    2019-1-21 17:00
  • 签到天数: 376 天

    [LV.9]以坛为家II

    发表于 2018-5-10 01:33:28 | 显示全部楼层
    garypang 发表于 2018-5-10 00:437 |" z5 X& u" ^
    好想法,但这全局变量肯定不能加在这词典里面,不然每次都会被初始化掉,Goldendict的话除了词典,没有其他途 ...

    4 H: ?( j1 n9 n2 W- z1 L1 f
    + N, J% @2 q8 `4 U* J5 Q9 t, w楼主碰到的问题应该是同一部词典的两个或两个以上词条被同时显示了,这个情况在欧路也有。
    2 |8 |6 J( i3 h& C
    1. if (!xxx) {需要执行的代码}
      ) \- q: v1 W+ `
    2. var xxx = true;
    复制代码
    , E  D! v0 y$ L9 D
    这么写,虽然js引入多次,但只执行一次。
    # p$ I. P9 J1 H: K( V; I/ D
    2 P7 j% Q& B1 \

    评分

    2

    查看全部评分

  • TA的每日心情
    开心
    2020-5-23 22:47
  • 签到天数: 128 天

    [LV.7]常住居民III

    发表于 2018-5-10 10:05:53 | 显示全部楼层
    本帖最后由 QQending2 于 2018-5-10 11:15 编辑 , v- Y6 D4 }  R6 a9 I7 `1 G& V
    3 }+ w$ B3 r( l1 W1 ~! A
    错误判断已删除% X, p3 {2 o! K2 k$ c
    --------------------------------------
    ' x  q; p' I# A6 I% n" q3 w/ N* s- P
    以上好像不是关键所在……6 S0 g4 z% {) t- A3 y# ^
    继续分析中
  • TA的每日心情
    开心
    2020-5-23 22:47
  • 签到天数: 128 天

    [LV.7]常住居民III

    发表于 2018-5-10 11:11:46 | 显示全部楼层
    本帖最后由 QQending2 于 2018-5-10 12:01 编辑
    3 E8 A, l5 C3 }: G3 ~8 T% d1 [, R0 l: K+ s& J1 _
    我的上一个回复为制杖回复# \- I2 j5 w1 g) ~" e

    $ Q& J4 c' C  t0 I" W. N$ o. V* _无意义回复,已编辑掉了
    # ~0 ]# Q: v5 q4 f9 {* e" U- E4 H
      N( b# E* ~( A; e! L* f9 `4 L0 z& B8 P3 O: ?
    ---------------------------------------
    4 u: T/ Y9 |% J又写错了……
  • TA的每日心情
    开心
    2018-1-29 01:48
  • 签到天数: 10 天

    [LV.3]偶尔看看II

    发表于 2018-5-10 11:31:00 | 显示全部楼层
    本帖最后由 fearfare090807 于 2018-5-10 11:54 编辑
    . K. q4 q( Z: V9 |' @2 P, o  U. B9 y" L
    赞一下楼主描述问题的方式,非常清晰而且有诚意,居然做了个网页摘要出来,所以我不得不答一下8 s( b* F, H4 D
    这是我用在本人collins里的防重入代码" Y% p8 ~8 D+ i0 h$ q
        if (typeof window.colcobuildoverhal_counter == 'undefined') {# d/ P9 p8 M) Q5 @7 k; a
            window.colcobuildoverhal_counter = 1;
    + q! a" h) ?0 Q# d4 G  G9 h) |9 D    } else {. A& d' ^: [5 a7 H+ O* Y* g
            return;  q6 m1 c2 d" h; {5 e/ l& v
        }3 X6 R( ~4 d  W+ k' s
    不需要声明任何变量,你放在任意位置都可以的,当然变量名你需要改一下

    评分

    1

    查看全部评分

  • TA的每日心情
    开心
    2018-1-29 01:48
  • 签到天数: 10 天

    [LV.3]偶尔看看II

    发表于 2018-5-10 11:32:56 | 显示全部楼层
    QQending2 发表于 2018-5-10 11:11
    + m6 q$ I7 @: \3 O* q# i$ t我的上一个回复为制杖回复$ z- K# Y9 V9 ?+ x
    - [# G- u; R5 l8 b8 u$ `
                
    8 f* U0 x. G+ Z& r% f
    你弄错了
    . D$ b  h7 ?& n4 w- z3 T, s+ v楼主这么写是摘要了goldendict当时出问题的网页,而不是他这么写的$ S% S9 r! z2 U& d7 Z4 l# ~' S9 u1 t
    所以,那个重复是goldendict造成的,你不可能去删goldendic的网页上的内容。
  • TA的每日心情
    开心
    2020-5-23 22:47
  • 签到天数: 128 天

    [LV.7]常住居民III

    发表于 2018-5-10 11:58:35 | 显示全部楼层
    本帖最后由 QQending2 于 2018-5-10 12:36 编辑 2 E# p% L; g' g- X  u" n9 p# o
    7 g  y8 F9 @' B' t% M
    我的解决方法代码:) {* R$ u% e* d8 ?' E
    1、
    9 C9 ?  ^: y1 L! ?. L, t* _
    1. var isToggle = false;$ p2 h! T& V1 ]. K

    2. ; K8 e; T3 w" P1 R4 v  z
    3. $(function(){. `4 C2 D; b% M$ f# @& ~0 h- ?
    4.     $(".a").click(function()
        {8 S/ Y9 e8 g+ `0 l" s
    5.         {. h' A$ B3 G3 U2 o& q
    6.         if (!isToggle){
        I0 {5 y( k  r4 d; L" t9 e
    7.                 isToggle = true;
      & ?+ e0 b7 r$ w! {
    8.                 console.log(isToggle);
      : C9 |& j5 y' `1 D8 ^1 P8 i- o$ H5 C
    9.                 $(this).children(".b").toggle();
      , G2 M& e, a; J+ K/ s
    10.                 }- @* a" \4 T. _  X. h
    11.         else{ isToggle = false; }
      4 g# x8 Q; k; C5 E4 {  {
    12.         });
      / v& o( r% p5 T  d" T" Z! B/ n6 H0 v
    13.        
      9 E" c5 Q8 v! o3 m) N% y  V% H! n
    14. });
    复制代码
    0 q( w7 v6 E( |; S6 @7 r, j; B) ?

    9 o  G3 [2 X- O2、
    - E0 O/ l! o8 P& d. X  a
    1. $(function(){2 z5 ^# a* ^3 |# w: ]
    2. console.log(isToggle);
      3 r- q( q+ ^. C) n* `3 d
    3.         if (!isToggle){isToggle = true;}. P% I3 S# k7 z$ ?
    4.         else{ return;}
      * A" J! {7 y  w
    5.     $(".a").click(function()
      9 t9 L6 p% }8 ]2 J, Y
    6.                 {$(this).children(".b").toggle();}       
      % h8 B+ K+ n! g: G* Q9 N
    7.         );
      1 g3 P3 x) v" E' L7 }. W
    8. });
    复制代码
    " C4 p8 a$ r. C- m# c+ X( E
    3 e  J8 `% T! q# G9 H: @- u# T: M6 K
    : Y" _' D7 z* V1 z
    FF大的解决方法代码:
      e% ]' n" W5 P! b) [
    1. $(function(){' i) y! I% Z9 ~: _
    2.   Z5 ]8 L9 Y; Z- C2 E3 C( E  ?# v
    3.         if (typeof window.toggle_test == 'undefined') {
      " A3 Q9 j# F" `" `' o  ^; ^
    4.                 window.toggle_test = 1;
      * b( M2 G1 T' @0 a% }
    5.         } else {return;}
      4 k' Y" u1 f5 `  W' X
    6.                
      # [4 S! K, K" k
    7.     $(".a").click(function()4 Q  U" u# l' _+ z
    8.         {) V0 J# t8 X# y( ~/ x! Z
    9.                 $(this).children(".b").toggle();
      ; v+ {6 m0 H% s/ F
    10.         });/ O' ^1 D$ _$ {

    11. 1 U, E2 ~2 p+ g; Q
    12. })
    复制代码

    / m; t" R. v1 d; S3 H4 t8 N" i0 A- p% \! y2 P+ |9 j7 F9 A+ A6 R
    其中有Return,放在主函数体内,如果不用Return,那就无所谓了。
    8 A5 j+ ~' i+ \! ]$ z" O
      f6 |1 r; J0 K: [" |/ _0 G8 U. B# Q% H2 a3 P: N7 Z# ~
    好了( J* q% c" b1 s! ]
    这样应该可以了。
    3 i1 n' V: _" e7 e5 o- k- Z声明全局变量(var)要放在所有文件的最开头部分
    - X  |9 k" g5 T  d$ B. Q9 [3 t; {" Z. @+ c
    0 e0 i- c  I( P/ u3 b3 ^
    ! G: R) U6 ^, _. n; f' p
    - v6 X! C$ O" Y8 i
    我百度到的声明全局变量的方式
    ) O3 |, R' H6 V6 C0 n: [) _
    $ S: E$ A7 J" x1 q+ {   声明全局变量的4种方法。
    4 f# S6 v1 c3 R8 b) O, M
    9 e0 T4 z+ M7 Z8 x+ J- c; A   1.直接在全局作用域中用var 声明的变量就是全局变量,此种方式声明的变量具有不可配置的属性,不能使用delete操作符把变量删除。( B4 o! D3 F1 B: L- O0 _
    . w1 C6 U: Z) h$ s
       2.window.变量,这种声明的变量也是全局变量,但这种变量跟上面用var 声明的变量有点不一样,这种方式声明的全局变量是可配置的,因此能用delete操作符把变量删除。5 T# \% X  ~! z$ F

    # D& A. _% V- f4 L, W. ?. B   3.隐式声明全局变量,就是不使用var声明,直接进行赋值的变量,在不严格模式中,相当于window.变量这种方式,但在严格模式下,会报错。
    $ k8 S9 z4 D- w  t
    9 u, I& P' o1 J0 y. h" O  ^& f   4.在html中给标签指定一个id属性,也相当于给Window对象添加了一个id的属性,在javascript中可直接通过标签的id访问该标签(或者window['id'])。7 @4 X" x  Q- w. B7 Z
    4 `: V; N% j3 x1 E$ G% ~6 d

    # \, \" p) X6 y' T' z" Y% a) p, lFF大应该用到的是第二种window

    评分

    2

    查看全部评分

  • TA的每日心情
    开心
    2020-5-23 22:47
  • 签到天数: 128 天

    [LV.7]常住居民III

    发表于 2018-5-10 12:01:05 | 显示全部楼层
    本帖最后由 QQending2 于 2018-5-10 12:02 编辑
    8 n  |4 d7 n" x2 `* Z
    fearfare090807 发表于 2018-5-10 11:32
    3 O3 p6 {2 x6 g' k: {你弄错了8 s/ v$ h, _+ B5 `- g/ N3 _9 k
    楼主这么写是摘要了goldendict当时出问题的网页,而不是他这么写的
    / ^" {- w- w2 a0 w所以,那个重复是goldendict ...

    3 X; Z9 Q" T& v+ v, j% L# y* N7 K  j) A# x, P. Y8 _
    这次改好了……的确是我弄错了' z4 `' r' L: Q  p
    一是我没有看清9 e$ g) E4 O1 _* p) Q7 L  S/ l; ~; S: _
    二是我自己本来就对这些很不了解,我也是看看别人会出现什么问题,顺便学习一下。3 j2 i; O. }" i
    反正都是要制作字典的嘛
    8 b% {' Z( Z' j6 d* n, K' Q0 l/ f2 T" M4 g$ u* y
    还有谢谢你的那个window方法。
  • TA的每日心情
    开心
    2020-5-23 22:47
  • 签到天数: 128 天

    [LV.7]常住居民III

    发表于 2018-5-10 12:07:17 | 显示全部楼层
    fearfare090807 发表于 2018-5-10 11:32  D+ K1 o) P; Y- T" o
    你弄错了9 ^# c( _8 i  s/ ~8 U6 u" ]  t
    楼主这么写是摘要了goldendict当时出问题的网页,而不是他这么写的; r/ z2 X1 Y1 H* ?
    所以,那个重复是goldendict ...
    ; u5 H3 f( X8 r3 q
    顺便请教一下2 y) q5 Z1 Z0 O" u; j
    FF大调试字典显示样式的时候使用的是Chrome么。
    2 L3 I: H* b4 \4 b如果不是,有什么好的推荐的么8 d2 V( ^- e# p
    谢谢
  • TA的每日心情
    开心
    2018-1-29 01:48
  • 签到天数: 10 天

    [LV.3]偶尔看看II

    发表于 2018-5-10 12:21:30 | 显示全部楼层
    QQending2 发表于 2018-5-10 12:07
    - S' N7 p6 X% u6 H4 A. b: g* s顺便请教一下
    + R2 B% T1 \4 ~9 I, z0 P( eFF大调试字典显示样式的时候使用的是Chrome么。( }) M0 I% X* |5 n
    如果不是,有什么好的推荐的么
    0 J) P5 V# f. L- u# T4 m) ]: b
    我主要用火狐,偶尔用一下goldendict自带的那个调试器
    , p* k% J0 O& K; M& S. @3 D) u无论火狐还是chrome, 用来调试字典功能都是强大到溢出的) E" `  C2 M( P+ Z5 m
    你用习惯了chrome, 换来做什么?
  • TA的每日心情
    慵懒
    2021-11-14 21:48
  • 签到天数: 90 天

    [LV.6]常住居民II

     楼主| 发表于 2018-5-10 19:29:38 | 显示全部楼层
    感谢各位的热心回复,解决了我的疑惑,学到了好多
    * p; |: m- h' [' N( u& J
    ( E4 s3 x/ a/ d8 i, m" p4 楼须佐之男的方法很简洁,似乎要在外部声明一下才可以用吧?+ }. a# |  S; G: E
    fearfare090807 大大的方法更加模块化,QQending2 还费心做了一番总结,真心有用!
    $ ]6 D+ p& o3 L+ @1 t再次感谢~
  • TA的每日心情
    奋斗
    2018-7-14 09:06
  • 签到天数: 5 天

    [LV.2]偶尔看看I

    发表于 2018-6-3 15:14:35 | 显示全部楼层
    fearfare090807 发表于 2018-5-10 11:31
    ( L0 [1 l8 k  s赞一下楼主描述问题的方式,非常清晰而且有诚意,居然做了个网页摘要出来,所以我不得不答一下
    0 U) E. u* y1 y: _) a这是我用在 ...
    # m, _" b; j- h' A" ]/ m$ e' M
    遇到同樣問題,用這個方法解決了!
    您需要登录后才可以回帖 登录 | 免费注册

    本版积分规则

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

    小黑屋|手机版|Archiver|PDAWIKI ( 美ICP 0000000字 )|网站地图

    GMT+8, 2021-11-29 08:43 , Processed in 0.046238 second(s), 17 queries , MemCache On.

    Powered by Discuz! X3.4

    Copyright © 2001-2020, Tencent Cloud.

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