首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将href值递增1 (Javascript)

将href值递增1 (Javascript)
EN

Stack Overflow用户
提问于 2012-04-13 17:30:04
回答 5查看 606关注 0票数 0

我有一份有序的清单

代码语言:javascript
复制
<li id="prev">
    <a href="#fragment-1>Next</a>
</li>

我希望将href值递增到

代码语言:javascript
复制
<a href="#fragment-1">...
<a href="#fragment-2">...
<a href="#fragment-3">...
<a href="#fragment-4">...

当点击下一个时,它应该从4开始停止并返回到1,所以用javascript可以吗?

谢谢

EN

回答 5

Stack Overflow用户

发布于 2012-04-13 17:33:55

首先给你的链接一个id,让它更容易选择。

然后,

代码语言:javascript
复制
document.getElementById('the_id_here').addEventListener('click', function(e) {
    var n = e.target.href.split('-')[1] * 1 + 1;
    if (n > 4)
        n = 1;
    e.target.href = e.target.href.split('-')[0] + '-' + n;
}, false);

示例:http://jsbin.com/ajegaf/4#fragment-1

票数 3
EN

Stack Overflow用户

发布于 2012-04-13 17:40:49

不完全是你想要的,但应该足够近,让你指向正确的方向,检查http://jsfiddle.net/pj28v/

代码语言:javascript
复制
<ul id="list"></ul>
<a href="#" id="next">Next</a>​

$(function() {

    var $list = $('#list'),
        count = 4,
        i = 0,
        cur = 0;

    for (; i < count; i++) {
        $list.append('<li><a href="#fragment' + i + '">frag' + i + '</a></li>');
    }

    $('a', $list).eq(0).css('color','red');

    $('#next').click(function(ev) {
        ev.preventDefault();
        cur++;
        if (cur >= count) cur = 0;
        $('a', $list).css('color','blue').eq(cur).css('color','red');
    });
});​
票数 0
EN

Stack Overflow用户

发布于 2012-04-13 17:41:46

jQuery解决方案:

代码语言:javascript
复制
$(document).ready(function(){

    $('#prev a').click(function(){

        var href = $(this).attr('href');
        var num = parseInt(href.substr(href.indexOf('-') + 1));

        if(num == 4)
        {
            num = 1;
        }
        else
        {
            num++;
        }

        $(this).attr('href', '#fragment-' + num)
    });

});​

http://jsfiddle.net/UYDdB/

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10138387

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档