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

相关文章

基于Java和FFmpeg实现视频压缩和剪辑功能

《基于Java和FFmpeg实现视频压缩和剪辑功能》在视频处理开发中,压缩和剪辑是常见的需求,本文将介绍如何使用Java结合FFmpeg实现视频压缩和剪辑功能,同时去除数据库操作,仅专注于视频处理,需... 目录引言1. 环境准备1.1 项目依赖1.2 安装 FFmpeg2. 视频压缩功能实现2.1 主要功

使用Python实现无损放大图片功能

《使用Python实现无损放大图片功能》本文介绍了如何使用Python的Pillow库进行无损图片放大,区分了JPEG和PNG格式在放大过程中的特点,并给出了示例代码,JPEG格式可能受压缩影响,需先... 目录一、什么是无损放大?二、实现方法步骤1:读取图片步骤2:无损放大图片步骤3:保存图片三、示php

深度解析Python yfinance的核心功能和高级用法

《深度解析Pythonyfinance的核心功能和高级用法》yfinance是一个功能强大且易于使用的Python库,用于从YahooFinance获取金融数据,本教程将深入探讨yfinance的核... 目录yfinance 深度解析教程 (python)1. 简介与安装1.1 什么是 yfinance?

Python脚本轻松实现检测麦克风功能

《Python脚本轻松实现检测麦克风功能》在进行音频处理或开发需要使用麦克风的应用程序时,确保麦克风功能正常是非常重要的,本文将介绍一个简单的Python脚本,能够帮助我们检测本地麦克风的功能,需要的... 目录轻松检测麦克风功能脚本介绍一、python环境准备二、代码解析三、使用方法四、知识扩展轻松检测麦

Java实现TXT文件导入功能的详细步骤

《Java实现TXT文件导入功能的详细步骤》在实际开发中,很多应用场景需要将用户上传的TXT文件进行解析,并将文件中的数据导入到数据库或其他存储系统中,本文将演示如何用Java实现一个基本的TXT文件... 目录前言1. 项目需求分析2. 示例文件格式3. 实现步骤3.1. 准备数据库(假设使用 mysql

Springboot项目登录校验功能实现

《Springboot项目登录校验功能实现》本文介绍了Web登录校验的重要性,对比了Cookie、Session和JWT三种会话技术,分析其优缺点,并讲解了过滤器与拦截器的统一拦截方案,推荐使用JWT... 目录引言一、登录校验的基本概念二、HTTP协议的无状态性三、会话跟android踪技术1. Cook

基于Spring Boot 的小区人脸识别与出入记录管理系统功能

《基于SpringBoot的小区人脸识别与出入记录管理系统功能》文章介绍基于SpringBoot框架与百度AI人脸识别API的小区出入管理系统,实现自动识别、记录及查询功能,涵盖技术选型、数据模型... 目录系统功能概述技术栈选择核心依赖配置数据模型设计出入记录实体类出入记录查询表单出入记录 VO 类(用于

Qt中实现多线程导出数据功能的四种方式小结

《Qt中实现多线程导出数据功能的四种方式小结》在以往的项目开发中,在很多地方用到了多线程,本文将记录下在Qt开发中用到的多线程技术实现方法,以导出指定范围的数字到txt文件为例,展示多线程不同的实现方... 目录前言导出文件的示例工具类QThreadQObject的moveToThread方法实现多线程QC

把Python列表中的元素移动到开头的三种方法

《把Python列表中的元素移动到开头的三种方法》在Python编程中,我们经常需要对列表(list)进行操作,有时,我们希望将列表中的某个元素移动到最前面,使其成为第一项,本文给大家介绍了把Pyth... 目录一、查找删除插入法1. 找到元素的索引2. 移除元素3. 插入到列表开头二、使用列表切片(Lis

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的