`

wordpress后台添加多套style文件切换 style switcher

阅读更多

项目需求:

1.添加多套style文件不定期 切换风格

2.后台方便切换管理

 

插件实现

步骤1.

在当前的主题文件下找到functions.php文件 没有的话自己写一个

copy如下代码到文件

$themename = "My theme";
$shortname = "MT";
$options = array (
array( "name" => "Style Sheet",
	"desc" => "Enter the Style Sheet you would like to use for Sweet Ass Theme",
	"id" => $shortname."_style_sheet",
	"type" => "select",
	"options" => array("default", "green", "blue", "yellow"), 
	"std" => "default"),
);

//presentation//

function mytheme_add_admin() {
 
global $themename, $shortname, $options;
 
if ( $_GET['page'] == basename(__FILE__) ) {
 
if ( 'save' == $_REQUEST['action'] ) {
 
foreach ($options as $value) {
update_option( $value['id'], $_REQUEST[ $value['id'] ] ); }
 
foreach ($options as $value) {
if( isset( $_REQUEST[ $value['id'] ] ) ) { update_option( $value['id'], $_REQUEST[ $value['id'] ]  ); } else { delete_option( $value['id'] ); } }
 
header("Location: themes.php?page=functions.php&saved=true");
die;
 
} else if( 'reset' == $_REQUEST['action'] ) {
 
foreach ($options as $value) {
delete_option( $value['id'] ); }
 
header("Location: themes.php?page=functions.php&reset=true");
die;
 
}
}
 
add_theme_page($themename." Options", "".$themename." Options", 'edit_themes', basename(__FILE__), 'mytheme_admin');
 
}
 
function mytheme_admin() {
 
global $themename, $shortname, $options;
 
if ( $_REQUEST['saved'] ) echo '<div id="message" class="updated fade"><p><strong>'.$themename.' settings saved.</strong></p></div>';
if ( $_REQUEST['reset'] ) echo '<div id="message" class="updated fade"><p><strong>'.$themename.' settings reset.</strong></p></div>';
 
?>
<div class="wrap">
<h2><?php echo $themename; ?> Settings</h2>
 
<form method="post">
 
<?php foreach ($options as $value) {
switch ( $value['type'] ) {
 
case "open":
?>
<table width="100%" border="0" style="background-color:#eef5fb; padding:10px;">
 
<?php break;
 
case "close":
?>
 
</table><br />
 
<?php break;
 
case "title":
?>
<table width="100%" border="0" style="background-color:#dceefc; padding:5px 10px;"><tr>
<td valign="top" colspan="2"><h3 style="font-family:Georgia,'Times New Roman',Times,serif;"><?php echo $value['name']; ?></h3></td>
</tr>

<!--custom-->
 
 
<?php break; 
case "sub-title":
?>
<h3 style="font-family:Georgia,'Times New Roman',Times,serif; padding-left:8px;"><?php echo $value['name']; ?></h3> 
<!--end-of-custom-->
 
 
<?php break;
 
case 'text':
?>
 
<tr>
<td valign="top" width="20%" rowspan="2" valign="middle"><strong><?php echo $value['name']; ?></strong></td>
<td width="80%"><input style="width:400px;" name="<?php echo $value['id']; ?>" id="<?php echo $value['id']; ?>" type="<?php echo $value['type']; ?>" value="<?php if ( get_settings( $value['id'] ) != "") { echo get_settings( $value['id'] ); } else { echo $value['std']; } ?>" /></td>
</tr>
 
<tr>
<td><small><?php echo $value['desc']; ?></small></td>
</tr><tr><td colspan="2" style="margin-bottom:5px;border-bottom:1px dotted #000000;">&nbsp;</td></tr><tr><td colspan="2">&nbsp;</td></tr>
 
<?php
break;
 
case 'textarea':
?>
 
<tr>
<td valign="top" width="20%" rowspan="2" valign="middle"><strong><?php echo $value['name']; ?></strong></td>
<td width="80%"><textarea name="<?php echo $value['id']; ?>" style="width:400px; height:200px;" type="<?php echo $value['type']; ?>" cols="" rows=""><?php if ( get_settings( $value['id'] ) != "") { echo get_settings( $value['id'] ); } else { echo $value['std']; } ?></textarea></td>
 
</tr>
 
<tr>
<td><small><?php echo $value['desc']; ?></small></td>
</tr><tr><td colspan="2" style="margin-bottom:5px;border-bottom:1px dotted #000000;">&nbsp;</td></tr><tr><td colspan="2">&nbsp;</td></tr>
 
<?php
break;
 
case 'select':
?>
<tr>
<td width="20%" rowspan="2" valign="middle"><strong><?php echo $value['name']; ?></strong></td>
<td width="80%"><select style="width:240px;" name="<?php echo $value['id']; ?>" id="<?php echo $value['id']; ?>"><?php foreach ($value['options'] as $option) { ?><option<?php if ( get_settings( $value['id'] ) == $option) { echo ' selected="selected"'; } elseif ($option == $value['std']) { echo ' selected="selected"'; } ?>><?php echo $option; ?></option><?php } ?></select></td>
</tr>
 
<tr>
<td><small><?php echo $value['desc']; ?></small></td>
</tr><tr><td colspan="2" style="margin-bottom:5px;border-bottom:1px dotted #000000;">&nbsp;</td></tr><tr><td colspan="2">&nbsp;</td></tr>
 
<?php
break;
 
case "checkbox":
?>
<tr>
<td width="20%" rowspan="2" valign="middle"><strong><?php echo $value['name']; ?></strong></td>
<td width="80%"><?php if(get_option($value['id'])){ $checked = "checked=\"checked\""; }else{ $checked = "";} ?>
<input type="checkbox" name="<?php echo $value['id']; ?>" id="<?php echo $value['id']; ?>" value="true" <?php echo $checked; ?> />
</td>
</tr>
 
<tr>
<td><small><?php echo $value['desc']; ?></small></td>
</tr><tr><td colspan="2" style="margin-bottom:5px;border-bottom:1px dotted #000000;">&nbsp;</td></tr><tr><td colspan="2">&nbsp;</td></tr>
 
<?php break;
 
}
}
?>
 
<p class="submit">
<input name="save" type="submit" value="Save changes" />
<input type="hidden" name="action" value="save" />
</p>
</form>
<form method="post">
<p class="submit">
<input name="reset" type="submit" value="Reset" />
<input type="hidden" name="action" value="reset" />
</p>
</form>
 
<?php
}
add_action('admin_menu', 'mytheme_add_admin');

 

 

步骤2

添加如下代码到header.php文件 替换掉原来的style.css加载文件 实现与前台的衔接

 

<?php
	global $options;
	foreach ($options as $value) {
		if (get_settings( $value['id'] ) === FALSE) { $$value['id'] = $value['std']; } else { $$value['id'] = get_settings( $value['id'] ); }
	}
	?>			
	<?php switch ($mst_style_sheet) {
		 case "default":?>
		<link rel="stylesheet" href="<?php bloginfo('stylesheet_url'); ?>" type="text/css" media="screen" />
	<?php break; ?>	
	<?php case "green":?>
		<link rel="stylesheet" href="<?php bloginfo('template_directory'); ?>/green.css" type="text/css" media="screen" />
	<?php break; ?>
	<?php case "blue":?>
		<link rel="stylesheet" href="<?php bloginfo('template_directory'); ?>/blue.css" type="text/css" media="screen" />
	<?php break; ?>
	<?php case "yellow":?>
		<link rel="stylesheet" href="<?php bloginfo('template_directory'); ?>/yellow.css" type="text/css" media="screen" />
	<?php break; ?>	
	<?php }?>
?>

 

 

步骤3.

部署文件

将不同套的green.css blue.css yellow.css 文件加到与style.css相同的路径下

 

步骤4.

在后台切换 保存后 查看效果

 

扩展:

前台切换 可以参考

http://www.dynamicdrive.com/dynamicindex9/stylesheetswitcher.htm

 

 

分享到:
评论

相关推荐

    Jquery switcher样式表切换插件css样式表切换实现

    而jQuery Switcher 插件则是用于实现CSS样式表(style sheets)动态切换的一个实用工具。这个插件允许用户在页面加载后根据需求更换不同的样式表,从而提供更丰富的交互体验和视觉效果。 首先,我们要理解CSS样式表...

    IP切换软件Maxidix IP Switcher v15.3.15汉化版.rar

    Maxidix IP Switcher是一款网络配置切换工具,你可以添加多个配置文件,给每个配置文件设置不同的信息,如果有多个网络适配器,能为每个配置器设置各自的DHCP/IP/DNS信息。当您连接到一个新网络的时候,你是否还在...

    style-switcher:Mapbox GL JS样式切换器

    向mapbox-gl添加样式切换器 安装: npm i mapbox-gl-style-switcher --save 演示: 用法: import { MapboxStyleSwitcherControl } from "mapbox-gl-style-switcher" ; import { Map as MapboxMap } from "mapbox...

    华丽应用切换 Fancy Switcher v3.1.1 正式版

    当前版本:3.1.1 软件语言:中文 ...华丽应用切换Fancy Switcher是一款增强型的应用快速切换和管理工具,它可以通过手势轻松调出最近使用的App。支持特效和风格包,并可自定义各项视觉元素。相当的漂亮!

    Host Switcher-Hosts 切换的Chrome插件

    通过该 Chrome 插件,快捷方便的切换、设置 hosts 代理规则,而不用修改系统 hosts 文件,方便web开发人员在 测试/开发/线上 等环境快速切换;同时顺便支持本地端口的代理设置

    Style Switcher 使用jQuery 切换网页风格

    内容索引:脚本资源,jQuery,样式切换,风格选择 Style Switcher 是一款使用jQuery 进行网页风格切换的例子,可能看上去不太直观,实例仅给出了使得jQuery控制不同的CSS片段,最后控制网页中某段文字的显示方式,以及...

    推荐一款高效网络配置切换神器(IP Switcher)

    IP Switcher 是一款功能强大的网络配置切换软件,它可以帮助用户在不同的网络环境下快速切换 IP 地址、子网掩码、网关、DNS 等网络设置,提高工作效率。 二、软件特点: 快速切换 IP Switcher 可以在几秒钟内完成...

    Maxidix IP Switcher 14.9中文注册版.rar

    Maxidix IP Switcher是一款方便实用的IP配置切换工具,你可以为指定的网络适配器设置不同的IP地址和DNS地址,方便你一键进行切换。点击添加配置文件,可以添加网卡的IP地址、子网掩码地址、网关的IP地址。可自动...

    图片切换Switcher

    【图片切换Switcher】是一种常见的UI交互设计,用于在多个图像之间进行平滑过渡,常应用于各种应用程序,如相册、广告轮播等。在这个项目中,开发者利用`imageSwitch`来实现这一功能,旨在提供一种简洁而流畅的图片...

    ip地址切换器汉化版(支持win7).rar

    Maxidix IP Switcher是一款很不错的IP地址切换工具,创建好不同的网络配置文件,可以很方便地在不同网络IP之间进行切换。每个配置文件需要设置各自使用的网络适配器、IP地址、掩码及网关、DNS服务器等,支持使用...

    Switcher,.zip

    标题中的"Switcher.zip"指的是一个压缩包文件,其中包含了一个名为"Switcher"的开源项目。这个项目设计用于帮助开发者在不同的视图之间进行平滑的切换,比如内容、进度和空占位符视图。这样的功能在很多应用程序中都...

    谷歌切换页签插件-Popup Tab Switcher 1.7.11

    对于经常需要处理多任务的用户,Popup Tab Switcher可以极大地提高工作效率,减少在多个窗口间反复切换的时间。特别是在进行研究、工作或者在线学习时,能够迅速在相关页面间跳转,对于保持工作流的连贯性具有重要...

    device-theme-switcher.1.8h汉化版

    1. 下载并安装:首先,将解压后的“device-theme-switcher.1.8汉化版”文件上传到WordPress的plugins目录下,然后在WordPress后台激活插件。 2. 配置设置:进入WordPress的“插件”页面,找到Device Theme Switcher...

    Elite Proxy Switcher 1.23 汉化版

    Elite Proxy Switcher 1.23 汉化版 可以切换代理

    Flash版本切换器forIE flash_switcher_win.xpi

    Flash版本切换器forIE flash_switcher_win.xpi

    Laravel开发-laravel-locale-switcher

    在Laravel框架中,"Laravel开发-laravel-locale-switcher"是一个专门用于处理多语言切换的中间件。这个中间件使得用户可以在不同的语言环境中轻松地浏览网站,这对于构建国际化应用至关重要。Laravel是一个优雅的...

    BMD ATEM Switcher开发SDK7.4版本

    这些切换台提供了多通道输入、多格式支持、实时特效、键控、多视图监控等众多功能,是视频制作中的核心设备。 Blackmagic ATEM SDK 7.4的发布,意味着开发人员可以利用这个版本的更新来优化他们对ATEM切换台的控制...

    低成本简易多通道8选1切换板-Switcher V1.2.zip

    《低成本简易多通道8选1切换板-Switcher V1.2》 在电子设计领域,多通道切换系统是常见的应用场景,例如在测试设备、数据采集系统或是控制系统中。本项目名为“Switcher V1.2”,是一款低成本、简易实现的8选1切换...

    ubuntu 切换java版本profile文件

    使用`sudo chmod a+x .profile*`命令可以给`.profile`文件及其任何关联的备份或链接文件添加执行权限。 ```bash sudo chmod a+x ~/.profile* ``` `.profile`文件通常包含了启动时执行的命令,例如设置环境变量。...

    浏览器UA切换 User Agent Switcher xml

    浏览器UA切换 UserAgent UserAgentSwitcher.xml

Global site tag (gtag.js) - Google Analytics