在vue3中Element Plus切换主题

  一共2种方法。

目录

第一种

第二种


第一种

暗黑模式,使用useDark,可以不用安装Element Plus,只切换页面的背景颜色,不改变Element Plus控件的颜色,本案例安装了Element Plus。

1.先建立一个可运行的程序

2.创建useDark.js

import {
	ref
} from 'vue'

export function useDark() {
	const isDark = ref(false)

	const toggle = () => {
		isDark.value = !isDark.value
		if (isDark.value) {
			document.documentElement.classList.add('dark')
		} else {
			document.documentElement.classList.remove('dark')
		}
	}

	return {
		isDark,
		toggle
	}
}

3.HelloWorld.vue代码

<template>
	<div :class="{ dark: isDark }">
		<h1>{{ msg }}</h1>
		<el-button type="primary">Primary</el-button>
		<h1>Dark Mode Demo</h1>
		<p>Current mode: {{ isDark ? 'Dark' : 'Light' }}</p>
		<button @click="toggleTheme">Toggle Theme</button>
	</div>
</template>
<script setup>
	import {
		ref
	} from 'vue'
	import {
		useDark
	} from './useDark'
	defineProps({
		msg: String
	})

	const dark = useDark()

	const isDark = ref(dark.isDark)
	const toggleTheme = () => {
		dark.toggle()
	}
	const count = ref(0)
</script>
<style>
	.dark {
		background-color: #333;
		/* red */
		color: #fff;
	}
</style>

 4.效果

点击切换按钮,就可以切换暗黑模式了

5.拓展

可以把颜色改成别的颜色,例如改成红色,这样就可以形成2种颜色的切换了

 

 源码:

https://download.csdn.net/download/u012563853/87537505

第二种

1.首先用HBuilder X建立一个vue3项目,如图所示

2.把不需要的代码删除,增加切换按钮

HelloWorld.vue代码

<template>
	<div>
		<el-button type="primary">Primary</el-button>
		<el-switch @click="toggleDarkMode()" v-model="value1" />
	</div>
</template>

<script setup>
	import {
		ref
	} from 'vue'

	const value1 = ref(true)
	const isDarkMode = ref(false)
	const toggleDarkMode = () => {
		isDarkMode.value = !isDarkMode.value
		document.body.classList.toggle('dark-mode')
	}
</script>



<style scoped>
	a {
		color: #42b983;
	}
</style>

3.命令安装

cnpm install element-plus --save

  

4.main.js代码

import { createApp } from 'vue'
import App from './App.vue'
 
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import 'element-plus/theme-chalk/dark/css-vars.css'//这句是暗黑模式切换
 
const app = createApp(App)
 
app.use(ElementPlus)
app.mount('#app')

5.找到css-vars.css文件

在里面增加代码

/* 暗黑模式 */
.dark-mode {
	background-color: #1f1f1f;
	/* background-color: #F53181; */
	color: #fff;

	/*  .el-button {
    background-color: #333;
    color: #fff;
  }

  .el-input {
    background-color: #333;
    color: #fff;
  } */
}

6.效果

 

 

 拓展:

整体修改控件的颜色

<template>
	<h1>{{ msg }}</h1>
	<el-button type="primary">Primary</el-button>
	<el-switch v-model="value1" />
	<el-switch v-model="value2" class="ml-2" style="--el-switch-on-color: #13ce66; --el-switch-off-color: #ff4949" />
</template>
<script setup>
	import {
		ref,
		onMounted
	} from 'vue'

	defineProps({
		msg: String
	})
	const value1 = ref(true)
	const value2 = ref(true)
	onMounted(() => {
		document.body.style.setProperty('--el-color-primary', '#E6196D');
		document.body.style.setProperty('--el-color-primary-light-9', '#95d475');
		document.body.style.setProperty('--el-color-primary-light-3', '#95d475');
	})

	const count = ref(0)
</script>
<style scoped>
</style>

来源:在vue3中Element Plus切换主题_element plus 主题-CSDN博客

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要在 Vue 3 和 Element Plus 增加请求接口,你可以通过使用 Vue 3 提供的 `axios` 或者 Element Plus 提供的 `ElMessage` 组件来实现。下面是一个示例,展示如何使用 `axios` 发起请求并在请求成功或失败时使用 `ElMessage` 显示提示信息。 首先,确保你已经安装了 `axios` 和 `element-plus`。你可以使用 npm 或者 yarn 进行安装,具体的安装命令可以参考官方文档。 在你的组件,首先需要导入 `axios` 和 `ElMessage` 组件: ```javascript import axios from 'axios' import { ElMessage } from 'element-plus' ``` 然后,在需要发起请求的地方,可以使用 `axios` 发起请求,并在请求成功或失败时显示相应的提示信息: ```javascript axios.post('/api/your-endpoint', requestData) .then(response => { // 请求成功处理逻辑 ElMessage.success('请求成功') // 处理返回的数据 console.log(response.data) }) .catch(error => { // 请求失败处理逻辑 ElMessage.error('请求失败') // 处理错误信息 console.error(error) }) ``` 在上述示例,我们使用 `axios.post` 方法发起一个 POST 请求,传入请求的 URL 和请求数据 `requestData`。在 `then` 方法处理请求成功的逻辑,在 `catch` 方法处理请求失败的逻辑。通过 `ElMessage.success` 和 `ElMessage.error` 方法,我们可以分别显示请求成功和失败的提示信息。 请注意,上述示例的 `/api/your-endpoint` 是一个示例的请求接口地址,你需要根据你的实际情况替换为正确的接口地址。 希望这个示例能够帮助你在 Vue 3 和 Element Plus 增加请求接口。如果有任何问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

故里2130

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值