聊聊return false

最近在做一些关于视频切换的时候。由于是用a标签做的会有默认的跳转。这时候我就想到了,return flase。阻止默认行为,也达到了预期的效果。后来就详细查了查。让我们来看看

“return false”之所以被误用的如此厉害,是因为它看起来像是完成了我们交给它的工作,浏览器不会再将我们重定向到href中的链接,表单也不会被继续提交,但这么做到底有什么不对呢

可能在你刚开始学习关于jQuery事件处理时,看到的第一个例子就是关于如何阻止浏览器执行默认行为,比如下面这段演示click事件的代码:

  1. <span style="font-size:14px;">$("a.toggle").click(function () {
  2. $("#mydiv").toggle();
  3. return false; // Prevent browser from visiting `#`
  4. }); </span>

这个函数使用toggle来显示或者隐藏#mydiv,然后阻止浏览器继续访问href中指定的链接。

像上面这样的例子会让用户养成使用“return false”来阻止浏览器执行默认行为的坏习惯,在这篇文章里,我将会讨论关于阻止浏览器执行默认行为的两个非常重要的主题:

?选择正确的方法: return false还是preventDefault,stopPropagation或者stopImmediatePropagation
?选择合适的位置,开始,结束,还是中间某个地方:你应该在事件回调的哪个部分取消浏览器执行默认行为?

注意:当我在这篇文章中提到event bubbling(事件冒泡),我想表达的是大部分事件都是先在初始DOM上触发,然后再通过DOM树往上,在每一级父元素上触发,事件不会在兄弟节点或是子节点上冒泡(当事件向下冒泡时,我们叫它事件捕捉(event capturing)),你可以在这里了解更多关于事件起泡和捕捉的介绍。

选择正确的方法

“return false”之所以被误用的如此厉害,是因为它看起来像是完成了我们交给它的工作,浏览器不会再将我们重定向到href中的链接,表单也不会被继续提交,但这么做到底有什么不对呢?

”return false“到底做了什么?

当你每次调用”return false“的时候,它实际上做了3件事情:

?event.preventDefault();
?event.stopPropagation();
?停止回调函数执行并立即返回。
“等等”,你叫了起来!我只是想让浏览器停止继续执行默认行为而已,我不需要它去做另外2件事。

这3件事中用来阻止浏览器继续执行默认行为的只有preventDefault,除非你想要停止事件冒泡,否则使用return false会为你的代码埋下很大的隐患,让我们通过一个真实的例子来看看这样的误用会造成什么后果:

这是我们用来演示的HTML:

 

  1. <div class="post">
  2. <h2><a href="http://jb51.net">My Page</a></h2>
  3. <div class="content">
  4. Teaser text...
  5. </div>
  6. </div>
  7. <div class="post">
  8. <h2><a href="http://jb51.net">My Other Page</a></h2>
  9. <div class="content">
  10. Teaser text...
  11. </div>
  12. </div>

现在假设我们想要在用户点击文章标题时,将文章动态载入到div.contentd中:

  1. <pre name="code" class="javascript">jQuery(document).ready(function ($) {
  2. $("div.post h2 a").click(function () {
  3. var a    = $(this),
  4. href = a.attr(‘href‘), // Let jQuery normalize `href`,
  5. content  = a.parent().next();
  6. content.load(href + " #content");
  7. return false; // "cancel" the default behavior of following the link
  8. });
  9. });

这段代码可以正常工作(至少目前是),但如果我们顺着这个思路继续,如果我想要在用户点击了一个div.post元素(或者任何一个它的子元素)时,给它加上一个active类,我就需要给div.post增加了一个click回调:

  1. // Inside Document Ready:
  2. var posts = $("div.post");
  3. posts.click(function () {
  4. // Remove active from all div.post
  5. posts.removeClass("active");
  6. // Add it back to this one
  7. $(this).addClass("active");
  8. });

现在,如果我们点击一个帖子的标题,这段代码会工作吗?答案是不会,因为我们在标题的click回调里使用了return false而不是我们应该使用的,”return false“等于event.preventDefault();加event.stopPropagation();,所以事件冒泡就被终止了,click事件不会被冒泡到div.post上,我们为它添加的事件回调当然也就不会被调用了。如果我们把它和live或者delegate事件混在一起使用时,情况就更糟了。

  1. $("a").click(function () {
  2. // do something
  3. return false;
  4. });
  5. $("a").live("click", function () {
  6. // THIS WON‘T FIRE
  7. });

那么我们真正需要的是什么呢?

preventDefault()

大多数情况下,当你使用return false时,你其实真正需要的是e.preventDefault()。要使用e.preventDefault,你需要确保你传递了event参数到你的回掉函数中(在这个例子里,就是那个e):

  1. $("a").click(function (e) {
  2. // e == our event data
  3. e.preventDefault();
  4. });

