這篇文章主要為大家詳細介紹了微信小程式實現換膚功能,具有一定的參考價值,有興趣的朋友們可以參考一下
pc或者移動端實現換膚功能還是比較簡單的,大致就是需要換膚的css,還有正常的css;把當前皮膚類型存入本地;然後通過js讀取並判斷當前應該加載哪套css。
由於微信小程式沒有操作wxss的api,所以實現的方式有點不一樣,大致如下:
1.需要換膚的wxss,正常的wxss。
2.每個頁面都引入換膚的wxss(因為換膚每個頁面都需要改變)。
3.在app.js的globalData裡設定預設的皮膚類型。
4.每個頁面onload的時候,讀取storage裡的資料並設定目前皮膚類型的值。
範例:
第一步:結構
<view class='page' id='{{SkinStyle}}'> <view class='header'> <view class='h-skin iconfont {{SkinStyle!=="normal"?"icon-moon":"icon-sun"}}' bindtap='bgBtn'></view> </view> </view>
備註:由於無法直接操作微信小程式的根節點page,要實作全螢幕背景色的修改,只能模仿一個高度寬度都是100%的p(觀點)。上面就是class為page的這個p(view)。
id='{{SkinStyle}}',設定id是為了根據當前皮膚類型,讓皮膚的wxss樣式的權重大於正常wxss樣式的權重,這樣有時候就沒必要加上! important了。
根節點page需要在wxss中設定width:100%;height:100%。然後設定class為page的p(view)寬高都是100%。這樣就等於有個能操作的根節點page了。
{{SkinStyle!=="normal"?"icon-moon":"icon-sun"}}這句話是判斷當前的皮膚類型,如果是normal就是icon-sun,否則就是icon- moon。
第二步:樣式wxss
皮膚wxss:
#dark { background: #333; } #dark .header .h-skin{ color: white; }
正常wxss:
.page .header .h-skin { color: #060505; padding: 0 32rpx; font-size: 40rpx; }
公用wxss:
page { height: 100%; width: 100%; } .page { width: 100%; height: 100%; }
備註:這分別是三個檔案。皮膚是theme.wxss,正常是index.wxss,公用是com.wxss
# 因為換膚是所有頁面都變化,所以我建議把皮膚的wxss檔@import "../theme-bg/ theme"; 載入到com.wxss檔案。然後每個頁面的wxss都@import這個公用的com.wxss檔。
第三步:js
首先:在app.js的檔案中,Page裡的globalData中設定:skin:"normal";即預設為normal皮膚
然後:在切換皮膚按鈕的頁面,添加切換按鈕的點擊事件bgBtn:
var app=getApp(); Page({ data:{ SkinStyle:"normal" //这里其实可以不要 }, bgBtn:function(){ if (this.data.SkinStyle==="normal"){ app.globalData.skin = "dark"; //设置app()中皮肤的类型 this.setData({ SkinStyle: app.globalData.skin //设置SkinStyle的值 }) wx.setStorage({ //设置storage key: 'skins', data: app.globalData.skin, }) }else{ app.globalData.skin="normal"; this.setData({ SkinStyle: "normal" }) wx.setStorage({ key: 'skins', data: app.globalData.skin, }) } } })
最後:在每個頁面,包括切換皮膚的頁面的Page中的onLoad事件裡,讀取storage並設定SkinStyle的值:
onLoad: function (options) { var that=this; wx.getStorage({ key: 'skins', success: function(res) { that.setData({ SkinStyle: res.data }) }, }) }
這樣每次啟動都能自動設定上一次設定的皮膚了。
最終效果圖:
上面是我整理給大家的,希望今後會對大家有幫助。
相關文章:
#以上是微信小程式實現換膚功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!

随着移动互联网技术和智能手机的普及,微信成为了人们生活中不可或缺的一个应用。而微信小程序则让人们可以在不需要下载安装应用的情况下,直接使用小程序来解决一些简单的需求。本文将介绍如何使用Python来开发微信小程序。一、准备工作在使用Python开发微信小程序之前,需要安装相关的Python库。这里推荐使用wxpy和itchat这两个库。wxpy是一个微信机器

小程序能用react,其使用方法:1、基于“react-reconciler”实现一个渲染器,生成一个DSL;2、创建一个小程序组件,去解析和渲染DSL;3、安装npm,并执行开发者工具中的构建npm;4、在自己的页面中引入包,再利用api即可完成开发。

微信小程序是一种轻量级的应用程序,可以在微信平台上运行,不需要下载安装,方便快捷。Java语言作为一种广泛应用于企业级应用开发的语言,也可以用于微信小程序的开发。在Java语言中,可以使用SpringBoot框架和第三方工具包来开发微信小程序。下面是一个简单的微信小程序开发过程。创建微信小程序首先,需要在微信公众平台上注册一个小程序。注册成功后,可以获取到

实现思路x01服务端的建立首先,在服务端,使用socket进行消息的接受,每接受一个socket的请求,就开启一个新的线程来管理消息的分发与接受,同时,又存在一个handler来管理所有的线程,从而实现对聊天室的各种功能的处理x02客户端的建立客户端的建立就要比服务端简单多了,客户端的作用只是对消息的发送以及接受,以及按照特定的规则去输入特定的字符从而实现不同的功能的使用,因此,在客户端这里,只需要去使用两个线程,一个是专门用于接受消息,一个是专门用于发送消息的至于为什么不用一个呢,那是因为,只

PHP与小程序的地理位置定位与地图显示地理位置定位与地图显示在现代科技中已经成为了必备的功能之一。随着移动设备的普及,人们对于定位和地图显示的需求也越来越高。在开发过程中,PHP和小程序是常见的两种技术选择。本文将为大家介绍PHP与小程序中的地理位置定位与地图显示的实现方法,并附上相应的代码示例。一、PHP中的地理位置定位在PHP中,我们可以使用第三方地理位

本篇文章给大家带来了关于微信小程序的相关问题,其中主要介绍了如何在小程序中用公众号模板消息,下面一起来看一下,希望对大家有帮助。

随着小程序的广泛应用,越来越多的开发者需要将其与后台服务器进行数据交互,其中最常见的业务场景之一就是上传文件。本文将介绍在小程序中实现文件上传的PHP后台实现方法。一、小程序中的文件上传在小程序中实现文件上传,主要依赖于小程序APIwx.uploadFile()。该API接受一个options对象作为参数,其中包含了要上传的文件路径、需要传递的其他数据以及

苏州健康码的小程序叫“苏康码”,它是苏州市疫情防控指挥部指定的通行服务码,疫情防控期间在全市范围内通用,可以作为广大民众日常出行的重要凭证,同时作为防疫人员查验的主要依据;也是省内所有来苏逗苏人员以及在苏工作学习生活,旅游或临时停留人员申报的键康申报数据为基础,结合相关数据比对后动态生成的个人电子健康凭证。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver CS6
視覺化網頁開發工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),