angular2中一种换肤实现方案
思路:整体思路是准备多套不同主题的css样式。在anguar项目启动时,首先加载的index.html中先引入一套默认的样式。当我们页面有动作时再切换css. 可以通过url传参触发,也可以通过button触发。下面演示的是url传参切换。button同理,只要调用有同的方法触发就行。
首先,index.html
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>CMDB Front</title>
<base href="./"> <meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="icon" type="image/x-icon" href="favicon.ico">
<!--下面两行是引入换肤的css样式-->
<link href="assets/skin/css/classic.css" rel="stylesheet" type="text/css">
<link id="skin" rel="stylesheet" type="text/css"> </head>
<body>
<app-root>
<div style=" display: flex;justify-content: center;align-items: center;height: 100vh;color: #DDDDDD;text-transform: uppercase;font-family: -apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica,sans-serif;font-size: 2.5em;text-shadow: 2px 2px 10px rgba(0,0,0,0.2);background: white;margin: 0;padding: 0;">
Loading
<span >.</span>
<span >.</span>
<span >.</span>
</div>
</app-root> </body>
</html>

第二步是在根组件app.component.ts中接收url参数
import {Component, OnInit} from '@angular/core';
import {ActivatedRoute} from "@angular/router";
import {SkinService} from "./shared/SkinService";
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent implements OnInit{
public dataSkin:any; //接收路由传参的皮肤参数
title = 'app';
constructor(
public activeRoute:ActivatedRoute,
public skinService:SkinService
) { }
ngOnInit(){
this.activeRoute.queryParams.subscribe(params=>{
this.dataSkin=params['defaultTheme'];
console.log("######",this.dataSkin)
if(this.dataSkin =='gwjd'){
this.skinService.showStyleOne(this.dataSkin);//国网经典主题
return;
}
if(this.dataSkin=='classic'){
this.skinService.showStyleTwo(this.dataSkin); //默认主题
return;
}
if(this.dataSkin=='hhyz'){
this.skinService.showStyleThree(this.dataSkin); //浩瀚宇宙主题
return;
}
if(this.dataSkin=='kjzg'){
this.skinService.showStyleFour(this.dataSkin); //科技之光主题
return;
}
if(this.dataSkin=='lscs'){
this.skinService.showStyleFive(this.dataSkin); //绿色城市主题
return;
}
if(this.dataSkin=='rqpb'){
this.skinService.showStyleSix(this.dataSkin); //热情拼搏主题
return;
}
else{
this.skinService.showStyleDefault(); //如果路由里没有携带皮肤参数,显示默认皮肤。
}
});
}
}
其次是skinService做的cookie处理。
import {Injectable} from "@angular/core";
/**
* Created by zhengxiaoya on 2018/6/11 13:28.
*/
@Injectable()
export class SkinService {
constructor(){}
showStyleOne(skin){
var Days = 30;
var exp = new Date();
exp.setTime(exp.getTime() + Days*24*60*60*1000);
// 获取到样式1的id.
// var StyleOneId=document.getElementById('u2923').id;
var StyleOneId=skin;
console.log("######a",StyleOneId);
// 把每次点击切换后的皮肤值存在cookie中
document.cookie="skinId="+(StyleOneId) +"; expires=" + exp.toDateString();
// add selected
$("#"+StyleOneId).addClass("selected").siblings().removeClass("selected");
$('#skin').attr("href","assets/skin/css/"+(StyleOneId)+".css");
}
showStyleTwo(skin){
var Days = 30;
var exp = new Date();
exp.setTime(exp.getTime() + Days*24*60*60*1000);
// 获取到样式1的id.
// var StyleTwoId=document.getElementById('u2924').id;
var StyleTwoId=skin;
console.log("StyleTwoId",StyleTwoId);
// 把每次点击切换后的皮肤值存在cookie中
document.cookie="skinId="+(StyleTwoId) +"; expires=" + exp.toDateString();
$('#skin').attr("href","assets/skin/css/"+(StyleTwoId)+".css");
}
showStyleThree(skin){
var Days = 30;
var exp = new Date();
exp.setTime(exp.getTime() + Days*24*60*60*1000);
// 获取到样式1的id.
// var StyleThreeId=document.getElementById('u2933').id;
var StyleThreeId=skin;
console.log("StyleThreeId",StyleThreeId);
// 把每次点击切换后的皮肤值存在cookie中
document.cookie="skinId="+(StyleThreeId) +"; expires=" + exp.toDateString();
$('#skin').attr("href","assets/skin/css/"+(StyleThreeId)+".css");
}
showStyleFour(skin){
var Days = 30;
var exp = new Date();
exp.setTime(exp.getTime() + Days*24*60*60*1000);
// 获取到样式1的id.
// var StyleThreeId=document.getElementById('u2933').id;
var showStyleFour=skin;
console.log("StyleThreeId",showStyleFour);
// 把每次点击切换后的皮肤值存在cookie中
document.cookie="skinId="+(showStyleFour) +"; expires=" + exp.toDateString();
$('#skin').attr("href","assets/skin/css/"+(showStyleFour)+".css");
}
showStyleFive(skin){
var Days = 30;
var exp = new Date();
exp.setTime(exp.getTime() + Days*24*60*60*1000);
// 获取到样式1的id.
// var StyleThreeId=document.getElementById('u2933').id;
var showStyleFive=skin;
console.log("StyleThreeId",showStyleFive);
// 把每次点击切换后的皮肤值存在cookie中
document.cookie="skinId="+(showStyleFive) +"; expires=" + exp.toDateString();
$('#skin').attr("href","assets/skin/css/"+(showStyleFive)+".css");
}
showStyleSix(skin){
var Days = 30;
var exp = new Date();
exp.setTime(exp.getTime() + Days*24*60*60*1000);
// 获取到样式1的id.
// var StyleThreeId=document.getElementById('u2933').id;
var showStyleSix=skin;
console.log("StyleThreeId",showStyleSix);
// 把每次点击切换后的皮肤值存在cookie中
document.cookie="skinId="+(showStyleSix) +"; expires=" + exp.toDateString();
$('#skin').attr("href","assets/skin/css/"+(showStyleSix)+".css");
}
showStyleDefault(){
var Days = 30;
var exp = new Date();
exp.setTime(exp.getTime() + Days*24*60*60*1000);
// 获取到样式1的id.
// var StyleThreeId=document.getElementById('u2933').id;
var StyleThreeId='classic';
console.log("StyleThreeId",StyleThreeId);
// 把每次点击切换后的皮肤值存在cookie中
document.cookie="skinId="+(StyleThreeId) +"; expires=" + exp.toDateString();
$('#skin').attr("href","assets/skin/css/"+(StyleThreeId)+".css");
}
}
url传参:http://localhost:4200/?defaultTheme='gwjd'
angular2中一种换肤实现方案的更多相关文章
- 在WPF中创建可换肤的用户界面
原文:在WPF中创建可换肤的用户界面 在WPF中创建可换肤的用户界面. ...
- Android App插件式换肤实现方案
背景 目前很多app都具有换肤功能,用户可以根据需要切换不同的皮肤,为使我们的App支持换肤功能,给用户提供更好的体验,在这里对换肤原理进行研究总结,并选择一个合适的换肤解决方案. 换肤介绍 App换 ...
- VC6.0中MFC界面换肤简例
利用VC中的MFC进行界面设计时,发现界面上的各控件无法简易地进行调整,比如字体大小.颜色.格式等. 为了改变外观,小小地美化一下,今天决定动手一试. 网上提供的库和方法不计其数,我选择了SkinMa ...
- iOS开发--换肤简单实现以及工具类的抽取
一.根据美工提供的图片,可以有两种换肤的方案. <1>美工提供图片的类型一: <2>美工提供图片的类型二:这种分了文件夹文件名都一样的情况,拖入项目后最后用真实文件夹(蓝色文件 ...
- Android可更换布局的换肤方案
换肤,顾名思义,就是对应用中的视觉元素进行更新,呈现新的显示效果.一般来说,换肤的时候只是更新UI上使用的资源,如颜色,图片,字体等等.本文介绍一种笔者自己使用的基于布局的Android换肤方案,不仅 ...
- 节日换肤通用技术方案__iOS端实现
一.问题的提出 不知道大家有没有发现, 元旦期间, 很多APP界面里的图标都换成了具有节日气氛的样式, 而在过了元旦节之后, 这些图标又悄无声息的变回了本来的面貌. 这些具有短暂生命周期.而又必须在固 ...
- Android 换肤功能的实现(Apk插件方式)
一.概述 由于Android 没有提供一套统一的换肤机制,我猜可能是因为国外更注重功能和体验的原因 所以国内如果要做一个漂亮的换肤方案,需要自己去实现. 目前换肤的方法大概有三种方案: (1)把皮肤资 ...
- C# 实现对窗体(Form)换肤
http://www.csharpwin.com/csharpresource/2992.shtml 一直想写一个比较完整的.容易扩展的窗体换肤的方案,由于时间问题,都没去实现这个想法.现在有朋友提出 ...
- qt之窗口换肤(一个qss的坑:当类属性发现变化时需要重置qss,使用rcc资源文件)
1.相关文章 Qt 资源系统qt的moc,uic,rcc命令的使用 2.概要 毕业两年了,一直使用的是qt界面库来开发程序,使用过vs08.10.13等开发工具,并安装了qt的插件,最近在做客户 ...
随机推荐
- (转)Linux系统排查4——网络篇
原文:http://www.cnblogs.com/Security-Darren/p/4700387.html 用于排查Linux系统的网络故障. 网络排查一般是有一定的思路和顺序的,其实排查的思路 ...
- 转-Shell笔记——命令:Sort,uniq,join,cut,paste,split
转自:http://blog.csdn.net/wklken/article/details/6562098 Sort,uniq,join,cut,paste,split 命令—— Sort Sort ...
- GitKraken使用教程-基础部分(9)
10. 合并分支并解决冲突(conflict) 1) 合并分支 在代码管理过程中,切换分支或者同步服务器代码时,常常会出现代码冲突的情况,这种情况出现的原因一般是由于两个分支对同一个文件进行修改, ...
- iis部署网站打不开
事件查看器 1.crypt32报错 2.ASP.NET 2.0错误 解决办法: 1.crpt32报错,根本原因是计算机无法连接更新根证书所致,可能造成死循环. [1]必须连接到 Internet 或关 ...
- mysql存储过程游标加计划任务事件调度器
存储过程加事件调度器 -- 存储过程 (多个)游标的使用 临时表的使用(让执行时间从一个小时降低到5分钟)DELIMITER $$ DROP PROCEDURE IF EXISTS `eval_cal ...
- [转]c#匿名类
首先让我们看一个例子, 假设我们并没有Person类, 并且我们关心的属性只有Name和Age. 下面的代码演示了我们如何在没有声明类型的情况下来构建一个对象的: 1: var tom = new { ...
- js获取省市
前台代码 @{ IList<Provinces> allProvinces = ViewBag.AllProvinces; IList<Districts> allDistri ...
- 温习SQL语句
作为一名使用C#语言开发人员,就很难逃脱与SQLSERVER打交道,虽说我们是开发人员,但我想说的是,对数据库的操作还是应该时不时的拿出来温习一番.下面那就是我见过的一道有趣的SQL题目,与你们一起分 ...
- Android GreenDAO 3.0 不修改版本号的情况下增加、删除表、添加字段
最近项目中使用了GreenDAO的3.0以上的版本,出现需要增加删除表的需求,刚开始用,发现官方对增加和删除的方法是每次去修改数据库版本号,版本一旦升级,那么原来数据库中的表会全部删除再重建.太麻烦, ...
- 创建Podspec 并且发布到github spec
昨天,花了点时间,把自己的代码做成framework,但是发现,每次迁移项目或者更新项目都是一件很头疼的事情,索性,也跟着时尚了一回,把所有代码都扔到git里面进行管理,通过cococapods直接安 ...