它会替我们完成所有工作,但不会阻止父节点继续处理事件,要记住,你放在代码中的限制越少,你的代码就越灵活,也就越易于维护。

stopPropagation()

但有些情况下,你有可能需要停止事件冒泡,让我们看看下面的例子:

 

  1. <div class="post">
  2. Normal text and then a <a href="http://jb51.net">link</a> and then more text.
  3. </div>

现在,让我们假设如果你点了div上除了a链接之外的地方,我们希望能发生点什么事情(比如改变下背景什么的),但是不能影响用户点击a链接的行为(从可用性的角度,这个例子不怎么好,你可能不希望用户点击别的地方时发生任何事情)。

 

  1. $("div.post").click(function () {
  2. // Do the first thing;
  3. });
  4. $("div.post a").click(function (e) {
  5. // Don‘t cancel the browser‘s default action
  6. // and don‘t bubble this event!
  7. e.stopPropagation();
  8. });

在这种情况下,如果我们使用return false,div的click事件不会被触发,但是用户也不会到达他们点的那个链接。

stopImmediatePropagation()

这个方法会停止一个事件继续执行,即使当前的对象上还绑定了其它处理函数,所有绑定在一个对象上的事件会按绑定顺序执行,看看下面的例子:

 

  1. $("div a").click(function () {
  2. // Do something
  3. });
  4. $("div a").click(function (e) {
  5. // Do something else
  6. e.stopImmediatePropagation();
  7. });
  8. $("div a").click(function () {
  9. // THIS NEVER FIRES
  10. });
  11. $("div").click(function () {
  12. // THIS NEVER FIRES
  13. });

你可能会觉得这个例子看起来很别扭,没错,尽管如此,但有时这的确会发生,如果你的代码非常复杂,那么不同的widgets和plugin就有可能在同一个对象上添加事件,如果遇到这种情况,那你就很有必要理解和使用stopImmediatePropagation。

return false

只有当你同时需要preventDefault和stopPropagation,并且你的代码可以接受直到你的回调执行完成才停止执行浏览器的默认行为,那你就可以使用”return false“。但我强烈建议你别在写给其它jQuery开发者的演示代码中使用这个方法,因为这会造成更多误用,只有在你确信非用不可的情况下再去使用”return false“。

选择适当的位置

如果你使用了”return false“,它只会在你的回调函数执行结束才去取消浏览器的默认行为,但是使用e.preventDefault,我们有更多的选择,它可以随时停止浏览器执行默认动作,而不管你将它放在函数的哪个部分。

1. 开发阶段,你应该总是将它放在第一行。你最不想做的事情可能就是你正在调试将一个form改成ajax提交的时候,它却已经被按照老方法提交了。

2. 产品阶段,如果你采用了渐进增强(progressive enhancement),那就把它放到回调的结束位置,或者是逻辑终点,如果在一个普通页面采用渐进增强,那你就需要在服务器端考虑如果浏览器不支持JS时(或者被禁用时),对链接的click事件和表单的提交事件的处理。这里的好处是,我们不考虑关闭JS的情况,只考虑支持js时的强狂,如果你的回调代码出错抛出了异常,让我们看看下面的代码:

 

  1. var data = {};
  2. $("a").click(function (e) {
  3. e.preventDefault(); // cancel default behavior
  4. // Throws an error because `my` is undefined
  5. $("body").append(data.my.link);
  6. // The original link doesn‘t work AND the "cool"
  7. // JavaScript has broken. The user is left with NOTHING!
  8. });

现在,让我们看看同样的事件,把preventDefault调用放在底部的效果:

 

  1. >
  2. var data = {};
  3. $("a").click(function (e) {
  4. // Throws an error because `my` is undefined
  5. $("body").append(data.my.link);
  6. // This line is never reached, and your website
  7. // falls back to using the `href` instead of this
  8. // "cool" broken JavaScript!
  9. e.preventDefault(); // cancel default behavior
  10. });

这对表单提交也同样有效,你可以更好的应对出错的情况,别指望你的代码一直正常工作,在发生错误时有正确的应对总胜过假设代码不会出错。

3.在产品阶段,如果功能这设计JS,那就还应该放在第一行。

记住,不必非得是函数的第一行,但是越早越好,这里的原则是:如果函数的功能是通过JS实现的(不涉及服务端交互),那就没必要考虑兼容,在这种情况下,添加在第一行可以防止URL中出现#字符,但显然,你还是应该尽可能多的增加些错误处理代码,以防止用户在出错时变得不知所措。

结论

