AmazeUI中各种的导航式菜单与解决方法


Posted in HTML / CSS onAugust 19, 2020

与Bootstrap一样,AmazeUI提供的导航式菜单也是喜欢蜷缩在右上角的一个按钮里面,然后一点击就向下拉开一大段距离。这样很不友好。此前《【AmazeUI】手机版页面的顶部导航条Header与侧边导航栏offCanvas》(点击打开链接)是一种解决方案,但是对于一些不使用页面的页面,这种方案则无能无力。

对于此有如下的几种方案可以解决:

一、改造AmazeUI提供的手机端文字横排菜单

AmazeUI提供的手机端文字横排菜单的背景颜色是白色的,字体是蓝色的,没有提供相应的class去改写里面的字体,

我们可以为背景与文字添加一个css,改写其背景与文字颜色

效果如下:

AmazeUI中各种的导航式菜单与解决方法 

代码如下:

<h1>导航菜单-横排文字式</h1>
        <style>
            /*这里是改写文字的颜色*/
            .am-menu-default .am-menu-nav a {
                color:#222;
            }
            /*这里是改写背景的颜色*/
            .am-menu-nav{
                background:#f1f1f1;
            }
        </style>
        <div data-am-widget="menu" class="am-menu  am-menu-default" >
            <a href="javascript: void(0)" class="am-menu-toggle a-in-menu"><i class="am-menu-toggle-icon am-icon-bars"></i></a>
            <!--表示每一个菜单都占3格,也就是在12格1行的布局中占据4格的位置-->
            <ul class="am-menu-nav am-avg-sm-3">
                <!--表示这个项目带下拉菜单-->
                <li class="am-parent">
                    <a href="#">项目1</a>
                    <ul class="am-menu-sub am-collapse am-avg-sm-4">
                        <li><a href="#">项目1-1</a></li>
                        <li><a href="#">项目1-2</a></li>
                        <li><a href="#">项目1-3</a></li>
                        <li><a href="#">项目1-4</a></li>
                        <li><a href="#">项目1-5</a></li>
                        <li><a href="#">项目1-6</a></li>
                    </ul>
                </li>
                <li><a href="#">项目2</a></li>
                <li><a href="#">项目3</a></li>
                <li><a href="#">项目4</a></li>
                <li class="am-parent">
                    <a href="#">项目5</a>
                    <ul class="am-menu-sub am-collapse am-avg-sm-4">
                        <li><a href="#">项目5-1</a></li>
                        <li><a href="#">项目5-2</a></li>
                        <li><a href="#">项目5-3</a></li>
                        <li><a href="#">项目5-4</a></li>
                        <li><a href="#">项目5-5</a></li>
                        <li><a href="#">项目5-6</a></li>
                    </ul>
                </li>
    
            </ul>
        </div>

 二、利用按钮组与下拉按钮

这里运用了解决Bootstrap导航栏的思想,《【Bootstrap】导航栏navbar在IE8上的缺陷与解决方案》(点击打开链接),但是AmazeUI的按钮组与下拉按钮的复合相当不给力。没有提供下拉按钮与按钮复合的按钮组。同时,其栅格化布局也无法约束其下拉按钮的大小,因此,必须自己整几个div,调节其width与margin属性,规范其大小。

效果如下:

AmazeUI中各种的导航式菜单与解决方法

代码如下:

<h1>导航菜单-下拉列表式</h1>
        <style>
            /*让每一个下拉按钮占据的宽度与居中*/
            .am-dropdown{
                width:30%;
                text-align:center;
            }
        </style>
        <!--这里表示一行-->
        <div style="text-align:center; width:100%; margin-left:-1.5%">
            <div class="am-dropdown" data-am-dropdown>
                <button class="am-btn am-btn-primary am-dropdown-toggle" data-am-dropdown-toggle style="width:110%;" >项目1<span class="am-icon-caret-down"></span></button>
                <ul class="am-dropdown-content">
                    <li><a href="#">项目1-1</a></li>
                    <li><a href="#">项目1-2</a></li>
                    <li class="am-divider"></li>
                    <li><a href="#">项目1-3</a></li>
                </ul>
            </div>
            <div class="am-dropdown" data-am-dropdown >
                <button type="button" class="am-btn am-btn-primary" style="width:110%;" onClick="javascript:window.location.href='#'">项目2</button>        
            </div>
            <div class="am-dropdown" data-am-dropdown>
                <button class="am-btn am-btn-primary am-dropdown-toggle" data-am-dropdown-toggle style="width:110%;" >项目3<span class="am-icon-caret-down"></span></button>
                <ul class="am-dropdown-content">
                    <li><a href="#">项目3-1</a></li>
                    <li class="am-divider"></li>
                    <li><a href="#">项目3-2</a></li>
                    <li><a href="#">项目3-3</a></li>
                    <li><a href="#">项目3-4</a></li>
                </ul>
            </div>
        </div>
        <!--搞完一行,必须自己再开一行-->
        <div style="text-align:center; width:100%; margin-left:-1.5%">
            <div class="am-dropdown" data-am-dropdown>    
                <button type="button" class="am-btn am-btn-primary" style="width:110%;" onClick="javascript:window.location.href='#'">项目4</button>
            </div>
            <div class="am-dropdown" data-am-dropdown >
                <button class="am-btn am-btn-primary am-dropdown-toggle" data-am-dropdown-toggle style="width:110%;" >项目5<span class="am-icon-caret-down"></span></button>
                <ul class="am-dropdown-content">
                    <li><a href="#">项目5-1</a></li>                
                    <li><a href="#">项目5-2</a></li>
                    <li class="am-divider"></li>
                    <li><a href="#">项目5-3</a></li>
                    <li><a href="#">项目5-4</a></li>
                </ul>
            </div>
            <div class="am-dropdown" data-am-dropdown>    
                <button type="button" class="am-btn am-btn-primary" style="width:110%;" onClick="javascript:window.location.href='#'">项目6</button>
            </div>
        </div>

这里,每一行最好放置3个组件就好,设置css为text-align:center,还要补上一个margin-left:-1.5%才刚好其居中,width:100%占据一行。

其下的各个div占据30%的宽度。接着的各个按钮、下拉按钮其宽度必须是110%,这样才能刚刚配合好原来的样式,把按钮与下拉按钮符合起来。

其中,里面的li class="am-divider"意为分割线。

三、利用无下拉项目的标签页

其实手机里面的导航真的无须使用下拉项目。下拉菜单在手机屏幕上是很难点的。直接利用标签页设置一个导航。代码也短,用户也不会不满意。关键是AmazeUI本来就提供这种布局。然后,你再于这个页面里面布置二级导航也可以。

效果如下:

AmazeUI中各种的导航式菜单与解决方法

代码如下:

<h1>导航菜单-标签页布局</h1>
        <div data-am-widget="tabs" class="am-tabs am-tabs-d2">
            <ul class="am-tabs-nav">
                <li class="am-active"><a href="#">项目1</a></li>
                <li><a href="#">项目2</a></li>
                <li><a href="#">项目3</a></li>
                <li><a href="#">项目4</a></li>
            </ul>
            <ul class="am-tabs-nav">
                <li><a href="#">项目5</a></li>
                <li><a href="#">项目6</a></li>
                <li><a href="#">项目7</a></li>
            </ul>
        </div>

同时,AmazeUI也提供另一种风格的标签页布局,效果如下:

AmazeUI中各种的导航式菜单与解决方法

代码如下:

<h1>导航菜单-标签页极简布局</h1>
        <div data-am-widget="tabs" class="am-tabs am-tabs-default">
            <ul class="am-tabs-nav">
                <li><a href="#">项目1</a></li>
                <li><a href="#">项目2</a></li>
                <li class="am-active"><a href="#">项目3</a></li>
            </ul>
            <ul class="am-tabs-nav">
                <li><a href="#">项目4</a></li>
                <li><a href="#">项目5</a></li>
                <li><a href="#">项目6</a></li>
            </ul>
        </div>

