php手机端底部导航演示,DUX主题修改移动端增加底部导航功能

2024-03-05 12:30

本文主要是介绍php手机端底部导航演示,DUX主题修改移动端增加底部导航功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

重要:本文最后更新于2020-04-29 08:28:43,某些文章具有时效性,若有错误或已失效,请在下方留言或联系代码狗。

有人跟我说他很喜欢网站在移动端浏览的时候,能像APP一样有个底部导航,这样做移动端用户体验会好很多,让我发一篇给DUX加个移动端底部导航功能的教程。正好之前仿themebetter的官网,做过这个功能,把代码扒出来,送给大家了。

e173f7a67531a93c3a5bc5b9e28d352d.png

DUX主题移动端增加底部导航功能修改

操作步骤

注册菜单

此功能是通过wordpress自带的菜单功能实现的,方便大家在后台修改底部导航内容。

打开functions.php文件,注意:不同主题存放函数集合文件有所不同,DUX主题请打开function-theme.php,DMD主题也是一样。

搜索函数register_nav_menus,增加一个菜单,如下所示,新增的是移动底部导航,就是那一句。

// 注册菜单 https://www.daimadog.com/6247.html

if (function_exists('register_nav_menus')){

register_nav_menus( array(

'nav' => __('网站导航', 'haoui'),

'topmenu' => __('顶部菜单', 'haoui'),

'pagenav' => __('页面左侧导航', 'haoui'),

'mobilenav' => __('移动底部导航', 'haoui')

));

}

增加主题设置

DUX的主题设置是基于option framework框架的,在其配置文件options.php中,加入一个新的配置项信息。

//添加配置项 https://www.daimadog.com/6247.html

$options[] = array(

'name' => '开启移动端底部导航',

'id' => 'is_mobile_menu',

'type' => "checkbox",

'std' => false,

'desc' => '开启后需要到菜单中设置移动底部导航内容!');

新增CSS样式

此样式需要全站加载,所以加在哪里自行决定,这里演示使用DUX的css文件夹中的main.css。在其末尾加入如下样式。

/**底部导航样式 https://www.daimadog.com/6247.html**/

.m-menubar {

display: none;

z-index: 9990;

position: fixed;

bottom: 0;

left: 0;

right: 0;

height: 60px;

background-color: #fff

}

.m-menubar:before {

content: '1';

color: transparent;

position: absolute;

left: 0;

top: 0;

width: 100%;

height: 1px;

background-color: rgba(0, 0, 0, 0.1);

display: block;

overflow: hidden;

-webkit-transform-origin: 50% 0;

transform-origin: 50% 0;

-webkit-transform: scaleY(0.5);

transform: scaleY(0.5)

}

.m-menubar ul {

display: flex;

text-align: center

}

.m-menubar li {

flex: 1;

text-align: center;

font-size: 11px

}

.m-menubar li .iconfont {

margin-bottom: 3px;

display: block;

font-size: 22px;

font-weight: normal

}

.m-menubar li a {

display: block;

height: 60px;

padding-top: 12px;

color: #657fa2

}

.m-menubar li.active a {

color: #01CDB8

}

.m-menubar li.active a .iconfont {

color: #01CDB8

}

@media (max-width: 1024px) {

.moblemenu {

padding-bottom: 60px !important;

}

.m-menubar {

display: block

}

}

添加导航结构函数

此函数控制后台菜单设置的内容输出结构,不喜欢可以自行修改,不清楚可以查看WordPress自定义导航菜单处理类Walker

打开function-theme.php,添加如下内容:

//移动底部导航菜单类 https://www.daimadog.com/6247.html

class Mobile_Menu_Walker extends Walker_Nav_Menu

{

public function start_lvl(&$output, $depth = 0, $args = array())

{

$output .= "";

}

public function end_lvl(&$output, $depth = 0, $args = array())

{

$output .= "";

}

public function start_el(&$output, $item, $depth = 0, $args = array(), $id = 0)

{

$is_current_item = '';

if (in_array('current-menu-item', $item->classes)) {

$is_current_item = 'active';

}

if ($item->url == '/login') {

if (is_user_logged_in()) {

$url = '/member';

} else {

$url = '/login';

}

} else {

$url = $item->url;

}

$output .= '

' . $item->title . '';

}

public function end_el(&$output, $item, $depth = 0, $args = array(), $id = 0)

{

$output .= '

';

}

}

//移动菜单

function mobile_the_menu($location = 'mobilenav')

{

echo wp_nav_menu(array('theme_location' => $location,

'container' => '',

'container_class' => '',

'items_wrap' => '

  • %3$s
',

'echo' => false,

'walker' => new Mobile_Menu_Walker()));

}

为页面添加样式

打开functions-theme.php文件,修改代码。

搜索_bodyclass函数,在很多if结构代码中,添加一个if结构,代码如下:

//php控制样式 https://www.daimadog.com/6247.html

if(_hui('is_mobile_menu')){

$class .=' moblemenu';

}

添加代码输出

修改footer.php文件,在

这篇关于php手机端底部导航演示,DUX主题修改移动端增加底部导航功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/776514

相关文章

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

SpringBoot实现微信小程序支付功能

《SpringBoot实现微信小程序支付功能》小程序支付功能已成为众多应用的核心需求之一,本文主要介绍了SpringBoot实现微信小程序支付功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录一、引言二、准备工作(一)微信支付商户平台配置(二)Spring Boot项目搭建(三)配置文件

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

Spring Boot项目中结合MyBatis实现MySQL的自动主从切换功能

《SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能》:本文主要介绍SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能,本文分步骤给大家介绍的... 目录原理解析1. mysql主从复制(Master-Slave Replication)2. 读写分离3.

Mybatis 传参与排序模糊查询功能实现

《Mybatis传参与排序模糊查询功能实现》:本文主要介绍Mybatis传参与排序模糊查询功能实现,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、#{ }和${ }传参的区别二、排序三、like查询四、数据库连接池五、mysql 开发企业规范一、#{ }和${ }传参的

Docker镜像修改hosts及dockerfile修改hosts文件的实现方式

《Docker镜像修改hosts及dockerfile修改hosts文件的实现方式》:本文主要介绍Docker镜像修改hosts及dockerfile修改hosts文件的实现方式,具有很好的参考价... 目录docker镜像修改hosts及dockerfile修改hosts文件准备 dockerfile 文

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优