位置: 编程技术 - 正文

使用jQuery实现Web页面换肤功能的要点解析(jqueryw3c)

编辑:rootadmin

推荐整理分享使用jQuery实现Web页面换肤功能的要点解析(jqueryw3c),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:使用JQuery实现简单的拼图网页,jqueryw3c,使用jquery实现的项目,jquery weui,使用jquery实现的项目,使用JQuery实现简单的拼图网页,web jquery,如何用jquery,内容如对您有帮助,希望把文章链接给更多的朋友!

网页换肤是一门老技术了,老的现在都不怎么流行了。但是,有时候有些客户就是想要这个换肤功能。于是就实践做了一下网页换肤,结果遇到了很多问题。

网页换肤的基本原理

基本原理很简单,就是使用 JS 切换对应的 CSS 样式表。例如导航网站 Hao 的右上方就有网页换肤功能。除了切换 CSS 样式表文件之外,通常的网页换肤还需要通过 Cookie 来记录用户之前更换过的皮肤,这样下次用户访问的时候,就可以自动使用上次用户配置的选项。

那么基本工作流程就出来了:访问网页——JS 读取 Cookie ——如果没有,使用默认皮肤——如果有,使用指定皮肤;用户点击换肤选项——JS 控制替换对应的 CSS 样式表——将皮肤选项写进 Cookie 保存。

网页换肤事先需要的准备

首先你可能要准备多套 CSS 样式表文件,当点击换肤按钮的是,使用 JS 来切换对应的 CSS 样式表。之后,就是在网页上增加一个 ul li 列表,用 CSS 修饰一下做成换肤选项。例如:

下面我们就来看具体功能代码。

实现点击切换对应 CSS 功能

首先,我们的皮肤选项的 HTML 结构是这样的

然后在网页的顶部偏下的位置放上一个空的 link 标签,我们将会使用 jQuery 为这个 link 标签赋予不同的 CSS 文件实现切换效果

使用jQuery实现Web页面换肤功能的要点解析(jqueryw3c)

其中,我自定义了一个 data-href 属性来存放系统默认的皮肤,这样当页面加载完成之后,如果 JS 没有检测到 Cookie 中的皮肤信息,就会把 data-href 中的内容赋值上去。之后就是大家熟悉的 jQuery 代码:

大体的逻辑就是获取到当前皮肤的 class 然后截取出来 skin* 然后通过一个函数得到其对应的 CSS 文件。skincssurl 记载的是网页的非皮肤 CSS 文件,主要用来获取当前网页的 CSS 目录 URL ,最后将混合好的 CSS 皮肤文件赋值准备好的空 link 中,实现换肤。

增加 Cookie 记录皮肤功能

这里主要用到两个自定义的函数,用来创建、读取 Cookie 内容。

你只需要把这两个函数复制到 JS 代码区域即可。在 jQuery 点击换肤的功能代码中,最后一句就创建了一个 Cookie,等网页加载完成之后,我们需要使用 JS 读取 Cookie 内容,然后使用 if 判断:

不要被这么乱的代码吓晕了,实际上逻辑很简单,先获取 Cookie 的皮肤值,如果有就为对应的皮肤选项高亮并且转换得到对应的 CSS 皮肤文件赋值。如果没有 Cookie 内容,就将 data-href 属性中记录的值赋值进去。

网页换肤的闪烁问题和不完美解决方案

网页换肤中,会遇到闪烁的问题。就是当点击切换按钮的时候,更换颜色或者图片会闪烁一下。或者使用 Cookie 记录之后,用户使用了非默认的皮肤,也会闪烁一下,先出现默认的样式然后再闪烁切换成用户自己选择的样式。

这种影响用户体验的现象肯定要彻底消灭,但是一直没有找到完美的解决方法。因为浏览器默认的是优先渲染 CSS 之后再加载 JS,特别是使用 Cookie 记录的皮肤,先渲染现有的 CSS 之后,JS 才能读取然后切换到皮肤。原理是这样的,跟客户协商之后,客户给出了一个“无闪烁”的换肤效果示例,是 MG 很早的一款主题。同样的 Cookie 记录等,但是他的作品确实没有闪烁情况。

于是我就查看了他的 JS 代码,没有发现特殊之处,后来才想明白,这种闪烁问题,在图片比较多的网页中效果尤其明显,因为切换的 CSS 需要加载图片需要更多时间。而 MG 那款主题中,切换的 CSS 文件只是改变了几个 background 颜色,加载速度快到你眼球反应不过来就造成了不闪烁的假象。

不完美解决方案也是有的,点击切换按钮之后的闪烁情况,也是因为要加载图片等,那么我们可以在访问网页的时候,使用预加载技术将其他皮肤图片预加载或者使用 CSS Sprite 技术做成一张大图片。

