zoukankan      html  css  js  c++  java
  • URL地址中的#符号

    一般我们想让一个a标签点击后执行javascript代码,有以下几种写法:
    方式一:<a href="#" onclick="alert(1);">点击一</a>
    这种方式的缺点就是点击后会在地址栏的URL后面加#号,同时把页面移动到顶部,如下图所示:


    方式二:<a href="javascript:void(0);" onclick="alert(1);">点击一</a>
    这种方式避免了方式一的缺点,点击后对页面没有任何影响。但是有一个致命的缺点,就是在IE6下不能执行form对象的submit()方法,也不能执行跳转语句,比如
    <a href="javascript:void(0);" onclick="document.forms[0].submit();">点击一</a>
    <a href="javascript:void(0);"  onclick="window.location.href='http://www.google.com';">点击一</a>
    在IE6下就无效,换成href=”#”就能在IE6下正常执行。

    方式三:<a href="###" onclick="alert(1);">点击一</a>
    点击后虽然会在地址栏的URL后面加三个#号,但是不会影响滚动条,同时在IE6下也能执行form对象的submit()方法与跳转语句,算是一个比较折中的方法。

    方式四:<a href="javascript:alert(1);">点击一</a>
    点击后不会影响滚动条,也不会在地址栏的URL后面加三个#号,同时在IE6下也能执行form对象的submit()方法与跳转语句;但是这样写最大的缺点是,JS方法都在

    鼠标点击事件之中,写法不灵活,无法使用其它事件,限制了使用范围,也不方便动态对标签绑定事件。

    结论:我个人认为如果执行的javascript方法中需要提交表单、跳转页面,则用方式三,其它情况都用方式二。

    :这又附带引出另一个问题,一般重新加载当前页面用如下的javascript代码:
    window.location.href = window.location.href;
    但是当URL地址中含有#时,上述代码无效,于是需要用如下代码:
    window.location.href = window.location.href.split('#')[0];
    将URL地址以#符号分割开,取第一部分即可。

    我的网站:http://i.goto327.top:85/
  • 相关阅读:
    纯CSS3实现不错的表单验证效果
    CANVAS模仿龙卷风特效
    HTML+CSS画一朵向日葵
    canvas水波纹效果
    樱花的季节,教大家用canvas画出飞舞的樱花树
    网站SEO,HTTP请求的关键数字----6
    css3绘制腾讯logo
    关于js的parseInt方式在不同浏览器下的表现
    封装keyframes插件
    模仿jquery的fileupload插件
  • 原文地址:https://www.cnblogs.com/jintianhu/p/1952577.html
Copyright © 2011-2022 走看看