jQuery插件转vue组件

<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>select.js</title>
<script type="text/javascript" src="https://cdn.bootcss.com/jquery/1.11.3/jquery.min.js"></script>
<script type="text/javascript" src="https://cdn.bootcss.com/vue/2.5.14/vue.min.js"></script>
<style type="text/css">
{
margin: 0;padding: 0;
}
ul,li{
list-style: none;
}
.z-form-select {
position: relative;
width: 256px;
height: 28px;
border: 1px solid #e6e6e6
}
.z-form-select .select-name {
display: block;
width: 219px;
height: 28px;
line-height: 28px;
overflow: hidden;
float: left;
text-align: center;
/
border-right: 1px solid #e6e6e6;*/
margin-right: 10px;
}
.z-form-select i {
display: block;
float: left;
width: 18px;
height: 9px;
margin-top: 9px;
display: inline-block;
width: 0;
height: 0;
margin-left: 2px;
vertical-align: middle;
border-top: 4px dashed;
border-top: 4px solid\9;
border-right: 4px solid transparent;
border-left: 4px solid transparent;
}
.z-form-select ul {
display: none;
position: absolute;
top: 29px;
width: 255px;
border: 1px solid #e6e6e6;
border-top: 0;
background-color: #fff;
overflow: auto
}
.z-form-select li {
height: 28px;
line-height: 28px;
padding: 0 10px;
white-space: nowrap
}
.z-form-select li:hover {
background-color: #e6e6e6
}
.z-form-select .disabled{
color: #ccc;
cursor: not-allowed;
background-color: #FFF!important
}
</style>
</head>
<body>
<div class="select" name="test"></div>
<div style="height:200px;" id="app">
<zh-select :data="list" id="s1"></zh-select>
<div style="height:200px;"></div>
<zh-select :disabled="disabled" :data="list2"></zh-select>
</div>
<div class="select" name="test2"></div>

<button id="get"></button>
<script type="text/javascript">
;(function(){ var Select = function(el,options){ var self = this; this.el =(el);
this.options = options || {};
var data = this.options.data || [],
onclick = this.options.onclick || function(el){console.log(el.text())};
var htm = [
'<div class="z-form-select">',
'<span class="select-name"></span>',
'<i></i>',
'<ul class="select-items"></ul>',
'</div>'
];
this.el.append(htm.join(''));
self.setValues(data);
(el) .on("click",".select-items li", function(){ if((this).hasClass('disabled')) return;
onclick && onclick((this));(this).addClass('selected').siblings().removeClass('selected');
self.el.find('.select-name').html((this).text()); }) .on("click",".select-name", function(){ if ((this).hasClass('disabled')) {
return;
}
(this).parent().find('.select-items').show(); });(document).click(function(e){
if((e.target).hasClass('select-name')) return; if((e.target).hasClass('disabled')) return;
('.select-items').hide(); }) } Select.prototype = { constructor:Select, setValues:function(data){ var self = this; var list = data || [], i = 0, j, arry = [],ul = self.el.find('.select-items');
if(Object.prototype.toString.call(list) == '[object Array]' && list.length > 0){
for(j=list.length; i < j; i++){
arry.push('<li>' + list[i] + '</li>');
}
}
ul.html('');ul.append(arry.join(''));
},
getValue:function(){
return this.el.find('.select-items .selected').html();
},
enable: function(value) {
this.el.find('.select-items li').each(function(){
if((this).text() == value){(this).removeClass('disabled');
}
});
},
disable: function(value) {
this.el.find('.select-items li').each(function(){
if((this).text() == value){(this).addClass('disabled');
}
});
},
allDisable:function(value){
if(value){
this.el.find('.select-name').addClass('disabled');
}else{
this.el.find('.select-name').removeClass('disabled');
}
}
}

var Plugin = function(option){
    var value,
        option = arguments[0],
        param = arguments[1];
     this.each(function() {
        var $this = $(this)
        var data = $this.data('z-select');
        if(!data) $this.data('z-select', (data = new Select(this,option)))
        if (typeof option == 'string'){
            value = data[option](param);
        }
    })
    return value ? value : this;
}

$.fn.select = Plugin;

})(jQuery)
</script>
<script type="text/javascript">
// (".select").select({data:['11','22','33'],onclick:function(el){ // var val = el.text(); // console.clear(); // console.log(val); // }}); //(function(){
// ("#get").click(function(){ // var val2 =(".select").select('getValue');
// console.log(val2);
// });
// (".select").select('disable','22'); // }) </script> <script type="text/javascript"> var param = { props:['disabled','data'], template:'<div class="select"></div>', data:{ instance:{} }, watch:{ disabled:function(val){ this.instance.select('allDisable',val) } }, mounted:function(){ var self = this; this.instance =(this.el).select({data:self.data,onclick:function(el){ var val = el.text(); console.clear(); console.log(val); }});(this.$el).select('disable','22');
}
}
Vue.component("zh-select",param);
</script>
<script type="text/javascript">
var app = new Vue({
data:{
list:['111','22','33','666'],
list2:['22','33','666'],
disabled:false
},
el:'#app'
})
</script>
</body>
</html>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,542评论 6 504
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,822评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,912评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,449评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,500评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,370评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,193评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,074评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,505评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,722评论 3 335
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,841评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,569评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,168评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,783评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,918评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,962评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,781评论 2 354

推荐阅读更多精彩内容

  • "use strict";function _classCallCheck(e,t){if(!(e instanc...
    久些阅读 2,030评论 0 2
  • 不会用代码框,所以看着有些乱套,,,,html部分 <!DOCTYPE html> 迅雷看看 ...
    这就是个帅气的名字阅读 1,534评论 0 0
  • 1. tab列表折叠效果 html: 能源系统事业部 岗位名称: 工作地点 岗位名...
    lilyping阅读 1,862评论 0 1
  • 今天6号店培训gtd,感觉不错。看到大家学习这么高的热情,很欣慰。因为看到大家的状态我想起了“适应性偏见”。 所谓...
    罗召伟阅读 248评论 2 8
  • 01 微风轻轻吹过,带动了我的碎发。 早晨九点,人很少,安静而空旷的车间道,...
    一小小小小只阅读 631评论 0 0