近日有需求做一个职业选择弹框,在网上搜了半天也没合适的;

暴躁大佬协助我DIY一个插件,直接使用,顺滑流畅,随心所欲!特别鸣谢@一样菜

不多BB了,直接撸代码:

引用写在上面:

/* 更改职业 */
selectOccupation : function() {
// 展示类型
var ms = new MutliSelectorUI(App.dataCode, function (data) {
App.OccupationTpCd = data.code;
App.OCCUPATION_NAME = data.name;
var str = data.name;
if (str.length>14) {
str = str.substr(0,14)+"...";
}
$("#selectOccupation").val(str);
$("#OccupationVal").val(data.code);
ms.hideDialog();
});
if(App.version) {
ms.showDialog();
}else{
ms.hideDialog();
}
},

  

function MutliSelectorUI(data, fn){
const data_list = data;
var panelBg = document.createElement('div')
panelBg.className="msu_panel_background"
panelBg.setAttribute('id','msu_panel_background')
document.body.appendChild(panelBg)
var $panel = $('#msu_panel_background')
$panel.css({
display: 'none'
}) this.showDialog = function(){
$panel.show()
$("#pageB").attr({"data-btnLeft":"false||", "data-btnRight":"false||"});
Fw.showPageArea($("#pageB"), [ $(".page") ], true);
}
this.hideDialog = function(){
$panel.hide()
$("#pageB").attr({"data-btnLeft":"true|返回|App.backPerson()", "data-btnRight":"true|保存|App.saveOccupation()"})
Fw.showPageArea($("#pageB"), [ $(".page") ], true)
}
let self = this
$panel.empty()
$panel_box = $('<div class="msu_panel_box"></div>')
$panel_box_cancel = $('<div class="msu_panel_cencels">取 消</div>')
$panel.append($panel_box)
$panel.append($panel_box_cancel) this.renderMainRow = function(){
let indx = 0;
$panel_box.empty()
for(let item of data_list){
console.log(JSON.stringify(item.classes))
var $row_item = $('<div class="msu_main_row" code="'+item.code+'" name="'+item.name+'" isexpend="false"><div class="msu_text">'+item.name+'</div><div class="msu_arrow right"></div></div>')
$panel_box.append($row_item)
if(item.classes.length == 0){
$row_item.find('.msu_arrow').hide()
}
indx++
if(indx == data_list.length){
$row_item.css({
borderBottom: '0'
})
} }
} // init
this.renderMainRow()
$panel_box_cancel.on('click',function(){
self.hideDialog()
})
$panel.on('click','.msu_main_row',function () {
let _code = $(this).attr('code')
let _name = $(this).attr('name')
let isexpend = $(this).attr('isexpend')
let classes = [] for(let dt of data_list){
if(dt.code == _code){
classes = dt.classes
break;
}
}
if(classes.length == 0){ if(typeof fn === 'function'){
fn({
code:_code,
name: _name
})
}
return;
}
$panel_box.empty(); var $subitem = $('<div class="msu_back_btn"><div class="msu_arrow left"></div><div class="msu_text">'+_name+'</div></div>')
$panel_box.append($subitem)
let indx = 0
for(var cls of classes){
var $subitem = $('<div class="msu_sub_row" code="'+cls.code+'" name="'+cls.name+'">'+cls.name+'</div>')
$panel_box.append($subitem);
indx++
if(indx == classes.length){
$subitem.css({
borderBottom: '0'
})
}
} })
$panel.on('click','.msu_sub_row',function () {
var _code = $(this).attr('code')
var _name = $(this).attr('name')
if(typeof fn === 'function'){
fn({
code:_code,
name: _name
})
}
})
$panel.on('click','.msu_back_btn',function () {
self.renderMainRow()
}) }

