`
Aubergine_kang
  • 浏览: 265926 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

探讨链接a,链接跳转(转载)

 
阅读更多

谈谈对A的认识
在web开发中,打交道比较多的除了按钮就是a了, 一般的交互我们基本上都是采用这2种方式进行的,这次就来认识一下a吧。
Html代码 复制代码
<a href="http://www.javaeye.com" onclick="return openwin()" target="_self">打开javaeye</a>  

<a href="http://www.javaeye.com" onclick="return openwin()" target="_self">打开javaeye</a>

a中最重要的就是这3个属性定义了:href、target、onclick。一般的跳转href和target都是配合使用的。
1、target有4个值,分别为_self(默认)、_blank、_top、_parent。
_blank是弹出新窗口显示内容,
_top和_parent是在iframe中才起作用,目的是在顶层刷新(_top),或者是在父页面刷新(_parent),注意:如果没有找到也不会报错,效果就和_blank一样了,新窗口显示内容。
其实target也是可以写其他内容的,例如:
Html代码 复制代码
<a href="http://www.sohu.com" target="main">搜狐</a>  
<a href="http://www.sohu.com" target="main">搜狐</a>
,那么,它就会去找name为main的iframe,在该iframe显示http://www.sohu.com的内容。如果没有这个main的话,就和_blank一样。
2、href
href是超链接的访问URI,这个不一定非要是http路径,其实浏览器识别href是通过协议进行的,
1) 如果没有任何协议,例如:
<a href="www.sohu.com">搜狐</a>,那么它寻找的就是当前路径下的www.sohu.com这个资源,显然我们的目录下应该不会有该资源,那么对不起,它就只能显示“无法显示网页”,url也变为file:///C:/Documents%20and%20Settings/jiwen.chenjw/Local%20Settings/Temp/www.sohu.com了。
比如我们的应用访问路径是http://localhost/work/sale/index.do,那么该页面定义的<a href="save.do">save</a>访问的就是http://localhost/work/sale/save.do,<a href="../show.do">link</a>,访问的就是http://localhost/work/show.do,<a href="/save.do">save</a>就是从根目录下开始寻找,也就是访问http://localhost/save.do了。
2) 接下来就应该要说说协议了,常用的协议有http、ftp、javascript,其他还有各种各样的自定义协议了。例如:tencent就是腾讯QQ定义的,如果安装过QQ的话,就会响应相对应的程序。
http是我们最常用的一个协议了,大部分时候我们的程序都没有指定这个协议,它就是依据当前应用程序访问的协议。例如:我们的程序访问url为http://localhost/work/index.do,那么页面上<a href="show.do">,我们去访问的时候会变为访问http://localhost/work/show.do,会继承当前页面的协议。
javascript这个协议应该是我们最常用的一个了,在处理链接的时候,大部分都是需要调用其他js函数进行处理,例如:
Html代码 复制代码
<a herf="javascript:addUser();">添加用户</a>  
<script>  
function addUser(){   
    var form1 = document.getElementById("form1");   
    form1.action="addUser.do";   
    form1.target="_blank";   
    form1.submit();   
}   
</script>  
<a herf="javascript:addUser();">添加用户</a>  <script>  function addUser(){   var form1 = document.getElementById("form1");   form1.action="addUser.do";   form1.target="_blank";   form1.submit();  }  </script>  

第二种写法就是
Html代码 复制代码
<a href="javascript:window.open('http://www.sohu.com')">添加用户</a>  
<a href="javascript:window.open('http://www.sohu.com')">添加用户</a>

还有一种写法就是
Html代码 复制代码
<a href="javascript:void(0)" onclick="addUser();">添加用户</a>  
<a href="javascript:void(0)" onclick="addUser();">添加用户</a>

这里就引入了onclick事件,上面3种方式都可以做到弹出新窗口进行添加用户操作。那么到底有什么区别呢?
(1)使用javascript:window.open()这种方式,在不同浏览器有不同的效果,ie和Firefox都可以弹出新窗口显示www.sohu.com的内容,而当前窗口的内容就显示为[object](IE6)以及[object Window](Firefox)。因为window.open是带有返回值的,而href就是获取返回值显示的。所以直接在href中使用window.open是不推荐的。
我们可以修改为第一种方式。
(2)第三种方式,我们是最常用的,但也会有问题,页面html代码如下:
Html代码 复制代码
<script>  
  function openwin(){   
    var form1 = document.getElementById("form1");   
    form1.target="_blank";   
    form1.submit();   
  }   
  </script>  
<a href="javascript:void(0)" onclick="openwin()">打开javaeye</a>  
<form action="http://www.javaeye.com" method="post" id="form1">  
</form>  
<script>    function openwin(){   var form1 = document.getElementById("form1");   form1.target="_blank";   form1.submit();    }    </script>  <a href="javascript:void(0)" onclick="openwin()">打开javaeye</a>  <form action="http://www.javaeye.com" method="post" id="form1">  </form>  

在ie6、firefox中测试没有问题,可以点击多次,而在google chrome浏览器中就只能打开一次,影响用户使用。
第一种方式也同样有这种问题。问题出在哪里呢?
不论是第一种还是第三种,其实都是执行了2次action,一次是openwin中打开新的页面,一次是执行void(0)或者是执行addUser的返回值,而void(0)和addUser的返回值都是为空,所以页面没有变化。这样就可以解释<a href="#" onclick="openwin()">打开javaeye</a>会跳到页面头部去,同时也会执行onclick的事件。
那我们有没有办法只执行一次呢,也就是只执行openwin这个函数,而不去触发href呢,第一种方式显然不行。
我们修改html代码如下:
Html代码 复制代码
<script>  
  function openwin(){   
    var form1 = document.getElementById("form1");   
    form1.target="_blank";   
    form1.submit();   
    return false;   
  }   
  </script>  
<a href="http://www.sohu.com" onclick="return openwin()">打开javaeye</a>  
<form action="http://www.javaeye.com" method="post" id="form1">  
</form>  
<script>    function openwin(){   var form1 = document.getElementById("form1");   form1.target="_blank";   form1.submit();   return false;    }    </script>  <a href="http://www.sohu.com" onclick="return openwin()">打开javaeye</a>  <form action="http://www.javaeye.com" method="post" id="form1">  </form>  

如果onclick="openwin()"那么我们会发现当前页面也同时跳转到搜狐首页去了,当我们修改为onclick="return openwin()",会发现这个页面就不会跳转。
这样就可以知道如果onclick的返回值如果为false,那么就不会触发href。
但上面的代码在chrome中只有第一次点击的时候才有效,原因呢?我们大概可以想到估计是和Ajax的处理原则一样,是不是因为form的action没有发生变化才导致的呢,那我们把代码修改为如下:
Html代码 复制代码
<script>  
  function openwin(){   
    var form1 = document.getElementById("form1");   
    form1.action="http://www.javaeye.com?date="+new Date().getTime();   
    form1.target="_blank";   
    form1.submit();   
    return false;   
  }   
  </script>  
<a href="http://www.sohu.com" onclick="return openwin()">打开javaeye</a>  
<form action="http://www.javaeye.com" method="post" id="form1">  
</form>  
<script>    function openwin(){   var form1 = document.getElementById("form1");   form1.action="http://www.javaeye.com?date="+new Date().getTime();   form1.target="_blank";   form1.submit();   return false;    }    </script>  <a href="http://www.sohu.com" onclick="return openwin()">打开javaeye</a>  <form action="http://www.javaeye.com" method="post" id="form1">  </form>  

在chrome中测试成功。
总结一下:
Html代码 复制代码
<script>  
  function openwin(){   
    var form1 = document.getElementById("form1");   
    form1.action="http://www.javaeye.com?date="+new Date().getTime();   
    form1.target="_blank";   
    form1.submit();   
    return false;   
  }   
  </script>  
<a href="http://www.sohu.com" onclick="return openwin()">打开javaeye</a>  
<form action="http://www.javaeye.com" method="post" id="form1">  
</form>  
<script>    function openwin(){   var form1 = document.getElementById("form1");   form1.action="http://www.javaeye.com?date="+new Date().getTime();   form1.target="_blank";   form1.submit();   return false;    }    </script>  <a href="http://www.sohu.com" onclick="return openwin()">打开javaeye</a>  <form action="http://www.javaeye.com" method="post" id="form1">  </form>  

页面中的代码处理如上所示,在
分享到:
评论

相关推荐

    PHP网站跳转链接页面源码 一般用在跳转到外部链接.

    这里我们将深入探讨PHP实现跳转的原理、方法以及如何编写这样的源码。 首先,理解HTTP响应状态码是关键。HTTP协议中,3xx系列的状态码用于表示重定向,比如301(永久重定向)和302(临时重定向)。在PHP中,我们...

    vue项目中跳转到外部链接的实例讲解

    但是如果我们还用这种方法跳到外部链接,就会报错,我们一看链接的路径,原来是我们的外部链接前面加上了http://localhost:8080/#/这一串导致跳转出现问题,那么我们如何跳转到外部链接呢,我们只需用 [removed]....

    探讨链接 探讨a.html

    标题中的“探讨链接 探讨a.html”暗示了我们即将讨论的是有关HTML链接(a标签)的知识。在网页开发中,HTML(超文本标记语言)是构建网页的基础,而`&lt;a&gt;`标签则是HTML中用于创建超链接的关键元素,它允许用户从一个...

    js或jq点击A链接跳转到百度并搜索关键词

    最近开发项目有这么一个需求 有一堆A链接关键词,点击后让他跳转到百度自动搜索此关键词,js写法如下,希望可以帮到各位

    易优url链接外链跳转插件.zip

    易优URL链接外链跳转插件是一款专为易优CMS(EyouCMS)设计的扩展工具,旨在帮助网站管理员更好地管理和控制网站上的外部链接。通过这个插件,你可以实现对外部URL的统一管理和定向跳转,提升用户体验,同时也有助于...

    android界面跳转传值和链接跳转

    android界面跳转传值和链接跳转android界面跳转传值和链接跳转

    抖音私信名片,抖音消息卡片,抖音跳转微信 链接跳转引流技术.zip

    抖音私信名片链接跳转"或"抖音私信消息卡片链接"或"抖音私信图文链接"是2022年抖音引流营销技术 可以在抖音APP私信环境下生成卡片链接,支持标题、描述、logo以及跳转落地页的完全自定义配置. 强大独立后台方便...

    js实现a标签跳转打开新页面

    a标签跳转打开新页面

    label中链接匹配,点击效果及跳转实现oc

    在iOS开发中,`UILabel` 是我们常用的用来展示文本的控件,但有时我们需要实现一些高级功能,如点击文本中的某个部分(比如链接)并触发特定的事件,这时`UILabel` 的原生功能就显得有些局限。为了实现这样的效果,...

    非本站链接自动跳转 站外链接跳转 SEO 防止网站权重流失

    非本站链接自动跳转 站外链接跳转 SEO 防止网站权重流失

    淘客链接跳转

    淘客链接跳转是一种网络营销策略,主要用于电商平台如淘宝的推广。淘客,即淘宝联盟的会员,通过分享商品链接来吸引消费者购买,从而赚取佣金。在这个过程中,"淘客链接转换工具"起到了关键作用。 淘客链接转换工具...

    Baidu链接 直接跳转至百度网页

    标题中的“Baidu链接 直接跳转至百度网页”表明这是一个与网页链接相关的文件,具体来说,它可能是一个HTML文件,设计成打开后会自动重定向到百度的主页。在互联网技术中,这种功能通常是通过HTML的`&lt;meta&gt;`标签或者...

    html链接打开app并跳转至某个指定界面

    html点击链接打开app并跳转至指定的界面;因为项目中有登录控制,所以需要在MainActivity中判断是否登录;如果登录状态,那么就直接跳转;如果未登录,则先保存要跳转的界面数据然后到登录界面登录成功回来会自动...

    Laravel重定向,a链接跳转,控制器跳转示例

    本篇文章将深入探讨Laravel中的重定向方法,包括通过`a`标签、表单提交、Ajax请求以及控制器方法内的跳转。 1. **`a`链接跳转**: 在HTML中,`&lt;a&gt;`标签用于创建超链接,直接指定URL即可实现页面跳转。在Laravel中,...

    TP5url短链接生成与跳转

    TP5短链接生成与跳转,短链接生成 地址:http://t.cn/setshorturl.html?sign=xxxxxxxxxxxxxxxxx post参数: urls 原链接地址 必填 title 描述信息 非必填 返回值: { "status": 0, "msg": "短链接生成成功", "data":...

    a 标签跳转

    ### a标签跳转知识点详解 #### 一、a标签简介 在HTML中,`a`标签是最基础也是最重要的标签之一,主要用于定义超链接。通过它,网页之间可以互相链接,从而构建起整个互联网世界。简单来说,`a`标签允许我们从一个...

    js导航栏A标签锚点跳转

    "js导航栏A标签锚点跳转"是JavaScript在网页交互中的常见应用,主要用于实现页面内部链接的平滑滚动效果。这个话题涉及到的知识点包括HTML锚点、JavaScript事件处理和DOM操作。 首先,HTML锚点(#标识符)允许我们...

    HTML的页面链接A标签.pdf

    &lt;A name="marker"&gt; 主题名称 &lt;/A&gt;为达到这种跳转效果,请在 href 参数中使用如下标记。&lt;A href="#marker"&gt;主题名称 &lt;/A&gt;超级链接名称前面的符号“#” 告诉浏览器当前链接是文档中的一个锚记点。由于在符号“#” 前未...

    js当前导航高亮带链接跳转效果

    在网页设计中,"js当前导航高亮带链接跳转效果"是一个常见的功能,它能够提升用户体验,使得用户更容易地了解当前所在页面的位置,并通过点击导航条目进行页面间的便捷跳转。这一功能主要依赖JavaScript(js)语言来...

    iOS和Android用同一个二维码实现跳转下载链接的方法

    最近一个项目需要iOS和安卓使用一个二维码,让扫描的机器自己识别操作系统实现跳转到相应的下载链接。比如iPhone用微信进行扫描就让他跳转appStore的下载页面,安卓机器使用微信扫描就直接跳浏览器下载。但是这...

Global site tag (gtag.js) - Google Analytics