时间:2021-05-26
本文实例为大家分享了下拉菜单生成器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() { 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) } 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;}以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
什么是生成器?生成器是一个包含了特殊关键字yield的函数。当被调用的时候,生成器函数返回一个生成器。可以使用send,throw,close方法让生成器和外界
在表单设计器中创建新表单时,使用“表单生成器”对话框可以把表或视图中的字段快速放到表单中。方法是:选择“表单”菜单中的“快速表单”选项,打开“表单生成器”对话框
4.生成器(generator)4.1.生成器简介首先请确信,生成器就是一种迭代器。生成器拥有next方法并且行为与迭代器完全相同,这意味着生成器也可以用于Py
生成器就是自己用python代码写的迭代器,生成器的本质就是迭代器。通过以下两种方式构建一个生成器:1、通过生成器函数2、生成器表达式生成器函数:函数deffu
使用方法 按钮组和下拉菜单组件一样,需要依赖于button.js插件才能正常运行。不过我们同样可以直接只调用bootstrap.js文件。因为这个文件已集成了