兔源码网 - 专注DZ模版分享、DZ插件分享!

 找回密码
 立即注册

QQ登录

只需一步,快速开始

广告
温馨提示:本站所有DZ相关模板、插件、教程(包括DZ应用中心已下架插件、模板)皆为提供免费下载,无任何收费模式(不包括VIP版块非DZ资源,VIP版块需充值兔币购买会员组方可下载),用户仅需手动前往【申请下载权限】申请用户组下载权限即可,如本站没有您需要的插件或模板,请自行前往淘宝互站网送吗网等第三方站点搜索相关插件或模板进行低价格购买下载本站非常不建议用户浪费金钱前往DZ应用中心购买。

jQuery 核心 - noConflict() 方法

[复制链接]
tuyuanma 发表于 2017-3-11 20:15:53 | 显示全部楼层 |阅读模式
温馨提醒:禁止内容附带广告图片、二维码图片,否则将在不通知情况下永久禁言账号!
欢迎加入兔源码站长交流群,您的加入是我们前行的动力!

DZ站长建站交流群:493651246

[ 温馨提示:点击上方群文字,可快速加入QQ群 ]


实例

使用 noConflict() 方法为 jQuery 变量规定新的名称:

  1. var jq=$.noConflict();
复制代码

定义和用法

noConflict() 方法让渡变量 $ 的 jQuery 控制权。

该方法释放 jQuery 对 $ 变量的控制。

该方法也可用于为 jQuery 变量规定新的自定义名称。

提示:在其他 JavaScript 库为其函数使用 $ 时,该方法很有用。


