jQuery使用.on()事件获取<a>元素的哈希值

Mau*_*wer 10 jquery jquery-1.7

在我对手册的引用引起轰动之前,我已经研究了很长一段时间了,并且不断陷入死胡同.甚至不确定如何正确调试它.因此,如果引用了任何参考文献,请确保它们具有良好的评论和指导性.这是由于我是一名PHP/mySQL开发人员,而JavaScript对象参考模型对我来说有点混乱(但绝对是我尽力学习!:)).

我正在尝试使用jQuery v1.7.2更新我对jQuery的了解.显然,现场活动已被弃用,并已被.on()取代.jQuery文档说不要使用.on()将旧的"click"或"live"事件与任何脚本混合在一起.

在尝试习惯使用时,我试图捕获给定URL的哈希值.

页面如下(标头已加载jquery.min.1.7.2.js):

    <div id='menuHolder' style="position:relative; margin-left:50px;margin-bottom:30px; padding-top:35px; min-width:600px;z-index:998;">
      <ul id="menu">
         <li><a href="#">Events</a>
            <ul id="events">
                <li>
                    <img class="corner_inset_left" alt="" src="images/menu/corner_inset_left.png"/>
                    <a id="linker21 menu" class="test AJAXcaller" href="index.php#?p=1&amp;d=AJAXcontent&i=1&amp;k=<?=$_SESSION['authcpanel']['key']?>" rel="nofollow">Upcoming Events</a>
                    <img class="corner_inset_right" alt="" src="images/menu/corner_inset_right.png"/>
                </li>
                <li><a href="#">List All Events</a></li>
                <li><a id="linkermenu" class="test AJAXcaller" href="index.php#?p=24&amp;d=AJAXcontent&i=1&amp;k=<?=$_SESSION['authcpanel']['key']?>" rel="nofollow">Add Events</a></li>
                <li class="last">
                    <img class="corner_left" alt="" src="images/menu/corner_left.png"/>
                    <img class="middle" alt="" src="images/menu/dot.gif"/>
                    <img class="corner_right" alt="" src="images/menu/corner_right.png"/>
                </li>
            </ul>
         </li>
      </ul>
    </div>

<script>
    $(document).on("click", "a.AJAXcaller", function(){ 
        alert("Goodbye!");
        alert($(this).attr("hash"));
    }); 
</script>
Run Code Online (Sandbox Code Playgroud)

单击"添加事件"链接(具有哈希值)时会触发第一个警报,继续"再见!",然后第二个处理程序触发并转发"未定义".我如何访问此哈希?

我的旧代码如下,并且它可以工作,但任何调用页面的ajax都不会附加事件处理程序,这就是我使用.on()事件的原因.另外,如果我这次要学习如何正确地做这件事;),我不希望涉及已弃用的功能......

旧代码(作品)

