欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  web前端

jquery插件开发之实现google+圈子选择功能_jquery

程序员文章站 2022-06-08 11:45:48
...
jquery插件开发之实现google+圈子选择功能_jquery

具体原理与调用不详述,可看代码注释及DEMO演示(演示中mod.udata.js里有一个汉字转拼音方法,它并不是插件的一部分,但为插件提供了拼音搜索的功能)。

复制代码 代码如下:

;(function ($) {
/*
* 基于jQuery实现类似Google+圈子选择功能插件(支持键盘事件)@Mr.Think(http://mrthink.net/)
*/
$.fn.iChoose = function (options) {
var SELF=this;
var iset = $.extend({}, $.fn.iChoose.defaults, options);
var _h,pull=null;
var main=$(iset.choMain);
var chose=$(iset.choCls,main);
var input=$(SELF);
var tips=$(iset.tips,main);
var cls=iset.selCls;
var ids=$(iset.chsIds);
var _l=iset.limit;
//若无列表数据则中断
if(iset.data.length==0){return false}
//初始化下拉列表
var tpl='
    ';
    var tplArr=[];
    $.each(iset.data,function(k,v){
    tplArr.push('
  • '+ v.name+'
  • ');
    });
    tpl=tpl+tplArr.join('')+'
';
if(pull==null){
main.append(tpl);
}
pull=$('.'+iset.pullCls,main);
_h=pull.find('li').outerHeight(true);
pull.width(main.width()-2);
//操作函数
var Action={
init:function(){
//列表鼠标划过
pull.delegate('li.hook_visible','mouseover',function(){
$(this).addClass(cls).siblings().removeClass(cls);
});
//选择列表
pull.delegate('li.hook_visible','click',function(){
Action.choose($(this));
});
//点击弹出列表
chose.click(function(){
Action.show();
});
//移除已选择
chose.delegate('.'+iset.removeEl,'click',function(){
Action.undock($(this));
});
},
move: function(dir) {
//上下移动 - 上::str=up | 下::step=down;
var index;
var item=pull.find('li.hook_visible').filter(':visible');
var cur=item.filter('.'+cls);
cur.size()==0 ? index=-1 : index=item.index(cur);
item.eq(dir=='up' ? (index //移动时跟随滚动
if(item.size()>_l){
//下翻滚动
if(dir=='down'){
pull.scrollTop((index+2-_l)*_h);
}
//上翻滚动
if(dir=='up'){
pull.scrollTop((index-1)*_h);
}
}
},
choose:function(el){
//列表选择
var mid=el.attr('data-mid');
var name=el.text();
tips.before('
'+name+'x
');
input.focus();
el.hide().removeClass('hook_visible');
//返回选中列表id
ids.val() =='' ? ids.val(mid) : ids.val(ids.val()+','+mid);
pull.find('li.hook_visible:first').addClass(cls).siblings().removeClass(cls);
this.upstyle();
},
undock:function(el){
//删除已选
var mid=el.attr('data-mid');
var idsArr=ids.val().split(',');
input.focus();
el.parent().remove();
idsArr=$.grep(idsArr,function(v,k){
return v != mid;
});
ids.val(idsArr.join(','));
pull.find('li.hook_'+mid).show().addClass('hook_visible');
this.upstyle();
},
show:function(){
//显示列表
pull.slideDown(100,function(){Action.match('')});
pull.find('li.hook_visible:first').addClass(cls).siblings().removeClass(cls);
$(SELF).focus();
tips.hide();
input.addClass(iset.inputWCls);
},
hide:function(){
//隐藏列表
pull.slideUp(100);
$(SELF).blur();
tips.show();
input.removeClass(iset.inputWCls);
},
upstyle:function(type){
//更新下拉列表样式 - 当已选换行时 --
var len=pull.find('li.hook_visible').size();
if(type=='match'){
len=pull.find('li:visible').size();
}
if(len<_l> pull.height(_h*len);
if(len==0){
this.hide();
}
}else{
pull.height(_h*_l);
}
pull.css('top',chose.outerHeight());
},
match:function(str){
//过滤选择 - 拼音选择须插件支持
var visible=pull.find('li.hook_visible');
visible.each(function(){
var name=$(this).attr('data-name');
name.match(str.toUpperCase())!=null ? $(this).show() : $(this).hide();
});
if(visible.size()==0 && $('.'+iset.noResCls).size()==0){
pull.find('li:first').before('
  • 暂无可选择列表
  • ')
    }
    this.upstyle('match');
    },
    blur:function(str){
    //非选择区域点击隐藏
    pull.find('li.hook_visible').each(function(){
    var name=$(this).text();
    if(name == str){
    Action.choose($(this));
    }
    });
    input.val('');
    }
    }
    Action.init();
    //键盘控制 - 绑定输入表单
    $(this).on({
    //键盘弹起
    'keyup change':function(){
    var val= $.trim(input.val());
    Action.match(val);
    },
    //失去焦点
    'blur':function(){
    var val= $.trim(input.val());
    Action.blur(val);
    },
    //键盘按下 -- 捕获键盘值,以执行对应事件
    /*
    8 - delete;
    27 - esc;
    38 - up;
    40 - down;
    9 - tab;
    13 - enter
    */
    'keydown':function(e){
    switch (e.keyCode) {
    case 8:
    if($.trim(input.val())==''){
    e.preventDefault();
    var last=chose.find('.'+iset.removeEl+':last');
    if(last.size()>0){
    Action.undock(last);
    }
    }
    break;
    case 27:
    e.preventDefault();
    Action.hide();
    break;
    case 38:
    e.preventDefault();
    Action.move('up');
    break;
    case 40:
    e.preventDefault();
    Action.move('down')
    break;
    case 9:
    case 13:
    e.preventDefault();
    Action.choose(pull.find('.'+cls));
    break;
    default:
    $.noop();
    }
    }
    });
    //点击非当前区域隐藏弹出层
    main.click(function(e){
    e.stopPropagation();
    });
    $(document).click(function(){
    Action.hide();
    });
    }
    $.fn.iChoose.defaults = {
    /*
    data:传入值,可以实时ajax传上,演示中是json值,具体格式可参考mod.udatas.js中的$.map(...)
    limit:每次显示的条数,其他滚动显示
    choMain:载入区域id
    pullCls:弹出列表的class
    choCls:已选择列表的外围class
    selItemCls:已选择的单个元素class
    removeEl:删除元素的class
    selCls:列表高亮的class
    inputWCls:input的class
    tips:默认提示值元素钩子
    noResCls:列表中无结果时的cls
    chsIds:已选择列表的id值,传给后端用的。(此值亦可用回调函数把值从插件中回传出来)
    */
    data:UDatas,
    limit:5,
    choMain:'#iChooseMain',
    pullCls:'icm-list',
    choCls:'.icm-box',
    selItemCls:'icm-item',
    removeEl:'icm-delete',
    selCls:'selected',
    inputWCls:'icm-input-w',
    tips:'.icm-cur-txt',
    noResCls:'hook_noresult',
    chsIds:'#iChooseIds'
    }
    })(jQuery);