我希望这篇文章传达的信息足够你在需要阻止浏览器执行默认行为时做出正确的选择。记住,只有当你真的明白你在做什么时,才使用”return false“,并确保你是在函数的正确位置调用了相应的代码。最后,尽可能保持代码的灵活性,尽量不要再用“return false”了!

时间: 2024-11-07 02:56:57

聊聊return false的相关文章

js中return;、return true、return false;区别

一.返回控制与函数结果, 语法为:return 表达式; 语句结束函数执行,返回调用函数,而且把表达式的值作为函数的结果  二.返回控制, 无函数结果,语法为:return;  在大多数情况下,为事件处理函数返回false,可以防止默认的事件行为.例如,默认情况下点击一个<a>元素,页面会跳转到该元素href属性指定的页.    Return False 就相当于终止符,Return True 就相当于执行符.    在js中return false的作用一般是用来取消默认动作的.比如你单击一

return、return false区别

return false来阻止提交表单或者继续执行下面的代码,通俗的来说就是阻止执行默认的行为. return false 只在当前函数有效,不会影响其他外部函数的执行. return  语句结束函数执行,返回调用函数,而且把表达式的值作为函数的结果. retrun true 返回正确的处理结果. 总结: retrun true: 返回正确的处理结果. return false:分会错误的处理结果,终止处理. return:把控制权返回给页面.

js 阻止事件冒泡和默认行为 preventDefault、stopPropagation、return false

preventDefault: preventDefault它是事件对象(Event)的一个方法,作用是取消一个目标元素的默认行为.既然是说默认行为,当然是元素必须有默认行为才能被取消,如果元素本身就没有默认行为,调用当然就无效了.什么元素有默认行为呢?如链接<a>,提交按钮<input type=”submit”>等.当Event对象的cancelable为false时,表示没有默认行为,这时即使有默认行为,调用 preventDefault也是不会起作用的. 我们都知道,链接&

js中return、return true、return false的区别

js中return.return true.return false;区别 一.返回控制与函数结果, 语法为:return 表达式; 语句结束函数执行,返回调用函数,而且把表达式的值作为函数的结果  二.返回控制, 无函数结果,语法为:return;  在大多数情况下,为事件处理函数返回false,可以防止默认的事件行为.例如,默认情况下点击一个<a>元素,页面会跳转到该元素href属性指定的页.    Return False 就相当于终止符,Return True 就相当于执行符.    

jQuery中return false,e.preventDefault(),e.stopPropagation()的区别

e.stopPropagation()阻止事件冒泡 <head> <title></title> <script src="http://cordial99.blog.163.com/blog/Scripts/jquery-1.4.1.js" type="text/javascript"></script> </head> <body> <table> <tr>

js中return,return true,return false的用法及区别

1.语法及返回方式 ①返回控制与函数结果         语法为:return 表达式;         语句结果函数的执行,返回调用函数,而且把表达式的值作为函数结果返回出去 ②返回控制无函数结果         语法为:return;         在大多数情况下,为事件处理函数如果让其返回false,可以防止默认的事件行为.例如,默认情况下,点击一个<a>标签元素,页面会跳转到该元素href属性指定的页. 而return false就相当于终止符,return true就相当于执行符.

stopPropagation, preventDefault 和 return false 的区别

因为有父, 子节点同在, 因为有监听事件和浏览器默认动作之分. 使用 JavaScript 时为了达到预期效果经常需要阻止事件和动作执行. 一般我们会用到三种方法, 分别是 stopPropagation(), preventDefault() 和 return false. 它们之间有什么区别, 该何时使用呢? 将在本文中进行讲解. 术语 监听事件, 在在节点上能被监听的页面操作. 如: select 节点的 change 事件, a 节点的 click 事件.浏览器默认动作, 指特定页面元素

javascript:return false有什么用

Return False 就相当于终止符,Return True 就相当于厉行符: 登陆界面:利用javascript 中的函数对内容进行验证,如果验证成功则进行跳转,验证不成功,不反应. 问题:基本功能,是页面的跳转: <form name="form1" method="post" action="register.jsp" <input type="submit" name="Submit"

JS事件处理函数中return false到底是什么东西

在<JS DOM编程艺术>一书中,用return false来阻止事件默认行为,可是js高程3里没有这种用法,那这到底是什么呢. 先看一下知乎的一个解释 就此问题,首先要纠正两个观点: 1. 事件处理方法中 的 return false 并不是终止事件,而是阻止事件宿主的默认行为: 2. 不是在所有的事件处理方法中 return fasle 都能阻止事件宿主的默认行为: 事实上,仅仅是在HTML事件属性 和 DOM0级事件处理方法中 才能通过返回 return false 的形式组织事件宿主的