源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

浅析return false的正确使用

  • 时间:2022-09-26 22:13 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:浅析return false的正确使用
可能在你刚开始学习关于jQuery事件处理时,看到的第一个例子就是关于如何阻止浏览器执行默认行为,比如下面这段演示click事件的代码:
[url=http://jb51.net]<div class="content">      Teaser text...    </div>  </div>  <div class="post">  <h2><a href="http://jb51.net">My Other Page</a></h2>  <div class="content">      Teaser text...    </div>  </div> 
现在假设我们想要在用户点击文章标题时,将文章动态载入到div.contentd中: 这段代码可以正常工作(至少目前是),但如果我们顺着这个思路继续,如果我想要在用户点击了一个div.post元素(或者任何一个它的子元素)时,给它加上一个active类,我就需要给div.post增加了一个[b]click回调: [/b]
[url=http://jb51.net]</div> 
现在,让我们假设如果你点了div上除了a链接之外的地方,我们希望能发生点什么事情(比如改变下背景什么的),但是不能影响用户点击a链接的行为(从可用性的角度,这个例子不怎么好,你可能不希望用户点击别的地方时发生任何事情)。
在这种情况下,如果我们使用return false,div的click事件不会被触发,但是用户也不会到达他们点的那个链接。 [b]stopImmediatePropagation()[/b] 这个方法会停止一个事件继续执行,即使当前的对象上还绑定了其它处理函数,所有绑定在一个对象上的事件会按绑定顺序执行,看看下面的例子:
[u]复制代码[/u] 代码如下:
$("div a").click(function () {    // Do something  });  $("div a").click(function (e) {    // Do something else    e.stopImmediatePropagation();  });  $("div a").click(function () {    // THIS NEVER FIRES  });  $("div").click(function () {    // THIS NEVER FIRES  }); 
你可能会觉得这个例子看起来很别扭,没错,尽管如此,但有时这的确会发生,如果你的代码非常复杂,那么不同的widgets和plugin就有可能在同一个对象上添加事件,如果遇到这种情况,那你就很有必要理解和使用stopImmediatePropagation。 [b]return false[/b] 只有当你同时需要preventDefault和stopPropagation,并且你的代码可以接受直到你的回调执行完成才停止执行浏览器的默认行为,那你就可以使用”return false“。但我强烈建议你别在写给其它jQuery开发者的演示代码中使用这个方法,因为这会造成更多误用,只有在你确信非用不可的情况下再去使用”return false“。 [b]选择适当的位置[/b] 如果你使用了”return false“,它只会在你的回调函数执行结束才去取消浏览器的默认行为,但是使用e.preventDefault,我们有更多的选择,它可以随时停止浏览器执行默认动作,而不管你将它放在函数的哪个部分。 [b]1. 开发阶段,[/b]你应该总是将它放在第一行。你最不想做的事情可能就是你正在调试将一个form改成ajax提交的时候,它却已经被按照老方法提交了。 [b]2. 产品阶段,[/b]如果你采用了渐进增强(progressive enhancement),那就把它放到回调的结束位置,或者是逻辑终点,如果在一个普通页面采用渐进增强,那你就需要在服务器端考虑如果浏览器不支持JS时(或者被禁用时),对链接的click事件和表单的提交事件的处理。这里的好处是,我们不考虑关闭JS的情况,只考虑支持js时的强狂,如果你的回调代码出错抛出了异常,让我们看看下面的代码:
[u]复制代码[/u] 代码如下:
var data = {};  $("a").click(function (e) {    e.preventDefault(); // cancel default behavior    // Throws an error because `my` is undefined    $("body").append(data.my.link);    // The original link doesn't work AND the "cool"    // JavaScript has broken. The user is left with NOTHING!  }); 
现在,让我们看看同样的事件,把preventDefault调用放在底部的效果:
[u]复制代码[/u] 代码如下:
>  var data = {};  $("a").click(function (e) {    // Throws an error because `my` is undefined    $("body").append(data.my.link);    // This line is never reached, and your website    // falls back to using the `href` instead of this    // "cool" broken JavaScript!    e.preventDefault(); // cancel default behavior  }); 
这对表单提交也同样有效,你可以更好的应对出错的情况,别指望你的代码一直正常工作,在发生错误时有正确的应对总胜过假设代码不会出错。 [b]3.在产品阶段,[/b]如果功能这设计JS,那就还应该放在第一行。 记住,不必非得是函数的第一行,但是越早越好,这里的原则是:如果函数的功能是通过JS实现的(不涉及服务端交互),那就没必要考虑兼容,在这种情况下,添加在第一行可以防止URL中出现#字符,但显然,你还是应该尽可能多的增加些错误处理代码,以防止用户在出错时变得不知所措。 [b]结论[/b] 我希望这篇文章传达的信息足够你在需要阻止浏览器执行默认行为时做出正确的选择。记住,只有当你真的明白你在做什么时,才使用”return false“,并确保你是在函数的正确位置调用了相应的代码。最后,尽可能保持代码的灵活性,尽量不要再用“return false”了!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部