Я хочу прикрепить пользовательские идентификаторы к ссылкам на основе строки запроса - PullRequest
3 голосов
/ 17 октября 2011

Я хочу прикрепить пользовательские идентификаторы к ссылкам на основе строки запроса , и я нашел этот очень полезный пост Грегори (пожалуйста, посмотрите на негополучить некоторый контекст).

Я пытаюсь достичь , если я захожу на www.mydomain.com, мне требуется добавить значение по умолчанию к ссылке на веб-странице,пример: www.ramdomdomain.com?myID1=default_value

Я думаю, что-то должно быть отредактировано после строки if(hrefvalue==null) в коде, но я не могу понять, как это сделать.Пожалуйста, помогите мне.Вот код, который я использую:

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.4/jquery.min.js"></script>

<script type="text/javascript">
function getHrefValue(key,url){
  var query=new RegExp("[\\?&]"+(key.replace(/[\[]/,"\\\[").replace(/[\]]/,"\\\]"))+"=([^&#]*)").exec(url);
  return (query==null)?null:query[1];
}
function matchHrefs(){
  var config={
    'myid1':["#topnav a[href^='http://www.domain.com']"],
    'myid2':["#topnav a[href^='http://www.domain.com']"]
  }
  for(var current in config){
    var myvalue=getHrefValue(current,location.search);
    if(myvalue!=null&&myvalue!=""){
      $(config[current].join(',')).each(function(){
        var href=$(this).attr('href');
        var hrefvalue=getHrefValue(current,href);
        if(hrefvalue==null){
          var href_split=href.split('#');
          $(this).attr('href',href_split[0]+(href_split[0].indexOf('?')>-1?'&':'?')+current+'='+myvalue+(typeof(href_split[1])!="undefined"?'#'+href_split[1]:''));
          $(this).addClass('selected selected-'+current);
        }
        if(hrefvalue==""){
          $(this).attr('href',href.replace(current+'=',current+'='+myvalue));
          $(this).addClass('selected selected-'+current);
        }
      });
    }
  }
}
$(function(){matchHrefs();});
</script>

<div id="topnav"><a href="http://www.domain.com/" target="_blank">Random domain</a></div>

1 Ответ

1 голос
/ 17 октября 2011

Это то, что вы ищете:

<div>        
        <script type='text/javascript' src='https://ajax.googleapis.com/ajax/libs/jquery/1.6.2/jquery.min.js'></script>
        <script type="text/javascript">
            $(function() {
                var requestid = new String(gup('myid'));
                if (requestid == "") {
                    requestid = "unknown";
                }
                $("a").each(function() {
                    var href = $(this).attr("href");
                    href += "?myId=" + requestid;
                    $(this).attr("href", href);
                })
            })

            //gup taken from here:http://www.netlobo.com/url_query_string_javascript.html
            function gup(name) {
                name = name.replace(/[\[]/, "\\\[").replace(/[\]]/, "\\\]");
                var regexS = "[\\?&]" + name + "=([^&#]*)";
                var regex = new RegExp(regexS);
                var results = regex.exec(window.location.href);
                if (results == null)
                    return "";
                else
                    return results[1];
            }

        </script>

        <div id="topnav">
            <a href="http://www.google.com" target="_blank">Random domain</a>
            <a href="http://www.yahoo.com" target="_blank">Random domain</a>
        </div>
    </div>
...