var linkClickAction = {
        'a.AJAXcaller' : function(element){
            element.onclick = function(){
                var locationString = $(this).attr("hash");
                locationString = locationString.replace(/.*\#(.*)/, "$1")
            var parameterString = locationString.replace(/.*\?(.*)/, "$1"); // onclick="sndReq('j=1&q=2&t=127.0.0.1&c=5');

            var parameterTokens = parameterString.split("&"); // onclick="sndReq('j=1,q=2,t=127.0.0.1,c=5');
            var parameterList = new Array();
            for (j = 0; j < parameterTokens.length; j++) {
                var parameterName = parameterTokens[j].replace(/(.*)=.*/, "$1"); // j
                var parameterValue = parameterTokens[j].replace(/.*=(.*)/, "$1"); // 1
                parameterList[parameterName] = parameterValue;
            }
            var page = parameterList['p'];
            var key = parameterList['k'];
            var includesDir = parameterList['i'];
            var changeDiv = parameterList['d'];

            sndReq(page,key,includesDir,changeDiv,parameterString); 
            return false;       
            }
        }

    };
Behaviour.register(linkClickAction);
Run Code Online (Sandbox Code Playgroud)

还加载了一个基本处理侦听器的behaviour.js脚本.我当时根本没有使用jQuery.相对而言,这很好,而且很快(很小的.js文件,没有多余的代码),但是当我在ui中处理奇特的东西时,我达到了能够编写有效JavaScript的极限.所以我必须在页面加载时加载jQuery脚本.看看它是如何加载的,我正在尝试使用它的功能,而不是为我的页面添加更多不必要的脚本来加载.因此,我想找到一个使用本机jQuery 1.7.2函数来实现此目标的结果.

结果

事实证明,当使用.attr()来查找DOM对象的属性时,jQuery 1.6+可能会中断.所以使用.prop()是可行的方法.更正后的代码如下:

/*
Page:           rating.js
Created:        Aug 2006
Last Mod:       May 30, 2012
Modder:         Darren Maurer
*/

    function sndReq(page,key,includesDir,changeDiv,parameterString) {
        var divToChange = document.getElementById(changeDiv); // the Div that the data will be put into

        // switch Div with a loading div
        divToChange.innerHTML = '<div class="loading"><img src="images/loading.gif" title="Saskatoon.CityGuru.ca - Loading Page" alt="Saskatoon.CityGuru.ca - Loading Page" border="0"/></div>';

        if (includesDir == 1){
            //Find Current Working Directory.  Use to find path to call other files from
            /*var myloc = window.location.href;
            var locarray = myloc.split("/");
            delete locarray[(locarray.length-1)];
            var arraytext = locarray.join("/");
            */
            $.ajax({
                type: "POST",
                url: "AJAXCaller.php",
                data: parameterString,
                success: function(msg){
                    $('#'+changeDiv).html(msg);
                }
            });
        } 
    }

/* =======END AJAX FUNCTIONS================= */

/* =======BEGIN CLICK LISTENER FUNCTIONS================= */
/* Listens to any a href link that has a class containing ' AJAXcaller' */
/* ie. <a id="link1" class="test AJAXcaller" href="index.php#http://233.help?id=22&think=33" rel="nofollow">> AJAX TEST LINK <</a> */
$(document).on("click", "a.AJAXcaller", function(){
    alert($(this).prop("hash")); 
            var locationString = $(this).prop("hash");
            locationString = locationString.replace(/.*\#(.*)/, "$1")
            var parameterString = locationString.replace(/.*\?(.*)/, "$1"); // onclick="sndReq('j=1&q=2&t=127.0.0.1&c=5');

            var parameterTokens = parameterString.split("&"); // onclick="sndReq('j=1,q=2,t=127.0.0.1,c=5');
            var parameterList = new Array();
            for (j = 0; j < parameterTokens.length; j++) {
                var parameterName = parameterTokens[j].replace(/(.*)=.*/, "$1"); // j
                var parameterValue = parameterTokens[j].replace(/.*=(.*)/, "$1"); // 1
                parameterList[parameterName] = parameterValue;
            }
            var page = parameterList['p'];
            var key = parameterList['k'];
            var includesDir = parameterList['i'];
            var changeDiv = parameterList['d'];
            sndReq(page,key,includesDir,changeDiv,parameterString); 
            return false;   
}); 
Run Code Online (Sandbox Code Playgroud)

希望对某人有所帮助,这绝对是我的救星!

Dev*_*man 31

您的元素没有哈希属性.尝试获取href属性并使用javascript的substr和indexOf函数将字符串拆分为#

var href = $(this).attr("href");
var hash = href.substr(href.indexOf("#"));
Run Code Online (Sandbox Code Playgroud)

你也可以使用

$(this).prop("hash");
Run Code Online (Sandbox Code Playgroud)


Ole*_*leg 5

$('a.js-hash').click(function() {

    // Store hash
    var hash = this.hash;

    // Using jQuery's animate() method to add smooth page scroll
    $('html, body').animate({
        scrollTop: $(hash).offset().top
    }, 1000, function() {

        // Add hash (#) to URL when done scrolling (default click behavior)
        window.location.hash = hash;
    });

    // Prevent default anchor click behavior
    return false;
});
Run Code Online (Sandbox Code Playgroud)