本文实例为大家分享了下拉菜单生成器dropMenu的使用方法,供大家参考,具体内容如

HTML
<div class="input-group"> <span class="input-group-addon" style="width: 100px" >职级:</span> <input type="text" class="units form-control" id="jobTitle" value="其他" style="border-radius:0 4px 4px 0;"></input> <span class="caret beside"></span> </div>
js
$(function(){
var title,
populationType,
titleInParty;
$.ajax({
url:'/api/v1/user/getUserTypeInfo',
type:'GET',
dataType:'json',
success:function (data) {
title=data.data.title;
titleInParty=data.data.titleInParty;
populationType=data.data.populationType;
partyLabel('jobTitle',title);
partyLabel('populationType',populationType);
partyLabel('titleInParty',titleInParty);
}
});
function partyLabel(menuID,data){
new DropMeun({
'id':menuID,
"data":data,
"dataSrc":"name", //数据是下面的这种格式的,你要的是name的值
"ableSearch":true, //可以搜索
"style":{ //样式,可选
"width":173,
"maxHeight":200,
"left":0, //定位到哪里
"top":5,
"initPos":"left" //设置在哪边出现
}
})
}
3.在页面中引用一个js 文件
(function(vq0599) {
window.DropMeun = vq0599
})(function() {
/*-- tools --*/
function getRealTop(node) {
return node.offsetParent.tagName.toUpperCase() === 'BODY' ?
node.offsetTop :
node.offsetTop + arguments.callee(node.offsetParent)
}
function getRealLeft(node) {
return node.offsetParent.tagName.toUpperCase() === 'BODY' ?
node.offsetLeft :
node.offsetLeft + arguments.callee(node.offsetParent)
}
/*-- tools end--*/
function DropMeun(option) {
this.picker = null
this.self = null
this.option = option
this.item = option.item || []
this.style = option.style || {}
this.dataList = option.data || []
this.init()
return this;
}
DropMeun.prototype.init = function () {
var html = '',
_this = this
this.self = document.createElement('ul')
this.picker = document.getElementById(this.option.id)
if (! this.picker) {
throw 'picker is null, making sure that picker\'s ID \''+ this.option.id +'\' is correct'
return
}
if (this.option.ableSearch) {
html += '<li><input class="dropMeun-searchInput" type="text"></li>'
}
this.dataList.forEach(function(data, index) {
var item = _this.option.dataSrc ? data[_this.option.dataSrc] : data,
content = _this.item.render ? _this.item.render(item, data) : item
html += '<li class="dropMeun-item '+ (_this.item.className || '') +'" data-index="'+ index +'">'+ content +'</li>'
})
this.self.classList.add('dropMeun')
this.self.innerHTML = html
document.body.appendChild(this.self)
this.setStyle()
this.bindEvent()
}
DropMeun.prototype.setStyle = function() {
this.self.style.width =
this.style.width ?
(parseInt(this.style.width) - 26) + 'px' :
'150px'
this.self.style.maxHeight =
this.style.maxHeight ?
(parseInt(this.style.maxHeight) - 26) + 'px' :
'300px'
var w = getRealLeft(this.picker) + (parseInt(this.style.left) || 0)
var h = getRealTop(this.picker) + this.picker.offsetHeight + (parseInt(this.style.top) || 0)
var realWidth = parseInt(this.self.style.width) + 26 // 26 = dobule(padding + border)
if (this.style.initPos === 'right') {
w = w - realWidth + this.picker.offsetWidth
}
this.self.style.top = h + 'px'
this.self.style.left = w + 'px'
}
DropMeun.prototype.bindEvent = function() {
var
_this = this,
iEvent = this.picker.nodeName.toUpperCase() !== 'INPUT' ?
'click' :
this.picker.type.toUpperCase() === 'TEXT' ?
'focus' : 'click'
this.picker.addEventListener('click', function(ev) {
var ev = ev || window.ev
ev.stopPropagation()
})
//
this.picker.addEventListener(iEvent, function(ev) {
document.body.click() // 触发 window.click 使其他dropMeun关闭
_this.self.style.display = 'block'
})
//
window.addEventListener('click', function() {
_this.self.style.display = 'none'
})
//
this.self.addEventListener('click', function(ev) {
var ev = ev || window.ev
ev.stopPropagation()
// 事件委托 item点击
if (ev.target.classList.contains('dropMeun-item')) {
var index = parseInt(ev.target.getAttribute('data-index'))
data = _this.option.dataSrc ?
_this.dataList[index][_this.option.dataSrc] :
_this.dataList[index]
if (iEvent === 'focus') {
_this.picker.value = ev.target.innerText
}
if (_this.item.callbakc) {
_this.item.callbakc(data, _this.picker, _this.dataList[index], _this.dataList)
}
_this.self.style.display = 'none'
}
})
//
if (_this.option.ableSearch) {
_this.searchInput = _this.self.getElementsByClassName('dropMeun-searchInput')[0]
_this.searchInput.addEventListener('keyup', function() {
var target = this.value.trim(),
items = _this.self.getElementsByClassName('dropMeun-item');
[].slice.call(items).forEach(function(item, index) {
item.style.display =
item.innerText.indexOf(target) === -1 ?
'none' : ''
})
})
}
}
return DropMeun
}())
4.在页面中引用一个css文件
ul,
li {
list-style: none;
margin: 0;
padding: 0;
}
.dropMeun {
position: absolute;
border: 1px solid #ccc;
overflow: auto;
padding: 8px 12px;
box-shadow: 0 6px 12px rgba(0, 0, 0, .175);
background-color: #fff;
border-bottom-left-radius: 4px;
border-bottom-right-radius: 4px;
box-sizing: content-box;
display: none;
}
.dropMeun li.dropMeun-item {
min-width: 150px;
padding: 2px 2px;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.dropMeun li.dropMeun-item:hover {
cursor: pointer;
background-color: rgba(238, 238, 238, 0.8);
}
.dropMeun-searchInput {
outline: none;
width: 100%;
box-sizing: border-box;
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# js
# 下拉菜单
# dropMenu
# 详解JS前端使用迭代器和生成器原理及示例
# JavaScript前端迭代器Iterator与生成器Generator讲解
# Javascript生成器(Generator)的介绍与使用
# 使用Node.js写一个代码生成器的方法步骤
# JavaScript实现随机数生成器(去重)
# JavaScript生成器函数Generator Functions优缺点特性详解
# 的是
# 你要
# 使其
# 可选
# 大家分享
# 具体内容
# 大家多多
# 到哪里
# maxHeight
# pointer
# left
# top
# initPos
# true
# partyLabel
# menuID
# data
# json
# success
# ableSearch
相关文章:
武清网站制作公司,天津武清个人营业执照注销查询系统网站?
如何在IIS7上新建站点并设置安全权限?
建站之星官网登录失败?如何快速解决?
如何选择高效便捷的WAP商城建站系统?
学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?
如何在阿里云完成域名注册与建站?
如何快速搭建高效可靠的建站解决方案?
制作企业网站建设方案,怎样建设一个公司网站?
实例解析angularjs的filter过滤器
如何在万网自助建站平台快速创建网站?
青岛网站建设如何选择本地服务器?
建站之星与建站宝盒如何选择最佳方案?
定制建站价位费用解析与套餐推荐全攻略
高配服务器限时抢购:企业级配置与回收服务一站式优惠方案
在线教育网站制作平台,山西立德教育官网?
高性能网站服务器部署指南:稳定运行与安全配置优化方案
高防服务器租用指南:配置选择与快速部署攻略
新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?
建站主机功能解析:服务器选择与快速搭建指南
单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?
专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?
制作公司内部网站有哪些,内网如何建网站?
建站之星在线客服如何快速接入解答?
香港服务器部署网站为何提示未备案?
一键网站制作软件,义乌购一件代发流程?
上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?
再谈Python中的字符串与字符编码(推荐)
如何通过主机屋免费建站教程十分钟搭建网站?
济南企业网站制作公司,济南社保单位网上缴费步骤?
较简单的网站制作软件有哪些,手机版网页制作用什么软件?
,怎么在广州志愿者网站注册?
如何快速重置建站主机并恢复默认配置?
,如何利用word制作宣传手册?
平台云上自助建站如何快速打造专业网站?
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
建站之星如何修改网站生成路径?
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
如何在Windows 2008云服务器安全搭建网站?
如何快速打造个性化非模板自助建站?
非常酷的网站设计制作软件,酷培ai教育官方网站?
如何获取开源自助建站系统免费下载链接?
建站之星IIS配置教程:代码生成技巧与站点搭建指南
如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南
小建面朝正北,A点实际方位是否存在偏差?
如何高效完成自助建站业务培训?
建站之星客服服务时间及联系方式如何?
电脑免费海报制作网站推荐,招聘海报哪个网站多?
企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?
如何在腾讯云服务器快速搭建个人网站?
网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?
*请认真填写需求信息,我们会在24小时内与您取得联系。