最后贴一下整个页面的效果图与代码:

AmazeUI中各种的导航式菜单与解决方法

<!--使用HTML5开发-->
<!doctype html>
<html class="no-js">
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <!--自动适应移动屏幕-->
        <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
        <!--优先使用webkit内核渲染-->
        <meta name="renderer" content="webkit">
        <!--不要被百度转码-->
        <meta http-equiv="Cache-Control" content="no-siteapp"/>
        <!--以下才是引入amazeui资源-->
        <link rel="stylesheet" href="assets/css/amazeui.min.css">
        <link rel="stylesheet" href="assets/css/app.css">
        <!--引入js的时候要注意,必须先引入jQuery,再引入amazeui,因为这个框架是基于jQuery开发的-->
        <script src="assets/js/jquery.min.js"></script>
        <script src="assets/js/amazeui.min.js"></script>
        <title>导航菜单</title>
    </head>  
    <body>    
        <h1>导航菜单-横排文字式</h1>
        <style>
            /*这里是改写文字的颜色*/
            .am-menu-default .am-menu-nav a {
                color:#222;
            }
            /*这里是改写背景的颜色*/
            .am-menu-nav{
                background:#f1f1f1;
            }
        </style>
        <div data-am-widget="menu" class="am-menu  am-menu-default" >
            <a href="javascript: void(0)" class="am-menu-toggle a-in-menu"><i class="am-menu-toggle-icon am-icon-bars"></i></a>
            <!--表示每一个菜单都占3格,也就是在12格1行的布局中占据4格的位置-->
            <ul class="am-menu-nav am-avg-sm-3">
                <!--表示这个项目带下拉菜单-->
                <li class="am-parent">
                    <a href="#">项目1</a>
                    <ul class="am-menu-sub am-collapse am-avg-sm-4">
                        <li><a href="#">项目1-1</a></li>
                        <li><a href="#">项目1-2</a></li>
                        <li><a href="#">项目1-3</a></li>
                        <li><a href="#">项目1-4</a></li>
                        <li><a href="#">项目1-5</a></li>
                        <li><a href="#">项目1-6</a></li>
                    </ul>
                </li>
                <li><a href="#">项目2</a></li>
                <li><a href="#">项目3</a></li>
                <li><a href="#">项目4</a></li>
                <li class="am-parent">
                    <a href="#">项目5</a>
                    <ul class="am-menu-sub am-collapse am-avg-sm-4">
                        <li><a href="#">项目5-1</a></li>
                        <li><a href="#">项目5-2</a></li>
                        <li><a href="#">项目5-3</a></li>
                        <li><a href="#">项目5-4</a></li>
                        <li><a href="#">项目5-5</a></li>
                        <li><a href="#">项目5-6</a></li>
                    </ul>
                </li>
    
            </ul>
        </div>
        
        <h1>导航菜单-下拉列表式</h1>
        <style>
            /*让每一个下拉按钮占据的宽度与居中*/
            .am-dropdown{
                width:30%;
                text-align:center;
            }
        </style>
        <!--这里表示一行-->
        <div style="text-align:center; width:100%; margin-left:-1.5%">
            <div class="am-dropdown" data-am-dropdown>
                <button class="am-btn am-btn-primary am-dropdown-toggle" data-am-dropdown-toggle style="width:110%;" >项目1<span class="am-icon-caret-down"></span></button>
                <ul class="am-dropdown-content">
                    <li><a href="#">项目1-1</a></li>
                    <li><a href="#">项目1-2</a></li>
                    <li class="am-divider"></li>
                    <li><a href="#">项目1-3</a></li>
                </ul>
            </div>
            <div class="am-dropdown" data-am-dropdown >
                <button type="button" class="am-btn am-btn-primary" style="width:110%;" onClick="javascript:window.location.href='#'">项目2</button>        
            </div>
            <div class="am-dropdown" data-am-dropdown>
                <button class="am-btn am-btn-primary am-dropdown-toggle" data-am-dropdown-toggle style="width:110%;" >项目3<span class="am-icon-caret-down"></span></button>
                <ul class="am-dropdown-content">
                    <li><a href="#">项目3-1</a></li>
                    <li class="am-divider"></li>
                    <li><a href="#">项目3-2</a></li>
                    <li><a href="#">项目3-3</a></li>
                    <li><a href="#">项目3-4</a></li>
                </ul>
            </div>
        </div>
        <!--搞完一行,必须自己再开一行-->
        <div style="text-align:center; width:100%; margin-left:-1.5%">
            <div class="am-dropdown" data-am-dropdown>    
                <button type="button" class="am-btn am-btn-primary" style="width:110%;" onClick="javascript:window.location.href='#'">项目4</button>
            </div>
            <div class="am-dropdown" data-am-dropdown >
                <button class="am-btn am-btn-primary am-dropdown-toggle" data-am-dropdown-toggle style="width:110%;" >项目5<span class="am-icon-caret-down"></span></button>
                <ul class="am-dropdown-content">
                    <li><a href="#">项目5-1</a></li>                
                    <li><a href="#">项目5-2</a></li>
                    <li class="am-divider"></li>
                    <li><a href="#">项目5-3</a></li>
                    <li><a href="#">项目5-4</a></li>
                </ul>
            </div>
            <div class="am-dropdown" data-am-dropdown>    
                <button type="button" class="am-btn am-btn-primary" style="width:110%;" onClick="javascript:window.location.href='#'">项目6</button>
            </div>
        </div>
        
        <h1>导航菜单-标签页布局</h1>
        <div data-am-widget="tabs" class="am-tabs am-tabs-d2">
            <ul class="am-tabs-nav">
                <li class="am-active"><a href="#">项目1</a></li>
                <li><a href="#">项目2</a></li>
                <li><a href="#">项目3</a></li>
                <li><a href="#">项目4</a></li>
            </ul>
            <ul class="am-tabs-nav">
                <li><a href="#">项目5</a></li>
                <li><a href="#">项目6</a></li>
                <li><a href="#">项目7</a></li>
            </ul>
        </div>
        
        <h1>导航菜单-标签页极简布局</h1>
        <div data-am-widget="tabs" class="am-tabs am-tabs-default">
            <ul class="am-tabs-nav">
                <li><a href="#">项目1</a></li>
                <li><a href="#">项目2</a></li>
                <li class="am-active"><a href="#">项目3</a></li>
            </ul>
            <ul class="am-tabs-nav">
                <li><a href="#">项目4</a></li>
                <li><a href="#">项目5</a></li>
                <li><a href="#">项目6</a></li>
            </ul>
        </div>
        
    </body>
