Sho*_*og9 1786
运用
$("a").attr("href", "http://www.google.com/")
Run Code Online (Sandbox Code Playgroud)
将修改所有超链接的href以指向Google.你可能想要一个更精致的选择器.例如,如果您混合使用链接源(超链接)和链接目标(也称为"锚点")锚标记:
<a name="MyLinks"></a>
<a href="http://www.codeproject.com/">The CodeProject</a>
Run Code Online (Sandbox Code Playgroud)
...那么你可能不想意外地href
为它们添加属性.为了安全起见,我们可以指定我们的选择器只匹配<a>
带有现有href
属性的标签:
$("a[href]") //...
Run Code Online (Sandbox Code Playgroud)
当然,你可能会想到一些更有趣的东西.如果要将锚点与特定的现有锚点匹配href
,可以使用以下内容:
$("a[href='http://www.google.com/']").attr('href', 'http://www.live.com/')
Run Code Online (Sandbox Code Playgroud)
这将找到href
与字符串完全匹配的链接http://www.google.com/
.更复杂的任务可能是匹配,然后只更新部分href
:
$("a[href^='http://stackoverflow.com']")
.each(function()
{
this.href = this.href.replace(/^http:\/\/beta\.stackoverflow\.com/,
"http://stackoverflow.com");
});
Run Code Online (Sandbox Code Playgroud)
第一部分选择其中的href只链接开始使用http://stackoverflow.com
.然后,定义一个函数,该函数使用简单的正则表达式将URL的这一部分替换为新部分.请注意这为您提供的灵活性 - 可以在此处对链接进行任何类型的修改.
小智 277
使用jQuery 1.6及更高版本,您应该使用:
$("a").prop("href", "http://www.jakcms.com")
Run Code Online (Sandbox Code Playgroud)
之间的区别prop
和attr
是attr
抓住HTML属性,而prop
抓住DOM属性.
你可以在这篇文章中找到更多细节:.prop()vs .attr()
Pet*_*ers 77
attr
在查找中使用该方法.您可以使用新值切换任何属性.
$("a.mylink").attr("href", "http://cupcream.com");
Run Code Online (Sandbox Code Playgroud)
fla*_*gos 39
根据您是否要将所有相同的链接更改为其他内容,或者您希望仅控制页面的给定部分或每个部分中的链接,您可以执行其中一个.
更改所有指向Google的链接,以便他们指向Google地图:
<a href="http://www.google.com">
$("a[href='http://www.google.com/']").attr('href',
'http://maps.google.com/');
Run Code Online (Sandbox Code Playgroud)
要更改给定部分中的链接,请将容器div的类添加到选择器.此示例将更改内容中的Google链接,但不会更改页脚中的Google链接:
<div class="content">
<p>...link to <a href="http://www.google.com/">Google</a>
in the content...</p>
</div>
<div class="footer">
Links: <a href="http://www.google.com/">Google</a>
</div>
$(".content a[href='http://www.google.com/']").attr('href',
'http://maps.google.com/');
Run Code Online (Sandbox Code Playgroud)
要更改单个链接而不管它们落在文档中的哪个位置,请在链接中添加一个ID,然后将该ID添加到选择器.此示例将更改内容中的第二个Google链接,但不会更改第一个或页脚中的链接:
<div class="content">
<p>...link to <a href="http://www.google.com/">Google</a>
in the content...</p>
<p>...second link to <a href="http://www.google.com/"
id="changeme">Google</a>
in the content...</p>
</div>
<div class="footer">
Links: <a href="http://www.google.com/">Google</a>
</div>
$("a#changeme").attr('href',
'http://maps.google.com/');
Run Code Online (Sandbox Code Playgroud)
Jos*_*ier 35
尽管OP明确要求获得jQuery答案,但这些天你不需要使用jQuery.
如果要更改所有元素的href
值,请选择所有 <a>
元素,然后遍历节点列表 :( 示例)
var anchors = document.querySelectorAll('a');
Array.prototype.forEach.call(anchors, function (element, index) {
element.href = "http://stackoverflow.com";
});
Run Code Online (Sandbox Code Playgroud)如果要更改实际具有属性href
的所有<a>
元素的值,请href
通过添加[href]
属性selector(a[href]
)来选择它们:( 示例)
var anchors = document.querySelectorAll('a[href]');
Array.prototype.forEach.call(anchors, function (element, index) {
element.href = "http://stackoverflow.com";
});
Run Code Online (Sandbox Code Playgroud)例如,如果要更改包含特定href
值的<a>
元素的值,请使用属性选择器:( 示例)google.com
a[href*="google.com"]
var anchors = document.querySelectorAll('a[href*="google.com"]');
Array.prototype.forEach.call(anchors, function (element, index) {
element.href = "http://stackoverflow.com";
});
Run Code Online (Sandbox Code Playgroud)
同样,您也可以使用其他属性选择器.例如:
a[href$=".png"]
可用于选择值<a>
以其href
结尾的元素.png
.
a[href^="https://"]
可用于选择<a>
的元素href
被值前缀与https://
.
如果要更改满足多个条件href
的<a>
元素的值:( 示例)
var anchors = document.querySelectorAll('a[href^="https://"], a[href$=".png"]');
Array.prototype.forEach.call(anchors, function (element, index) {
element.href = "http://stackoverflow.com";
});
Run Code Online (Sandbox Code Playgroud)..在大多数情况下,不需要正则表达式.
小智 18
尝试这个;
$("#link").attr("href", "https://coenvink.com/")
Run Code Online (Sandbox Code Playgroud)
代码作用的细分:
$("#link")
Run Code Online (Sandbox Code Playgroud)
这部分代码获取 id 为“Link”的元素。之后,您将属性“href”(女巫基本上是链接到网址)设置为您的新网址,在本例中,女巫是我自己的网站:
.attr("href", "https://coenvink.com/")
Run Code Online (Sandbox Code Playgroud)
我希望现在一切都清楚了!
单击"menu_link"类的链接时会调用此代码段,并显示链接的文本和网址.返回false会阻止链接被跟踪.
<a rel='1' class="menu_link" href="option1.html">Option 1</a>
<a rel='2' class="menu_link" href="option2.html">Option 2</a>
$('.menu_link').live('click', function() {
var thelink = $(this);
alert ( thelink.html() );
alert ( thelink.attr('href') );
alert ( thelink.attr('rel') );
return false;
});
Run Code Online (Sandbox Code Playgroud)
$("a[href^='http://stackoverflow.com']")
.each(function()
{
this.href = this.href.replace(/^http:\/\/beta\.stackoverflow\.com/,
"http://stackoverflow.com");
});
Run Code Online (Sandbox Code Playgroud)
停止使用jQuery只是为了它!仅使用JavaScript非常简单.
document.querySelector('#the-link').setAttribute('href', 'http://google.com');
Run Code Online (Sandbox Code Playgroud)
https://jsfiddle.net/bo77f8mg/1/
这样做的简单方法是:
Attr函数(自jQuery 1.0版开始)
$("a").attr("href", "https://stackoverflow.com/")
Run Code Online (Sandbox Code Playgroud)
要么
Prop函数(自jQuery 1.6版开始)
$("a").prop("href", "https://stackoverflow.com/")
Run Code Online (Sandbox Code Playgroud)
同样,上述方式的优点在于,如果选择器选择单个锚,则仅更新该锚,并且如果选择器返回一组锚,则仅通过一条语句更新特定组。
现在,有很多方法可以识别确切的锚点或一组锚点:
很简单的一个:
$("a")
$("a:eq(0)")
active
):$("a.active")
profileLink
ID):$("a#proileLink")
$("a:first")
更有用的:
$("[href]")
$("a[href='www.stackoverflow.com']")
$("a[href!='www.stackoverflow.com']")
$("a[href*='www.stackoverflow.com']")
$("a[href^='www.stackoverflow.com']")
$("a[href$='www.stackoverflow.com']")
现在,如果要修改特定的URL,可以执行以下操作:
例如,如果您要为转到google.com的所有URL添加代理网站,则可以按以下方式实现它:
$("a[href^='http://www.google.com']")
.each(function()
{
this.href = this.href.replace(/http:\/\/www.google.com\//gi, function (x) {
return "http://proxywebsite.com/?query="+encodeURIComponent(x);
});
});
Run Code Online (Sandbox Code Playgroud)
href
在一个属性中,因此您可以使用纯 JavaScript 更改它,但是如果您已经在页面中注入了 jQuery,请不要担心,我会以两种方式展示它:
想象一下你有这个href
:
<a id="ali" alt="Ali" href="http://dezfoolian.com.au">Alireza Dezfoolian</a>
Run Code Online (Sandbox Code Playgroud)
你喜欢改变它的链接...
使用没有任何库的纯 JavaScript,您可以执行以下操作:
document.getElementById("ali").setAttribute("href", "https://stackoverflow.com");
Run Code Online (Sandbox Code Playgroud)
但也可以在jQuery中执行以下操作:
$("#ali").attr("href", "https://stackoverflow.com");
Run Code Online (Sandbox Code Playgroud)
或者
$("#ali").prop("href", "https://stackoverflow.com");
Run Code Online (Sandbox Code Playgroud)
在这种情况下,如果您已经注入了 jQuery,那么 jQuery one 可能看起来更短、更跨浏览器……但除此之外,我选择了那个JS
……
归档时间: |
|
查看次数: |
1376327 次 |
最近记录: |