js弹出div层内容(按回退键关闭div层及遮罩)
<!--弹出的div列表对应的详情-->
<div id="newhtml" class="white_content">
<div style="height: 5%;">
<ul class="mui-table-view" id="cd_ul_top">
</ul>
</div>
<div style="top:5%;overflow:auto;height:95%;">
<ul class="mui-table-view" style="height: 100%;" id="cd_ul">
</ul>
</div>
</div>
<!--结合div的遮罩层-->
<div id="fade" class="black_overlay">
</div>
如下是弹出div和遮罩层的样式.初始默认为隐藏.
.black_overlay{
display: none;
position: fixed;
top: 0;
right: 0;
bottom: 0;
left: 0;
z-index: 998;//该属性如果不写,如果div的position属性值为fixed,则会出现遮罩层盖不住的情况
background-color: black;
opacity:.35;
}
.white_content {
display: none;
position: fixed;
top: 40%;
width: 100%;
height: 30px;
background-color: white;
z-index:1002;
text-align: center;
}
mui实例中统计图显示:mychart.setOption();
//使用刚制定的配置和数据显示图表
mychart.setOption(option);
getli(list_dc_id,list_num,list_sum,list_name);
//生成li列表,用mui设置每个li的监听事件,.this.id获取该li标签的动态id,,this.innerHTML查看li标签内的内容(子标签的所有内容).this.outerHTML显示整个li标签的所有内容(包括自己的所有内容)
function getli(list_dc_id,list_num,list_sum,list_name){
var ul_li = document.getElementById('ul_li');
if(list_num==""&&list_sum==""&&list_name==""){
ul_li.innerHTML="";
}else{
var ul_li_html = '<li class="mui-table-view-cell mui-col-xs-12" style="text-align: center;" >'+
'<span class="mui-pull-left"style="width: 33.30%;">姓名</span>'+
'<span style="width: 33.30%;">单数</span>'+
'<span class="mui-pull-right"style="width: 33.30%;">金额</span></li>';
for(var i = 0;i<list_name.length;i++){
var li_html='<li class="mui-table-view-cell mui-col-xs-12" style="text-align: center;"id='+list_dc_id[i]+'>'+
'<span class="mui-pull-left"style="width: 33.30%;">'+list_name[i]+'</span>'+
'<span style="width: 33.30%;">'+list_num[i]+'</span>'+
'<span class="mui-pull-right"style="width: 33.30%;">'+list_sum[i]+'</span></li>';
ul_li_html+=li_html;
}
ul_li.innerHTML=ul_li_html;
}
}
如下图,通过监听li标签,设置div层和遮罩层样式display属性值为block.显示div和遮罩层
//菜单列表ul_li的监听
mui('#ul_li').on('tap','li',function(){
var dc_id = this.id;
if(dc_id==""){
return;
}
//传统ajax的post请求方式
mui.ajax('http://192.168.1.23:8080/YSE/back/queryapp_getFoodSale.action', {
data: {
type: type,
user:dc_id,
date: nd,
token: token
},
dataType: 'json', //服务器返回json格式数据
type: 'post', //HTTP请求类型
success: function(data) {
//服务器返回响应,根据响应结果,分析是否登录成功;
if(data == null) {
mui.toast('服务器连接失败,请重新尝试!!!');
}else if(data==""){
mui.toast('未查询到该点餐数据!!!');
}else if(data == '1') {//成功
}else{
var newData = JSON.stringify(data);//在这里stringfy()的作用是用于将一个对象解析成字符串
var newData2 = eval('('+newData+')');
var newhtml = '<li class="mui-table-view-cell mui-col-xs-12" style=" width:100%; margin-top:0px;text-align: center; color: white;background-color: #1C86EE;z-index:99">'+
'<span class="mui-pull-left"style="width: 33.30%;">菜名</span>'+
'<span style="width: 33.30%;">数量</span>'+
'<span class="mui-pull-right"style="width: 33.30%;">金额</span></li>';
var li_html="";
for(var i = 0;i<newData2.length;i++){
var name = newData2[i].name;
var num = newData2[i].num;
var sum = newData2[i].sum;
li_html += '<li class="mui-table-view-cell mui-col-xs-12" style="text-align: center;">'+
'<span class="mui-pull-left"style="width: 33.30%;">'+name+'</span>'+
'<span style="width: 33.30%;">'+num+'</span>'+
'<span class="mui-pull-right"style="width: 33.30%;">'+sum+'</span></li>';
}
document.getElementById('cd_ul_top').innerHTML = newhtml;
document.getElementById("cd_ul").innerHTML = li_html;
document.getElementById('newhtml').style.display='block';
document.getElementById('fade').style.display='block';
}
},
error: function(xhr, type, errorThrown) {
//异常处理;
console.log(xhr + "," + type + "," + errorThrown);
mui.toast("服务器连接异常!!!");
}
});
});
利用mui框架设置手机回退按键功能.如果div属性为block,点击回退执行操作:设置属性none隐藏div层和遮罩层,否则继续执行回退按键回退webview操作.
第二个为监听点击遮罩层,同样隐藏div层和遮罩层
//回退按钮
var oldBack = mui.back;
mui.back = function(event) {
if(document.getElementById('newhtml').style.display=='block'){
document.getElementById('newhtml').style.display='none';
document.getElementById('fade').style.display='none';
return false;
}else{
oldBack();
}
};
document.getElementById('fade').addEventListener('tap',function(){
document.getElementById('newhtml').style.display='none';
document.getElementById('fade').style.display='none';
})
//弹出层后,设置样式,禁止底部滑动:
主要是设置html和body两个标签的overflow属性:hidden超出部分隐藏.实现不能滑动
.noscroll{
height: 100%;
overflow: hidden;
}
//添加属性class="noscroll",禁止滑动
document.getElementsByTagName('html')[0].className="noscroll";
document.getElementsByTagName('body')[0].className="noscroll";
js弹出div层内容(按回退键关闭div层及遮罩)的更多相关文章
- JS弹出层制作,以及移动端禁止弹出层下内容滚动,overflow:hidden移动端失效问题
HTML <div class="layer"> <div class="menu-list"> <span>社会</ ...
- js弹窗 js弹出DIV,并使整个页面背景变暗
1.首先写一个遮罩层div,然后再写一个弹窗的div <!-- 遮罩层 --> <div id="cover" style="background: # ...
- js弹出层
js弹出层 1.div附近显示 <div id="message"></div> $().delay().hide(); 2.遮罩层 表单提交后遮住页面,等 ...
- 文字添加响应事件,js动态加载CSS, js弹出DIV
文字添加响应事件,js动态加载CSS, js弹出DIV <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN&qu ...
- bootstrap中popover.js(弹出框)使用总结+案例
bootstrap中popover.js(弹出框)使用总结+案例 *转载请注明出处: 作者:willingtolove: http://www.cnblogs.com/willingtolove/p/ ...
- JS弹出浮层
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- js弹出对话框的方法总结
九种js弹出对话框的方法总结,需要的朋友可以参考一下 [1.最基本的js弹出对话框窗口代码] 这是最基本的js弹出对话框,其实代码就几句非常简单: <script LANGUAGE=" ...
- JS弹出下载对话框以及实现常见文件类型的下载
写在前面 JS要实现下载功能,一般都是这么几个过程:生成下载的URL,动态创建一个A标签,并将其href指向生成的URL,然后触发A标签的单击事件,这样就会弹出下载对话框,从而实现了一个下载的功能. ...
- python selenium-webdriver 处理JS弹出对话框(六)
在实际系统中,在完成某些操作时会弹出对话框来提示,主要分为"警告消息框","确认消息框","提示消息对话"三种类型的对话框. 1.警告消息框 ...
随机推荐
- xml布局解析报错的可能原因
xml布局解析报如下的错11-15 16:55:21.425 17633-17633/com.hongfans.mobileconnect I/LogUtils_info: [CrashHandler ...
- Anaconda(python3.6)中使用python2.7
因为我现在安装的是最新版Anaconda3,其自带的Python版本为3.6,如果我们需要添加2.7版本的Python,可以进行如下操作.(同理,如果有人安装的是Anaconda2需要添加Python ...
- CSS实现鼠标悬浮无限向下级展示的简单代码
*{ margin:; padding:; } ul,li{ list-style: none; } .ui-slide-box{ width: 300px; } .ui-slide-item{ wi ...
- Struts2访问web元素的各种方法
1.通过RequestAware,SessionAware,ApplicationAware获取: 在Struts2中不能直接访问Request,Session,Application元素,但是可以使 ...
- 如何在maven项目里面编写mapreduce程序以及一个maven项目里面管理多个mapreduce程序
我们平时创建普通的mapreduce项目,在遍代码当你需要导包使用一些工具类的时候, 你需要自己找到对应的架包,再导进项目里面其实这样做非常不方便,我建议我们还是用maven项目来得方便多了 话不多说 ...
- 新型DenseBody框架:一张照片获得3D人体信息
来自云从科技和上海交通大学的研究者近期提出一种新型框架 DenseBody,可直接从一张彩色照片中获取 3D 人体姿势和形状.该研究设计了一种高效的 3D 人体姿势和形状表示,无需中间表示和任务,端到 ...
- KVM总结-KVM性能优化之磁盘IO优化
前面讲了KVM CPU(http://blog.csdn.net/dylloveyou/article/details/71169463).内存(http://blog.csdn.net/dyllov ...
- nvm use 指定版本后无效 win7
如图所示,nvm install 6.12.3之后,使用命令nvm use 6.12.3,提示切换成功,但是执行node app.js时,报错没有node命令,执行nvm ls查看,发现没有任何版本是 ...
- mybatis基于注解形式的多数据源
最近在做一个系统管理项目,需要使用到多数据源,尝试了注解形式和xml形式的多数据源配置,以下是基于注解形式的Mybatis多数据源配置. 1.application.yml 配置文件 database ...
- mysql千万级数据库插入速度和读取速度的调整记录
一般情况下mysql上百万数据读取和插入更新是没什么问题了,但到了上千万级就会出现很慢,下面我们来看mysql千万级数据库插入速度和读取速度的调整记录吧. 1)提高数据库插入性能中心思想:尽量将数据一 ...