</html>

到此这篇关于AmazeUI中各种的导航式菜单与解决方法的文章就介绍到这了,更多相关AmazeUI导航式菜单内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

HTML / CSS 相关文章推荐
CSS3系列教程:背景图片(背景大小和多背景图) 应用说明
Dec 19 HTML / CSS
CSS3对背景图片的裁剪及尺寸和位置的设定方法
Mar 07 HTML / CSS
使用CSS3中的calc()属性来以算式表达尺寸数值
Jun 06 HTML / CSS
CSS3中Transition动画属性用法详解
Jul 04 HTML / CSS
CSS3 @keyframes简单动画实现
Feb 24 HTML / CSS
HTML5实现QQ聊天气泡效果
Jun 26 HTML / CSS
把富文本的回车转为br标签
Aug 09 HTML / CSS
html5 canvas-1.canvas介绍(hello canvas)
Jan 07 HTML / CSS
HTML页面中添加Canvas标签示例
Jan 01 HTML / CSS
HTML5 canvas实现移动端上传头像拖拽裁剪效果
Mar 14 HTML / CSS
Canvas引入跨域的图片导致toDataURL()报错的问题的解决
Sep 19 HTML / CSS
如何使用canvas绘制可移动网格的示例代码
Dec 14 HTML / CSS
AmazeUI 手机版页面的顶部导航条Header与侧边导航栏offCanvas的示例代码
Aug 19 #HTML / CSS
AmazeUI 缩略图的实现示例
Aug 18 #HTML / CSS
AmazeUI 单选框和多选框的实现示例
Aug 18 #HTML / CSS
amazeui时间组件的实现示例
Aug 18 #HTML / CSS
AmazeUI 模态窗口的实现代码
Aug 18 #HTML / CSS
AmazeUI底部导航栏与分享按钮的示例代码
Aug 18 #HTML / CSS
wordpress添加Html5的表单验证required方法小结
Aug 18 #HTML / CSS
You might like
PHP使用自定义方法实现数组合并示例
2016/07/07 PHP
JS多物体 任意值 链式 缓冲运动
2012/08/10 Javascript
ExtJS中文乱码之GBK格式编码解决方案及代码
2013/01/20 Javascript
jquery实现的随机多彩tag标签随机颜色和字号大小效果
2014/03/27 Javascript
关于JavaScript命名空间的一些心得
2014/06/07 Javascript
原生javaScript实现图片延时加载的方法
2014/12/22 Javascript
Ajax 加载数据 练习代码
2017/01/05 Javascript
vue.js使用v-model指令实现的数据双向绑定功能示例
2018/05/22 Javascript
详解Vue-cli中的静态资源管理(src/assets和static/的区别)
2018/06/19 Javascript
bootstrap select2插件用ajax来获取和显示数据的实例
2018/08/09 Javascript
angular1.x ui-route传参的三种写法小结
2018/08/31 Javascript
详解关于element级联选择器数据回显问题
2019/02/20 Javascript
vue 父组件给子组件传值子组件给父组件传值的实例代码
2019/04/15 Javascript
vue 弹窗时 监听手机返回键关闭弹窗功能(页面不跳转)
2019/05/10 Javascript
[02:08:58]2014 DOTA2国际邀请赛中国区预选赛 Ne VS CIS
2014/05/22 DOTA
[36:43]NB vs Optic 2018国际邀请赛小组赛BO1 B组加赛 8.19
2018/08/21 DOTA
python正则表达式匹配不包含某几个字符的字符串方法
2019/07/23 Python
简单了解python协程的相关知识
2019/08/31 Python
Python实现字符串中某个字母的替代功能
2019/10/21 Python
Python爬取豆瓣视频信息代码实例
2019/11/16 Python
Python时间差中seconds和total_seconds的区别详解
2019/12/26 Python
Java Unsafe类实现原理及测试代码
2020/09/15 Python
StubHub意大利:购买和出售全球演唱会和体育赛事门票
2017/11/21 全球购物
英国领先的在线旅游和休闲零售商:lastminute.com
2019/01/23 全球购物
药剂专业自荐信范文
2014/04/16 职场文书
环保倡议书300字
2014/05/15 职场文书
学党史心得体会
2014/09/05 职场文书
优秀党员先进材料
2014/12/18 职场文书
我的生日感言
2015/08/03 职场文书
使用Pytorch训练two-head网络的操作
2021/05/28 Python
Python 实现绘制子图及子图刻度的变换等问题
2021/05/31 Python
一文搞懂redux在react中的初步用法
2021/06/09 Javascript
世界无敌的ICOM IC-R9500宽频接收机
2022/03/25 无线电
详解Vue3使用axios的配置教程
2022/04/29 Vue.js
如何使用注解方式实现 Redis 分布式锁
2022/07/23 Redis
详解MySQL的内连接和外连接
2023/05/08 MySQL