( `+ B* Q' u) N! U6 J语法
  1. jQuery.noConflict(removeAll)
复制代码
参数描述
removeAll布尔值。指示是否允许彻底将 jQuery 变量还原。
说明

许多 JavaScript 库使用 $ 作为函数或变量名,jQuery 也一样。在 jQuery 中,$ 仅仅是 jQuery 的别名,因此即使不使用 $ 也能保证所有功能性。假如我们需要使用 jQuery 之外的另一 JavaScript 库,我们可以通过调用 $.noConflict() 向该库返回控制权:

  1. <script type="text/javascript" src="other_lib.js"></script>
    6 [+ t; S: R% @, O1 P4 x5 G
  2. <script type="text/javascript" src="jquery.js"></script>* S3 m4 `, m% a( H: x
  3. & l3 Q8 E3 Z( U7 v
  4. <script type="text/javascript">- {7 d, B, q/ H$ ^8 B0 p
  5.   $.noConflict();
    % s5 y! m; C+ v( K4 q
  6.   // 使用另一个库的 $ 的代码& X" J8 c% z: H5 j& }' f
  7. </script>
复制代码
可以与 .ready() 方法结合起来使用,来为 jQuery 对象起别名,这项技术非常有效:
  1. <script type="text/javascript" src="other_lib.js"></script>5 ~5 K$ n  U2 Y' H; W4 W, G
  2. <script type="text/javascript" src="jquery.js"></script>7 I# \- z* v  z; {; D

  3. : p8 u! m0 \/ m+ G/ O" X: R3 a
  4. <script type="text/javascript">5 V! O: }- R. u* @& L, Z8 C/ D
  5.   $.noConflict();: L" Z3 E6 _, o5 |* s3 f
  6.   jQuery(document).ready(function($) {1 l2 v0 J5 V2 r; k
  7.     // 使用 jQuery $ 的代码% F4 a5 G4 f* W
  8.   });
    0 R2 g. h' v) h
  9.   // 使用其他库的 $ 的代码
    7 V' E8 u) l) }1 O0 Q/ l% A
  10. </script>
复制代码

此外,通过向该方法传递参数 true,我们可以将 $ 和 jQuery 的控制权都交还给原来的库。用之前请考虑清楚!

这是相对于简单的 noConflict 方法更极端的版本,因为这将完全重新定义 jQuery。这通常用于一种极端的情况,比如你想要将 jQuery 嵌入一个高度冲突的环境。注意:调用此方法后极有可能导致插件失效。


, Y  ^) c( i8 T$ a. t' K. M0 J& g
& v/ ^% G2 c, V" H
实例例子 1

将 $ 引用的对象映射回原始的对象:

  1. jQuery.noConflict();
    3 E% t* j1 E9 ~0 K7 h) I+ J9 n- Y
  2. " ]# x& n" d* d1 N; A
  3. jQuery("div p").hide();        // 使用 jQuery% F, b% f& R: j1 Z
  4. # f+ N6 t. X) v" V0 h* j% e
  5. $("content").style.display = "none";        // 使用其他库的 $()
复制代码

8 N' q) O3 n6 N; ?9 U9 g
例子 2( h6 w3 f3 y# p& Q) |: r' x

恢复使用别名 $,然后创建并执行一个函数,在这个函数的作用域中仍然将 $ 作为 jQuery 的别名来使用。在这个函数中,原来的 $ 对象是无效的。这个函数对于大多数不依赖于其他库的插件都十分有效:

  1. jQuery.noConflict();
    5 s4 e" C, b# K: X: y2 Q
  2. ; @1 @3 V: i; L9 V  h+ I6 A
  3. (function($) { ( a* s. x/ W3 P3 V
  4.   $(function() {
    5 [0 M: `- C6 l. }( M9 P
  5.     // 使用 $ 作为 jQuery 别名的代码. p7 h8 F2 u& L0 S
  6.   });$ q/ l  z% V# Z' a2 ~8 l
  7. })(jQuery);4 h5 n# Y; B* w, L4 x
  8. 2 \# p$ w/ Q. D9 N3 Y
  9. ... // 其他用 $ 作为别名的库的代码
复制代码

, d4 c9 L  `$ Y6 L( Z& b( R
例子 3
2 M5 ]8 _+ G: E9 r& C( P9 t

可以将 jQuery.noConflict() 与简写的 ready 结合,使代码更紧凑:

  1. jQuery.noConflict()(function(){( Y7 \# Z8 `7 F) T0 j6 ^( T
  2.     // 使用 jQuery 的代码
    ) P! F  o! e9 a% {* s0 @5 @6 @0 ]
  3. });' _. t3 q0 `# A+ z; H

  4. & _+ |6 D* L: h0 m' N
  5. ... // 其他库使用 $ 做别名的代码
复制代码


3 A8 a1 q8 w; Z- A5 f8 {
例子 4

创建一个新的别名用以在接下来的库中使用 jQuery 对象:

  1. var j = jQuery.noConflict();
    7 a2 M# b- }, C  B% c* j- M0 c& u/ Q
  2. + `4 g) e: @; }* N! h
  3. j("div p").hide();        // 基于 jQuery 的代码
      u2 w4 f9 W; k/ o( i/ A. O0 W5 m
  4. * G0 f$ M9 H" v) f. e
  5. $("content").style.display = "none";        // 基于其他库的 $() 代码
复制代码

: U; p* x: v+ ~5 ?4 h0 }
例子 5

完全将 jQuery 移到一个新的命名空间:

  1. var dom = {};/ H; R' H% i" D  I# H% ?  z
  2. dom.query = jQuery.noConflict(true);
复制代码
结果:
  1. dom.query("div p").hide();        // 新 jQuery 的代码
    9 f# @' J0 y2 ]' s" n% a: R3 Y

  2. : n% L5 E  `: k! a% u& x1 n. Q/ S
  3. $("content").style.display = "none";        // 另一个库 $() 的代码" w! }5 `' J1 _% `) A$ ?

  4. 2 D$ d4 c7 _$ {' X9 S) W
  5. jQuery("div > p").hide();        // 另一个版本 jQuery 的代码
复制代码

/ q4 ]" @9 f7 [
1 S! ?0 u# Y! {$ x" ~$ {: w

版权声明
1、转摘或引用本站内容资源须注明原网址,并标明本站网址(兔源码www.tuyuanma.com);
2、对于转摘或引用本站内容资源而引起的民事纠纷、行政处罚或其他损失,本站不承担责任;
3、对于不遵守本声明或其他违法、恶意使用本站内容者,本站保留其追究法律责任的权利。




自动排版 | 高级模式
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

广告

兔源码网 ( 赣ICP备17001544号 公网安备36112102000036号 )

兔源码 QQ交流群:493651246  GMT+8, 2019-7-19 06:20
←站长统计工具 查看密码:tuyuanma

兔源码DZ模板下载 站长邮箱:tuyuanma@qq.com 站长QQ:3197813386 网站地图

© 2001-2013 本站内容皆来自互联网及用户分享,如需删除请提供软著或商标证书。

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