*新闻详情页*/>
近期写CSS3和js融合,遇到了许多次z-index不起效的状况:
1.在用z-index的情况下,该元素沒有精准定位(static精准定位以外)
2.在有精准定位的状况下,该元素的z-index沒有起效,是由于该元素的子元素后来者居上,盖住了该元素,处理方法:将盖住该元素的子元素的z-index设定为负数
往下拉框事例:
1.盖住的情况下:
2.将往下拉框的z-index设定为负数
编码:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf⑻"> <title>无题目文本文档</title> <style type="text/css"> * { padding: 0; margin: 0; list-style: none; } .all { width: 330px; height: 120px; overflow: hidden; background: url(img/bg.jpg) no-repeat; margin: 100px auto; line-height: 30px; text-align: center; padding-left: 10px; margin-bottom: 0; } .all ul { position: relative; height: 30px; width: 100%; } .all ul li { width: 100px; height: 30px; background: url(img/libg.jpg); float: left; margin-right: 10px; position: relative; cursor: pointer; } .all ul ul { position: absolute; left: 0; top:⑼0px; /*display: none; 是1一瞬间的事*/ transition: all 1s; opacity: 0; /*后来的盒子会盖住前面的盒子,即使前面的盒子z-index再大也会被盖住, 但是能够设定后来的盒子的z-index为负数就可以了*/ z-index:⑴; } .all ul .lvTow { top:⑼0px; opacity: 0; } .all ul .show{ top:30px; opacity: 1; } </style> </head> <body> <div class="all" id="list"> <ul> <li>1级菜单 <ul > <li>2级菜单</li> <li>2级菜单</li> <li>2级菜单</li> </ul> </li> <li>1级菜单 <ul > <li>2级菜单</li> <li>2级菜单</li> <li>2级菜单</li> </ul> </li> <li>1级菜单 <ul > <li>2级菜单</li> <li>2级菜单</li> <li>2级菜单</li> </ul> </li> </ul> </div> </body> </html> <script> // 获得目标 遍历目标实际操作 显示信息控制模块 掩藏控制模块 function List(id) { // 获得目标 this.id = document.getElementById(id); // 取 id 值 this.lis = this.id.children[0].children; // 获得1级菜单全部的li } // init 原始化 List.prototype.init = function() { // 遍历全部的li 显示信息和掩藏 var that = this; for(var i=0;i<this.lis.length;i++) { this.lis[i].index = i; this.lis[i].onmouseover = function() { that.show(this.children[0]); // 显示信息出来 } this.lis[i].onmouseout = function() { that.hide(this.children[0]); // 掩藏起来 } } } // 显示信息控制模块 List.prototype.show = function(obj) { // obj.style.display = "block"; obj.className = "show"; } // 掩藏控制模块 List.prototype.hide = function(obj) { // obj.style.display = "none"; obj.className = "lvTow"; } var list = new List("list"); // 案例化了1个目标 叫 list list.init(); </script>
以上便是本文的所有內容,期待对大伙儿的学习培训有一定的协助,也期待大伙儿多多适用脚本制作之家。
Copyright © 2002-2020 上线了小程序官网_年会抽奖小程序免费_做小程序_小程序网站_跑腿小程序 版权所有 (网站地图) 粤ICP备10235580号