CSS下拉菜单

例子:

鼠标移动到按钮上打开下拉菜单。(在这里我将下拉菜单的内容的链接设置为百度首页)

 

 

 

 

 

HTML 部分:

制作下拉菜单可以使用任何的 HTML元素来打开下拉菜单,如:<span>, 或 <button> 元素。

使用容器元素 (如: <div>) 来创建下拉菜单的内容,并放在任何你想放的位置上。

使用 <div> 元素来包裹这些元素,并使用 CSS 来设置下拉内容的样式。

CSS 部分:

.dropdown 类使用 position:relative, 这将设置下拉菜单的内容放置在下拉按钮 (使用 position:absolute) 的右下角位置。

.dropdown-content 类中是实际的下拉菜单。默认是隐藏的,在鼠标移动到指定元素后会显示。注: 如果你想设置下拉内容与下拉按钮的宽度一致,可设置 width 为 100% 。

使用 box-shadow 属性让下拉菜单看起来像一个"卡片",更有立体感。

:hover 选择器用于在用户将鼠标移动到下拉按钮上时显示下拉菜单。

 

 1 <style>
 2 /* 下拉按钮样式 */
 3 .dropbtn {
 4     background-color: #4CAF50;
 5     color: white;
 6     padding: 16px;
 7     font-size: 16px;
 8     border: none;
 9     cursor: pointer;
10 }
11 
12 /* 容器 <div> - 定位下拉内容 */
13 .dropdown {
14     position: relative;
15     display: inline-block;
16 }
17 
18 /* 下拉内容 */
19 .dropdown-content {
20     display: none;       /*将下拉内容设置为默认隐藏*/
21     position: absolute;
22     background-color: #f9f9f9;
23     min-width: 160px;
24     box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
25 }
26 
27 /* 下拉菜单的链接 */
28 .dropdown-content a {
29     color: black;
30     padding: 12px 16px;
31     text-decoration: none;
32     display: block;
33 }
34 
35 /* 鼠标移上去后修改下拉菜单链接颜色 */
36 .dropdown-content a:hover {background-color: #f1f1f1}
37 
38 /* 在鼠标移上去后显示下拉菜单 */
39 .dropdown:hover .dropdown-content {
40     display: block;
41 }
42 
43 /* 当下拉内容显示后修改下拉按钮的背景颜色 */
44 .dropdown:hover .dropbtn {
45     background-color: #3e8e41;
46 }
47 </style>
48 
49 <div class="dropdown">
50     <button class="dropbtn">下拉菜单</button>
51         <div class="dropdown-content">
52             <a href="http://www.baidu.com">菜单内容 1</a> 
53             <a href="http://www.baidu.com">菜单内容 2</a> 
54             <a href="http://www.baidu.com">菜单内容 3</a>
55         </div>
56 </div>

效果图:

 

还可以将下拉内容设置为图片,起到一个类似于图片放大的效果。

 

 1 <style>
 2 .dropdown {
 3     position: relative;
 4     display: inline-block;
 5 }
 6 
 7 .dropdown-content {
 8     display: none;
 9     position: absolute;
10     background-color: #f9f9f9;
11     min-width: 160px;
12     box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
13 }
14 
15 .dropdown:hover .dropdown-content {
16     display: block;
17 }
18 
19 .desc {
20     padding: 15px;
21     text-align: center;
22 }
23 </style>
24 </head>
25 <body>
26 
27 <h2>下拉图片</h2>
28 <p>移动鼠标到图片上显示下拉内容。</p>
29 
30 <div class="dropdown">
31   <img src="https://ss1.bdstatic.com/70cFvXSh_Q1YnxGkpoWK1HF6hhy/it/u=1466689081,2386523910&fm=23&gp=0.jpg" alt="Trolltunga Norway" width="100" height="50">
32   <div class="dropdown-content">
33     <img src="https://ss1.bdstatic.com/70cFvXSh_Q1YnxGkpoWK1HF6hhy/it/u=1466689081,2386523910&fm=23&gp=0.jpg" alt="Trolltunga Norway" width="200" height="100">
34     <div class="desc">添加图片描述</div>
35   </div>
36 </div>
View Code

 

 效果图:

 

转载于:https://www.cnblogs.com/ParaDise-LJ/p/6684204.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/269657.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

maven跳过单元测试-maven.test.skip和skipTests的区别

第一种 -Dmaven.test.skiptrue&#xff0c;不执行测试用例&#xff0c;也不编译测试用例类。 一 使用maven.test.skip&#xff0c;不但跳过单元测试的运行&#xff0c;也跳过测试代码的编译。 mvn package -Dmaven.test.skiptrue<plugin> <groupId>org.apache.m…

linux下java命令行参数_Java调用Linux命令行

Java调用Linux命令行Java语言以其跨平台性和简易性而著称&#xff0c;在Java里面的lang包里(java.lang.Runtime)提供了一个允许Java程序与该程序所运行的环境交互的接口&#xff0c;这就是Runtime类&#xff0c;在Runtime类里提供了获取当前运行环境的接口。那么java怎么调用Li…

BZOJ 4810 莫队+bitset

思路&#xff1a; 看完这道题根本没有思路啊.... 然后我就膜拜了一波题解... 这神tm乱搞思路 维护两个bitset 第一个bitset代表当前区间哪些数出现过 第二个bitset是 maxp-p出现过 差为x的时候 就用第一个bitset与一下它右移x就好了 和为x的时候 就第一个bitset与一下第二个bi…

java -p_javap命令详解 - JackieYeah的个人空间 - OSCHINA - 中文开源技术交流社区

一、用法javap [ 选项 ] classes二、描述javap命令反汇编一个或多个类文件。它的输出由使用的选项决定。如果没有使用选项&#xff0c;javap命令将打印输出传递给它的类的包&#xff0c; protected和public属性和方法。javap打印输出到标准输出。选项命令行选项。classes一个或…

初识RPC概念

什么是RPC RPC 全称 Remote Procedure Call——远程过程调用。在学校学编程&#xff0c;我们写一个函数都是在本地调用就行了。但是在互联网公司&#xff0c;服务都是部署在不同服务器上的分布式系统&#xff0c;如何调用呢&#xff1f; RPC技术简单说就是为了解决远程调用服务…

JAVA编码(41)—— 线程池队列执行任务(ThreadPoolQueue)(1)

废话少说&#xff0c;上代码 package com.sinosoft;import java.util.concurrent.*;/*** Created by xushuyi on 2017/4/9.*/ public class ThreadPoolQueue {/*** 定义线程池中最大的线程数量*/private static final Integer THREADPOOLSIZE 100;/*** 创建线程队列*/private …

Dubbo介绍

1:什是Dubbo 2&#xff1a;架构图 3:节点角色说明 4&#xff1a;调用关系说明

一键去除网页BOM属性【解决乱码,头部空白,#65279问题】

几个常出现的问题&#xff1a; 1.网站打开空白 2.页面头部出现多余的空白 3.网站出现乱码&#xff0c;如“锘&#xfffd;” 解决方法可以是&#xff1a; 1.选用专业的编辑器&#xff0c;例如notepad&#xff0c;sublime&#xff0c;editplus这样不会自动签名。 2.sublime通过如…

java 关闭语句_java.sql.SQLRecoverableException: 关闭的语句

数据库连接池配置&#xff1a;数据库链接在运行时报错&#xff1a;Caused by: java.sql.SQLRecoverableException: 关闭的语句at oracle.jdbc.driver.OracleClosedStatement.exitImplicitCacheToActive(OracleClosedStatement.java:4667)at oracle.jdbc.driver.OraclePreparedS…

编程英语学习【转】

一种绝对提高开发水平的方法 目录 一、概要二、常用单词 2.1、初级单词第一节第二节第三节第四节第五节第六节第七节第九节第十节第十一节第十三节第十四节第十五节第十六节第十七节2.2、高级部分三、《Java语言程序设计》书中单词频率排行四、常见异常与错误翻译 4.1、java中4…

下载的java游戏怎么运行不了_java运行环境下载

java运行环境下载对这款游戏感兴趣的玩家可以来我们网站下载试玩。"No," said Elsie, sharply. "Ill quote you a text: Eat, drink, and be merry, and let me alone.""Its not your sex that I am clasping, but you&#xfffd;&#xfffd;YOU, m…

Mac idea使用Command + p 快捷键查看一个类的构造函数需要传入什么参数

Mac idea使用Command p 快捷键查看一个类的构造函数需要传入什么参数 如下图所示

TortoiseGit不同分支合并代码

现在有主分支master和分支day2.现在要把day2上的变更合并到主分支master上&#xff01; 1.首先切换到目标分支master上。 说明当前分支是master分支。 2.在master分支上查看提交记录,即show log一下。 3.切换到源分支上 4.选中你所有的提交&#xff0c;右键&#xff0c;Cherry …

java jdk 类加载机制_JDK源码阅读之类加载

java类加载类的生命周期(类加载过程)LLIUUVPR加载(Loading)链接(Linking)验证(Verification)准备(Preparation)解析(Resolution)初始化(Initialization)使用(Using)卸载(Unloading) 类类加载器种类BootstrapClassLoader&#xff1a;C编写&#xff0c;负责加载java核心类库Launc…

2017.4.11 AM

练恋有词U28单元单词及应用 转载于:https://www.cnblogs.com/bgd140201219/p/6696472.html

JAVA标识符中含小数点可以吗_数值类型小数点后是否可以接零问题

有些情况下&#xff0c;我们需要数据的精准性&#xff0c;小数部分或多或少要保留几位。而恰巧为整数时&#xff0c;我们需要将整数也加上小数点然后接0的形式来表示。js中&#xff0c;我们常使用 input 框绑定数值变量的形式来提供展示或修改数据&#xff0c;那么大家一定会遇…

volatile不具备原子性

1、理解原子性&#xff1a; 上面说到volatile不具备原子性&#xff0c;那么原子性到底是什么呢&#xff1f;先看如下代码 public class TestVolatile {public static void main(String[] args) {AtomicDemo atomicDemo new AtomicDemo();for (int x 0; x < 10; x) {new Th…

Nginx upstream 配置

1、轮询&#xff08;默认&#xff09;每个请求按时间顺序逐一分配到不同的后端服务器&#xff0c;如果后端服务器down掉&#xff0c;能自动剔除。2、weight指定轮询几率&#xff0c;weight和访问比率成正比&#xff0c;用于后端服务器性能不均的情况。例如&#xff1a;upstream…