是这样的,网页上有4个链接,名称分别为1,2,3,4其中1,2,3链接指向#(即空)但是有onclick触发js事件,4链接指向test.php现在要用js来做到如下效果,点击1,使4这个链接的地址改成test.php?link=1,点击2,使4这个链接的地址改成test.php?link=2,但是先点1,再点2,链接就要改成test.php?link=1,2   
要是只点击3的话,4的地址就变成test.php?mode=1,要是先点1,再点2,再点3的话,地址就会变成test.php?link=1,2&mode=1不会写,急求点播,希望能多给点注释

解决方案 »

  1.   

    <Script Language="javascript">
    var Type="";
    var ID="";
    function Sel(m) {
    Type=Type+m;

    if(Type=='1')
       {ID="link=1";}
    else if(Type=='2')
       {ID="link=2";}
    else if(Type=='12')
       {ID="link=1,2";}
    else if(Type=='3')
       {ID="mode=1";}
    else if(Type=='123')
       {ID="link=1,2&mode=1";}
    var hh="test.php?"+ID;
    //把4的地址就变成hh就行了
    }
    </Script>1,2,3链接得onclick事件都调用Sel(m)方法分别是:Sel(1),Sel(2),Sel(3)
      

  2.   

    哈哈,楼主很逗,不晓得为啥实现这样的业务操作,不觉得很烦人嘛,那要是点了1,再点3,再点2再点1,我点点点,点N多次又是啥样子的呢,哈哈我姑且相信只有一次的说法吧,我也简单写下吧:其实你这个将所有的跳转放到JS中去完成就很好解决了,非要用href去连接也行,我就尝试下吧:
    <html>
    <body>
        <a href="javascript:addUrl('key1')">连接1,哈哈,你点击这里你的URL就变长了点点,试试看</a><br/>
    <a href="javascript:addUrl('key2')">连接2,哈哈,你点击这里你的URL又会变长了点点,不信你就试试看</a><br/>
    <a href="javascript:addUrl('key3')">连接3,哈哈,你点击这里你的URL会变更长了,不信我就自杀</a><br/>
    <a href="test.php" id="link4" target="_blank">连接4(就是你要来回变那个玩意)</a>
    </body> <script language="javascript">
    function tempObj(pori,keyinfo) {
    this.pori = pori; //前缀表达式
    this.keyinfo = keyinfo;//值信息存储
    this.isUsed = "0";//该对象是否已经使用,若使用变成1,初始化为0
    this.getPori = function() {
    return this.pori;
    }
    this.getKeyinfo = function() {
    return this.keyinfo;
    }
    this.getIsUsed = function() {
    return this.isUsed;
    }
    this.setIsUsed = function(isUsed) {
    this.isUsed = isUsed;
    }
    } var addInfo = {
    "key1":new tempObj("link=","1"),
    "key2":new tempObj("link=","2"),
    "key3":new tempObj("mode=","3")
    };
    var nowInfo = {"beginUrl":"test.php"};
    var nowSize = 1;

    function addUrl(key) {
    var obj = addInfo[key];
    if(obj.getIsUsed() == "1") {
    alert("这个连接啦,URL不会因为你这个连接变化啦,已经增加过了,不要在点啦,在点就报警啦,哈哈");
    return;
    }
    obj.setIsUsed("1");//设置该节点已经被使用
    if(nowSize == 1) {
    nowInfo[obj.getPori()] = "?"+obj.getPori()+obj.getKeyinfo();
    getUrlObj().href = getUrlObj().href + nowInfo[obj.getPori()];
    }else {
    var needUri = nowInfo[obj.getPori()];
    if(needUri == undefined) {//没有找到相同前缀的URL
    nowInfo[obj.getPori()] = "&" + obj.getPori()+obj.getKeyinfo();
    getUrlObj().href = getUrlObj().href + nowInfo[obj.getPori()];
    }else {
    getUrlObj().href = getUrlObj().href.replace(needUri,needUri+","+obj.getKeyinfo());
    nowInfo[obj.getPori()] = needUri+","+obj.getKeyinfo();
    }
    }
    nowSize ++;
    showUrl();
    } function getUrlObj() {
    return document.getElementById("link4");
    } function showUrl() {
    alert("现在的URL变成了:"+getUrlObj().href);
    }
    </script>
    </html>哎呀,终于写完了,我这IE6测试通过,其它浏览器没试过哈。。
    其实干嘛改变它的URL呢,用变量绑定将跳转放在JS中去做就完了呗,哈哈