至于 Cookie 记录闪烁的问题,这是浏览器渲染的硬伤,只能尽量减少换肤需要改变的地方,尽量压缩图片减小体积。然后优先加载没有任何皮肤的基础样式,之后使用 JS 加载默认样式或者读取 Cookie 获取的皮肤选项。这样处理,访问网页的时候会先显示白色或者无颜色,之后直接切换成之前选择的皮肤的颜色,而不会从默认的颜色闪烁变成另一种颜色从而提升一定的用户体验。

使用jQuery制作遮罩层弹出效果的极简实例分享 客户的网站上突然需要一个遮罩弹窗效果,也可以称作暗箱之类的,具体效果就是网页中背景变成半透明,然后在屏幕中间出现一个菜单之类的东西。

基于jQuery倒计时插件实现团购秒杀效果 倒计时一般是用来表示未来某一时刻距现在时刻还剩多少时间。倒计时在WEB上应用非常广泛,如考试系统倒计时,团购网站中的优惠活动倒计时等等。今天

jQuery Easyui 验证两次密码输入是否相等 什么是jQueryEasyUIjQueryEasyUI框架提供了创建网页所需的一切,帮助您轻松建立站点。easyui是一个基于jQuery的框架,集成了各种用户界面插件。easyui提供建

标签: jqueryw3c

本文链接地址:https://www.jiuchutong.com/biancheng/386557.html 转载请保留说明!

上一篇:jQuery中$.each()函数的用法引申实例(jquery中each()方法的作用及使用)

下一篇:使用jQuery制作遮罩层弹出效果的极简实例分享(jqueryfilter)

  • 公司注册实缴资金能取出吗
  • 已经缴纳的税款怎么做账
  • 资产负债表存货怎么填列
  • 取得的管理部门证书
  • 罚款收据与通用的区别
  • 商品房的销售方式有哪些
  • 直线法计提折旧的公式预计净残值
  • 税前扣除凭证的内部凭证
  • 逾期不缴纳税款责令限改期限内改正的
  • 现金账怎么记账图例
  • 新个税年终奖怎么申报
  • 坏账确认无法收回的会计分录
  • 经营租赁不动产发票备注栏
  • 对外捐赠衣物怎样入账
  • 企业收到工程款开发票要扣哪些税
  • 外购低值易耗品可以抵扣进项税额吗
  • 金税盘费用如何抵扣
  • 未办理房屋预售许可证怎么处理
  • 当期损益包括哪些费用
  • 医疗器械 税点
  • 防洪工程维护费取消
  • 员工借款收不回来账务处理
  • 外地预缴工会其他经费计入什么科目?
  • 办公车辆的燃油费过路费怎么报销?
  • 付佣金代扣个人所得税税前列支
  • 国家统计局一套表平台网址
  • 投资长期溢价债券,容易获取投资收益
  • 劳务公司开具劳务费发票
  • PHP:Memcached::appendByKey()的用法_Memcached类
  • 专项资金下达期限
  • Sublime Text v4.0(4143)破解方法
  • 黑沙滩是什么意思
  • 企业股股票
  • php框架ci
  • 公司缴纳残保金怎么做账
  • 外出培训餐费要进差旅费吗
  • 数据可视化分析
  • python爬虫中数据接口的含义
  • 土地增值税的扣除项目金额怎么算
  • 收到银行结息收据3
  • 多收了钱怎么记账
  • 企业之间借款有利息要开票吗
  • 员工福利费属于什么会计科目
  • 累计带薪缺勤账务怎么处理
  • 库存商品的成本主要包括
  • 子公司的注册资金需要母公司股东出吗?
  • 新建厂房需要缴纳什么税
  • 残次品生产成本怎么算
  • 错帐的查找方法
  • 跨年度的项目如何做
  • 记账凭证的项目有哪些
  • 会计可以用收据做账吗
  • sqlserver CONVERT()函数用法小结
  • mysql服务自动停止运行
  • win10 rs5
  • 自动启动win10
  • ubuntu装完后重启找不到操作系统
  • windows xp怎样禁止弹出广告
  • ip冲突不能上网怎么解决
  • 苹果Mac系统怎么装
  • win10 u盘写保护
  • windows10 经典模式
  • windows7怎么设置右键菜单
  • win7 虚拟磁盘
  • 微信小程序实现人脸识别
  • javascript语言入门教程
  • excel最小化后再次选择不弹出来
  • opengl gpu编程
  • 批处理重启后继续运行
  • ip安全策略设置报错
  • socketio视频教程
  • shell脚本编写简单计算器
  • js自动切换图片效果
  • unity持久化存储
  • script标签可以放在html哪个位置
  • 广州市地税局副局长
  • 亚马逊网上商城
  • 最新印花税税目内容
  • 税务稽查团队
  • 税票电话号码变更影响抵扣吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设