BEGIN;

最近在做html页面时,有时候会遇到以前没遇到的各种奇葩问题。

目前要记载的,就是其中之一。

我们在写链接的时候,即A标签,最普通的写法无非是

<a href='http://www.baidu.com'>百度</a>

(都说百度主页50%是用来测网速的,现在又多了一个用来举例的。。。)。

那么,我们也有很多时候是需要做操作的,如验证文本框内容,成功后再ajax提交,

那么,这个时候我们的html代码有可能会写成这样的:

<a href='#' onclick='test()'>百度</a>

或者干脆直接不写 href,即:

<a onclick='test()'>百度</a>

当我们在测试test()方法的时候,会发现,一切正常,可以alert,可以文本框值神马的,依然可以提交到指定的后台方法,表面上看没有任何问题。

但是可能会出现如下情况:

1、如果你的网页超过了你的电脑分辨率高度,即你滚动了滚动条,然后在中间去点击,因为你的是ajax提交,

你要展示的地方,数据依然刷新,但是,你的网页会重新回到页面的最上方,这个时候,我们可以看到,

浏览器的url地址上的最后面,会多出一个#号!

2、假设JS中有个全局变量获取请求test方法的参数,并提交,样例代码如下:

 var gotoPage = 1;<span style="white-space:pre">	</span>// 需要跳转的页数,默认为1
function mysubmit(gotoPageNo) {
<span style="white-space:pre"> </span>gotoPage = gotoPageNo;
<span style="white-space:pre">	</span>// 验证是否获取到了3
<span style="white-space:pre">	</span>alert(gotoPage);
<span style="white-space:pre"> </span>// 提交
<span style="white-space:pre"> </span>$('#div').load = 'xxx.do?gotoPage=' + <span style="font-family: 'Microsoft YaHei';">gotoPage;</span>
} <a href='#' onclick='mysubmit(3)'>提交</a>

从表面上面,gotoPage获取到传递过来的值,然后进行提交,按道理是gotoPage的确是3。

按照上面代码,做了一个alert,没错,弹出来的gotoPage也的确是3。但是我们再xxx.do的方法里面,拿到的却是1!

问题就出在于,页面刷新了。但是具体是怎么个过程,当时解决问题时没有细研究,

但是的确弹出来的是3,而xxx.do拿到的是1。

解决办法:

当我们再用到A标签的时候,尽可能的不要出现<a href='#' οnclick='test()'>这样的情况,

一般,都要写成<a href='javascript:;' οnclick='test()'>或者<a href='javascript:void(0);' οnclick='test()'>。

就算!你那个A标签没有链接地址,我的建议是,还是不能写成href='#',

因为很有可能会因为不知道为什么页面老是跳到网页的最上面而浪费时间去找原因。

OK,结束。

END;

--- --- --- ---> 点击查看更多最新原创博文<--- --- --- ---

技术交流

A标签上使用onclick事件,js函数响应成功,单会刷新当前页面陷阱的更多相关文章

  1. 在js中拼接<a>标签,<a>标签中含有onclick事件,点击无法触发该事件

    我们在<a>标签中添加事件一般是onclick="editUser()" 这样添加,在html页面上是行的通的 但是如何你是在js中拼接<a>标签并在< ...

  2. JQuery模拟点击页面上的所有a标签,触发onclick事件

    注意: 这种方法需要给所有的a标签加上id属性 页面加载完成模拟点击所有的a标签: <script> $(function () { // 模拟点击页面上的所有a标签,触发onclick事 ...

  3. HTML中在a标签中添加onclick事件

    1.链接的onclick 事件被先执行,其次是href属性下的动作; 2.假设链接中同时存在href 与onclick,如果想让href 属性下的动作不执行,onclick 必须得到一个false的返 ...

  4. a 标签中加 onclick事件,根据事件中的校验情况来决定是否执行a标签的链接

    a 标签中加 onclick方法后,先执行onclick方法,在去执行a标签href下属性对应的动作,如果不想执行href属性下动作需要用false作为返回值. <a href="ht ...

  5. js函数、表单验证

    惊天bug!!!在script里面只要有一点点错误,就都不执行了!!!所以每写一个方法,就跑一下,因为这个书写疏忽导致的bug不可估量!!! [笑哭,所以我才这么讨厌js么,后来真心的是一点都不想再看 ...

  6. js修改url参数,无刷新更换页面url

    一.js修改地址栏URL参数 function changeURLPar(destiny, par, par_value) { var pattern = par + '=([^&]*)'; ...

  7. vue项目进行时,script标签中,methods事件中函数使用的async/await

    用 async/await 来处理异步 await关键字只能放到async函数里面,通过await得到就是Promise返回的内容:当然也能通过then()去获取,若通过then()获取了则就无Pro ...

  8. 标签中的onclick调用js方法传递多个参数的解决方案

    1.JS方法 <script type="text/javascript"> funcation cc(parameter1,parameter2,parameter3 ...

  9. 在HTML标签元素中,绑定JS函数

    <a onclick="ShowMsg(this)" id="myA" href="#">按钮</a> //JS方法 ...

随机推荐

  1. 修道士与野人问题(BFS广度搜索)

    #include "iostream.h" #include "string.h" //定义一个状态节点 typedef struct //存储各个状态 { i ...

  2. Mac 常用

    Mac下如何复制文件路径 / 文件夹路径 Rudon滨海渔村 2020-08-06 20:35:33 587 收藏分类专栏: Mac OS X 命令行 文章标签: Mac Finder版权步骤在Fin ...

  3. SpringCloud和Dubbo?

    SpringCloud和Dubbo都是现在主流的微服务架构SpringCloud是Apache旗下的Spring体系下的微服务解决方案Dubbo是阿里系的分布式服务治理框架从技术维度上,其实Sprin ...

  4. 面试问题之C++语言:类模板声明与定义为何不能分开

    C++中每个对象所占用的空间大小,是在编译的时候就确定的,在模板类没有真正的被使用之前,编译器是无法知道,模板类中使用模板类型的对象的所占用的空间的大小的.只有模板被真正使用的时候,编译器才知道,模板 ...

  5. Error和Exception有什么区别?

    Error表示系统级的错误和程序不必处理的异常,是恢复不是不可能但很困难的情况下的一种严重问题:比如内存溢出,不可能指望程序能处理这样的情况:Exception表示需要捕捉或者需要程序进行处理的异常, ...

  6. Python - 异常处理初步

  7. String工具类之“四个判空方式”StringUtils.isNotBlank和StringUtils.isEmpty和StringUtils.isBlank和StringUtils.isNotEmpty

    一.判断str字符串都不为空==>StringUtils.isNotBlank(String str); 1 /** 2 * <p>检查一个字符串是否非空("") ...

  8. 如何解决Visual Studio 2017 运行后控制台窗口一闪就消失了

    出现这种情况的原因 安装使用Visual Studio 2017 后,用Ctrl+F5运行程序,结果控制台窗口一闪就没了,也没有出现"press any key to continue-&q ...

  9. Vue中获取元素宽高

    <div ref="init"></div> 写在 页面 方法 部分 这里的 offsetHeight 是返回元素的宽度(包括元素宽度.内边距和边框,不包括 ...

  10. Mac 安装WordPress

    Mac 安装WordPress 一.环境要求 PHP 5.2.4或更新版本 MySQL 5.0或更新版本 WebServer(可以选择Apache.nginx等支持PHP的,这里我选择Apache) ...