将jquery选择器传递给插件中的子功能

时间:2009-02-12 14:03:59

标签: javascript jquery function jquery-plugins

我正在尝试制作一个快速jquery插件(作为学习练习),用于从项目列表(在本例中为LI)中创建一个简单的寻呼机,并在将当前选择器(this)传递给时遇到问题一个子功能。代码如下。

问题是在创建动态导航时(插件需要jquery 1.3)并且我需要传递选择器,因为它是执行构成寻呼机的实际显示/隐藏的子功能。我正在尝试以下

var selector = $(this);

要获取选择器,然后将其传递给脚本底部的子功能,如下所示

$(".pageNav a").live("click", function(selector) {

并希望在子功能中使用选择器如下

$(selector).hide();

但我什么也没得到。任何建议将不胜感激,无需为我完成插件!

由于

(function($) {
$.fn.quickPager = function() {

    //edit this
    var pageSize = 10;
    //leave this
    var selector = $(this);
    var totalRecords = $(this).length;
    var currentPage = 1;
    var pageCounter = 1;

    $(this).each(function(i){
        if(i < pageCounter*pageSize && i >= (pageCounter-1)*pageSize) {
            $(this).addClass("page"+pageCounter);
        }
        else {
            $(this).addClass("page"+(pageCounter+1));
            pageCounter ++;
        }   
    });

    //show/hide the appropriate regions 
    $(this).hide();
    $(".page"+currentPage).show();

    //first check if there is more than one page. If so, build nav
    if(pageCounter > 1) {

        //Build pager navigation
        var pageNav = "<ul class='pageNav'>";   
        for (i=1;i<=pageCounter;i++){

            if (i==1) {
                pageNav += "<li class=currentPage pageNav"+i+"'><a rel='"+i+"' href='#'>Page "+i+"</a></li>";   
            }
            else {
                pageNav += "<li class='pageNav"+i+"'><a rel='"+i+"' href='#'>Page "+i+"</a></li>";
            }

        }
        pageNav += "</ul>";
        $("#pagerContainer").append(pageNav);

        //pager navigation behaviour
        $(".pageNav a").live("click", function(selector) {          
            //grab the REL attribute 
            var clickedLink = $(this).attr("rel");
            currentPage = clickedLink;
            //remove current current (!) page
            $("li.currentPage").removeClass("currentPage");
            //Add current page highlighting
            $(this).parent("li").addClass("currentPage");
            //hide and show relevant links
            //$("ul.paging li").text("TEST");
            $(selector).hide();
            $(selector+".page"+clickedLink).show();
            return false;
        });

    }



}
})(jQuery);

3 个答案:

答案 0 :(得分:4)

var selector = $(this);
$(".pageNav a").live("click", function() {
  // do something
  selector.hide();
});

答案 1 :(得分:0)

并更改

$(selector+".page"+clickedLink).show();

selector.find(".page"+clickedLink).show();

selector 不是字符串,它是一个jQuery对象,其中包含插件理解为 this

的所有元素

答案 2 :(得分:0)

似乎缺少的链接是

selector.parent().find(".page"+clickedLink).show();

感谢您宝贵的帮助夸克。