需求:
实现通过一个弹出对话框来选择下拉列表中对应值进行参数设置操作,及弹出对话框中需要有一个下拉列表输入和一个确定按钮即可,要求弹出对话框后,背部界面不能够操作或者被屏蔽灰掉。
思路:
1.开始以为so so much simple,毫不犹豫考虑prompt弹出对话框,结果发现prompt只能进行简单的文本输入操作,不能进行下拉列表选择输入操作,于是放弃。
2.很多BS模式系统中弹出对话框下拉列表是怎么实现的呢?因为他们可以使用强大的js库,如jquery,ext等等js库中有现成的对话框,功能超级强大哦,但是项目属于嵌入式项目,代码空间如城市里的地盘寸土寸金啊,不能为了一个小小需求而牺牲如此的代码空间去存放js库了,也就不能再考虑下去。
3.继续求助度娘,个人认为度娘在解决web前端问题方面还是很有实力的。发现了一种通用的解决方式,涉及到遮罩层、弹出层等等理论,就不赘述了,直接上解决方案吧。
解决方案:
关键js代码如下,
function createPrompt()
{
var divSp = document.createElement("div"); //弹出对话框
var newMask = document.createElement("div"); //遮罩层,用来屏蔽灰掉背部界面
var btnSub = document.createElement("input"); // 弹出对话框中按钮
var inner;
// 弹出对话框中要呈现的页面元素布局等html代码
inner = '<div class="fieldset" style="height:300px background:#A9A9A9">';
inner += ' <div class="fs-heading" style="background:#D2691E">';
inner += ' <h2>Please set the Time zone when you first login !</h2>';
inner +=