如何使用外部插件picker的更多相关文章

  1. angular4.0如何引入外部插件2:declare方案

    前面有个<angular4.0如何引入外部插件1:import方案>,但是有局限,因为方案1需要用到@types这个东西. 但是并不是每一个插件都有@types,所以现在写个方案2. 拿引 ...

  2. angular4.0如何引入外部插件1:import方案

    引入外部插件是项目中非常重要的环节.因为部分插件以js语法写的,而ng4用的是ts语法,所以在引入时需要配置. Step1:引入swiper插件的js文件[css在下面会讲到,先别急] 很重要的意见: ...

  3. 不用外部插件启用u盘ntfs写功能

    mac下启用NTFS u盘读写功能. 不用要任何外部插件,其实mac本来就支持,只是因为专利原因隐藏了而已. macbook:~ uwe$ sudo umount /Volumes/UNTITLED ...

  4. metronic后台模板学习 -- 所用外部插件列表

    插件名称 描述 URL jQuery 1.11.0 js库,不用介绍了 http://www.jquery.com jQuery Migrate plugin 1.2.1 jQuery 老版本过渡迁移 ...

  5. vue使用一些外部插件及样式的配置

    一.配置全局css及js样式 1.首先将事先写好的css文件及js文件放在src文件目录下的assets文件下 2.在main.js文件输上图右边两个红色框的代码 二.配置全局jQuery及boots ...

  6. ionic3引用外部插件--百度地图及echart报表的使用

    前言 ionic3提供的组件已经相当丰富咯,但是事实上有些特殊的需求,比如使用百度地图,或者第三方插件echart报表插件是,就不能用传统的方式去使用第三方插件咯,如何在Ionic3项目中使用第三方J ...

  7. Vue-cli开发笔记三----------引入外部插件

    (一)绝对路径直接引入: (1)主入口页面index.html中头部script标签引入: <script type="text/javascript" src=" ...

  8. 在vue-cli中引入外部插件

    一.可以用npm下载的 现在以jquery为例子: 1 先在package.json中的dependencies中写入“jquery”:“^3.2.1”(jquery版本) 2 在npm中搜索jque ...

  9. MyEclipse2016添加外部的maven插件

    1.在maven官网下载最新的maven安装包,下载地址:http://maven.apache.org/download.cgi: 2.目前maven的版本是3.5.0,我们下载apache-mav ...

随机推荐

  1. 洛谷1099 [NOIP2007] 树网的核

    链接https://www.luogu.org/problemnew/show/P1099 题目描述 设T=(V,E,W)是一个无圈且连通的无向图(也称为无根树),每条边到有正整数的权,我们称TTT为 ...

  2. rest-framework框架

    rest-framework框架是Django里面非常重要的框架,但提到rest-framework框架就不得不说两种请求方式,那就是CBV和FBV. FBV(function base views) ...

  3. 为什么要清除BSS段

    如题,看到uboot里有清除BSS段的代码,想知道这样做的目的是什么啊,BSS段默认值本来就是0了啊,希望大哥大姐们能详细的解说下,谢谢了 bss 段描述了未初始化的全局变量和静态变量的大小等信息,但 ...

  4. Spring Boot 启动的时候遇到 java.lang.ClassNotFoundException: ch.qos.logback.classic.Level

    在刚开始接触spring boot的时候,想创建一个Hello World 的project. 但是创建完之后,Run as 'Spring Boot APP'的时候遇到这个错误. Level类存在于 ...

  5. Python3的URL编码解码

    前言 博主最近在用python3练习一些爬虫脚本的时候,发现一些url的编码问题,在浏览器提交请求api时,如果url中包含汉子,就会被自动编码掉.呈现的结果是 ==> %xx%xx%xx.如果 ...

  6. Java基础学习总结(47)——JAVA输入输出流再回忆

    一.什么是IO Java中I/O操作主要是指使用Java进行输入,输出操作. Java所有的I/O机制都是基于数据流进行输入输出,这些数据流表示了字符或者字节数据的流动序列. Java的I/O流提供了 ...

  7. nginx 查看每秒有多少访问量

    nginx访问量统计 1.根据访问IP统计UV awk '{print $1}' access.log|sort | uniq -c |wc -l 2.统计访问URL统计PV awk '{print ...

  8. ZOJ 3329

    方程很明显有 d[i]=sum(pk*d[i+k])+p0*d[0]; 其中pi可以在开始时枚举求出. 设d[i]=A[i]*d[0]+B[i], 代入上式 d[i]=(sum(pk*A[i+k])+ ...

  9. POJ 1765 November Rain

    题目大意: 有一些屋顶,相当于一些线段(不想交). 问每一条线段能够接到多少水,相对较低的屋顶能够接到高屋顶留下的水(如题图所看到的).因为y1!=y2,所以保证屋顶是斜的. 解题思路: 扫描线,由于 ...

  10. android AudioManager AUDIOFOCUS

    如今開始做音乐播放器的模块.遇到了几个问题 当播放音乐的过程中,去调节音量或者情景模式中的铃声设置,结果会有两种声音同一时候响起. 引起此问题的解决办法是音乐焦点问题没弄清 现分析一下音乐焦点的几个属 ...